要将Apollo GraphQL发送请求时将本地主机上的请求发送到指定的终端,可以使用Apollo Server来创建一个GraphQL服务器,并使用Express中间件将请求转发到指定的终端。
以下是一个示例代码,演示了如何设置Apollo Server和Express中间件来实现此功能:
首先,安装所需的依赖项:
npm install apollo-server-express express
然后,创建一个server.js
文件,并添加以下代码:
const { ApolloServer, gql } = require('apollo-server-express');
const express = require('express');
const { createProxyMiddleware } = require('http-proxy-middleware');
// 定义GraphQL Schema
const typeDefs = gql`
type Query {
hello: String
}
`;
// 定义GraphQL解析器
const resolvers = {
Query: {
hello: () => 'Hello, world!',
},
};
// 创建Apollo Server实例
const server = new ApolloServer({
typeDefs,
resolvers,
});
// 创建Express实例
const app = express();
// 设置GraphQL路由和中间件
server.applyMiddleware({ app });
// 设置代理中间件,将请求转发到指定的终端
app.use('/api', createProxyMiddleware({
target: 'http://指定的终端地址',
changeOrigin: true,
}));
// 启动服务器
app.listen({ port: 4000 }, () => {
console.log(`Apollo Server listening at http://localhost:4000${server.graphqlPath}`);
});
在上面的代码中,我们首先导入所需的依赖项,包括ApolloServer
和gql
来定义GraphQL的Schema,以及express
和createProxyMiddleware
来创建Express应用和设置代理中间件。
然后,我们定义了GraphQL的Schema和解析器,并使用ApolloServer
创建了一个GraphQL服务器实例。
接下来,我们创建了一个Express应用实例,并使用server.applyMiddleware
将GraphQL路由和中间件添加到Express应用中。
最后,我们使用app.use
设置了代理中间件,将/api
路径下的请求转发到指定的终端地址。
通过运行上述代码,您将在本地主机的4000端口上启动Apollo Server,并将请求转发到指定的终端地址。您可以通过访问http://localhost:4000/graphql
来访问GraphQL Playground并测试您的GraphQL查询和变异。