在GraphQL的Apollo服务器中,有两个主要的实现:apollo-server和apollo-server-express。它们的主要区别在于apollo-server-express是基于Express框架构建的,而apollo-server是基于Node.js HTTP服务器实现的。这意味着在使用这两个库时会有一些差异。
首先,看一下使用Express和apollo-server-express建立GraphQL端点的代码示例:
const express = require('express');
const { ApolloServer, gql } = require('apollo-server-express');
const app = express();
const typeDefs = gql`
type Query {
greet: String
}
`;
const resolvers = {
Query: {
greet: () => 'Hello, World!'
}
};
const server = new ApolloServer({ typeDefs, resolvers });
server.applyMiddleware({ app });
app.listen({ port: 4000 }, () =>
console.log(`Server ready at http://localhost:4000${server.graphqlPath}`)
);
这里我们使用了Express框架并通过调用applyMiddleware方法将Apollo服务器安装在路由上。GraphQL端点现在位于“/graphql”。
与此相反,使用Node.js HTTP服务器和apollo-server构建GraphQL端点的示例代码如下:
const { ApolloServer, gql } = require("apollo-server");
const http = require("http");
const typeDefs = gql`
type Query {
greet: String
}
`;
const resolvers = {
Query: {
greet: () => "Hello, World!",
},
};
const server = new ApolloServer({
typeDefs,
resolvers,
});
const httpServer = http.createServer();
server.applyMiddleware({ app: httpServer });
httpServer.listen({ port: 4000 }, () => {
console.log(`� Server ready at http://localhost:4000${server.graphqlPath}`);
});
这里我们使用了Node.js内置的HTTP服务器,通过调用createServer方法创建了服务器实例,并通过调用applyMiddleware将Apollo服务器安装在服务器实例上。GraphQL端点现