首页 文章

如何将请求标头传递给graphql解析器

提问于
浏览
1

我有一个由JWT授权的graphql endpoints . 我的JWT策略验证JWT然后将用户对象添加到请求对象 .

在一个宁静的路线中,我会像这样访问我的用户数据:

router.get('/', (req, res, next) => {
    console.log('user', req.user)
}

我想访问graphql解析器中的req.user对象,以便提取用户的ID . 但是,当我尝试记录 context 变量时,它始终为空 .

我是否需要配置我的graphql endpoints 以将 req 数据传递给解析器?

我的app.js我的graphql设置如下:

import { graphqlExpress, graphiqlExpress } from 'apollo-server-express';

app.use('/graphql', [passport.authenticate('jwt', { session: false }), bodyParser.json()], graphqlExpress({ schema }));

然后我就像我这样的解析器:

const resolvers = {
  Query: { 
    user: async (obj, {email}, context) => {
        console.log('obj', obj) // undefined
      console.log('email', email) // currently passed through in graphql query but I want to replace this with the user data passed in req / context
        console.log('context', context) // {}
        return await UserService.findOne(email)
    },
};

// Put together a schema
const schema = makeExecutableSchema({
  typeDefs,
  resolvers,
});

如何在解析器中访问我的JWT用户数据?

1 回答

  • 1

    显然你需要手动传递上下文,如下所示:

    app.use('/graphql', [auth_middleware, bodyParser.json()], (req, res) => graphqlExpress({ schema, context: req.user })(req, res) );
    

    如果有兴趣的话,找到答案here

相关问题