Apollo server 是一个用于构建 GraphQL 服务器的框架,其中 context 参数是一个可选的函数,用于在每个请求中创建一个上下文对象,以便在解析器函数以及任何后续中间件中使用。context 函数可以返回一个对象或 promise,如果返回了 promise,则服务器将在解析请求之前等待其解析完毕。
以下代码示例展示了如何在 Apollo server 中使用 context 参数:
const { ApolloServer, gql } = require('apollo-server');
// 定义 schema
const typeDefs = gql`
type Query {
hello: String
}
`;
// 定义 resolver
const resolvers = {
Query: {
hello: (_, __, { user }) => {
if (user) {
return `Hello, ${user.name}!`;
} else {
return 'Hello, stranger!';
}
}
}
};
// 定义 context 函数
const context = ({ req }) => {
const token = req.headers.authorization || '';
const user = getUserFromToken(token); // 从 token 获取用户信息
return { user };
};
// 创建 Apollo server 实例
const server = new ApolloServer({ typeDefs, resolvers, context });
// 启动服务器
server.listen().then(({ url }) => {
console.log(`Server ready at ${url}`);
});
在上面的示例中,我们定义了一个 context 函数,它会从传入的请求中获取授权 token 并根据 token 获取用户信息。然后我们将用户信息保存在 context 对象中,以供 resolver 使用。
需要注意的是,context 函数的参数是一个对象,其中包含了该次请求的一些相关信息,比如 HTTP 请求对象等。如果没有需要使用的信息,可以将该函数定义为一个空函数,例如:
const context = () => ({});