2017-03-07 56 views
2

我的客户端是这样的:

$http(
     { 
      method: 'GET', 
      url: myConfig.serverUrl + '/getUserId', 
      data: '', 
      headers: { 'Authorization' : '21321313'}, 
     }); 

服务器侧节点JS和表达:

app.use(function (req, res, next) { 
res.setHeader('Access-Control-Allow-Origin', '*'); 
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS'); 
res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With, content-type, Authorization'); 
next(); 

});

但要求没有设置授权值
OPTIONS /getUserId HTTP/1.1. Host: xxxxx. Connection: keep-alive. Pragma: no-cache. Cache-Control: no-cache. Access-Control-Request-Method: GET. Origin: http://localhost:9000. User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36. Access-Control-Request-Headers: authorization. Accept: */*. Referer: http://localhost:9000/. Accept-Encoding: gzip, deflate, sdch. Accept-Language: en-US,en;q=0.8,he;q=0.6.
我尝试了很多方法,但他们没有工作。 当我试图与邮递员,我得到的价值,所以我认为我的问题在我的角度,但我不知道是什么问题。

回答

1

这个问题在服务器端, 在“选项” API调用不需要检查授权

0

你需要指定authorization type'Authorization', 'Basic ZWx1c3VhcmlvOnlsYWNsYXZl'

+0

是啊试试这也..仍然没有工作。 –

0

在基本身份验证,BASE64来的用户名进行解码和密码。因此,注入并使用Base64来编码用户名和密码

var token = Base64.encode(username + ':' + password); 
$http.defaults.headers.common['Authorization'] = 'Basic ' + token; 
+0

仍然无法正常工作 –