【问题标题】:Cant get the token from request at server side无法从服务器端的请求中获取令牌
【发布时间】:2017-12-21 19:09:45
【问题描述】:

我指的是this 示例 我试图通过 $localStorage 从前端设置标头上的令牌。我已经在 $localStorage 验证了令牌。

$httpProvider.interceptors.push(['$q', '$location', '$localStorage', function($q, $location, $localStorage) {
        return {
            'request': function (config) {
                config.headers = config.headers || {};
                if ($localStorage.token) {
                    config.headers.Authorization = 'Bearer ' + $localStorage.token;
                }
                return config;
            },
            'responseError': function(response) {
                if(response.status === 401 || response.status === 403) {
                    $location.path('/signin');
                }
                return $q.reject(response);
            }
        };
    }]);

在服务器端,我试图在路由中间件中获取令牌以进行身份​​验证。

    var api = express.Router();
    api.use(function(req, res, next) {
        res.setHeader('Access-Control-Allow-Origin', '*');
        res.setHeader('Access-Control-Allow-Methods', 'GET, POST');
        res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type, Authorization');
        next();
    });

api.use(function(req, res, next) {    
    var bearerToken;
    var bearerHeader = req.headers["authorization"];

     }

bearerHeader 总是不确定。

【问题讨论】:

  • 你有没有在客户端调试过请求,看看localStorage.token是否不为空,是否真的发送到服务器?
  • 是的,有效并发送到服务器。

标签: angularjs node.js jwt


【解决方案1】:

试试

var bearerHeader = req.headers["Authorization"];

大写A而不是小A

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-07-04
    • 2015-05-04
    • 1970-01-01
    • 2023-03-30
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多