没有从响应头中的后端获取JWT令牌

问题描述

启动登录并创建令牌(如果注册了用户并使用res.header函数发送令牌)时,我正在向前端(登录应用程序)发送令牌,但是当我记录响应时。 strong>我只获得内容类型(我认为这是默认值),但是每当我尝试从邮递员登录时,都会在标题部分获得令牌。

这是我的快速后端服务器的代码,该代码正在创建令牌 并发送

router.post('/login',(req,res) => {
  let user = {email: req.body.email,password: req.body.password};
  if (validateUser(user)) {
    pool.query(
      'SELECT * FROM auth WHERE email = ($1) AND password = crypt(($2),password)',[user.email,user.password],)
    .then( (results) => {
      if(results.rows.length >= 1) {
        const token = jwt.sign({ name: results.rows[0].name,email: results.rows[0].email },process.env.TOKEN_SECRET);
        console.log(results.rows[0].name + ' Logged In');
        res.header('Authorization',token );
        res.status(200).json({message: "Welcome! " + results.rows[0].name });
      }
    },( error ) => {
      res.status(401).json({message: 'User Not Found'});
    }
   )
  }
  else {
    res.status(401).json({message: 'Invalid Credentials'});
  }
});

如果需要前端代码:

login() {
            this.axios.post( 'http://localhost:3000/users/login',{
                    email: this.email,password: this.password
                } )
                .then(
                    ( response ) => {
                        console.log( response.headers );
                        this.$router.push( {path: '/register'} );
                    },( error ) => {
                        alert( error.response.data.message );
                    }
                )
        }
    },};

解决方法

仅在发送请求时才使用Authorization标头;不在回应中。尝试改为在响应的正文中返回授权:

res.status(200).json({message: "Welcome! " + results.rows[0].name,token:token});

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...