[英]Apollo Server Express + Subscriptions error
我正在开发一个 Express 后端项目( Apollo Server + Express + GraphQL ),它的前端部分是用 React 制作的。
我想根据数据库更改在前端进行一些更改。 例如,当创建用户时。 我正在阅读一些文档,直到到达有关 React 订阅的 Apollo 文档。
然后我阅读了Apollo Boost 迁移以手动设置客户端,因为它不支持订阅。 然后我继续前进,直到设置 Express 以支持订阅,但我的代码不起作用。
这是我在控制台中得到的错误:
app.use(process.env.GRAPHQL_PATH, _bodyParser["default"].json(), (0, _apolloServerExpress.graphqlExpress)({
TypeError: (0 , _apolloServerExpress.graphqlExpress) 不是 Object 的函数。 (C:\\Web\\backend\\src/index.js:83:5)
这是第 83 行: graphqlExpress({ schema })
,我在下面的右侧发表了评论。
首先,我的 Express 是这样的:
import cors from 'cors';
import express from 'express';
import jwt from 'jsonwebtoken';
import mongoose from 'mongoose';
import { ApolloServer, AuthenticationError } from 'apollo-server-express';
import errorMessages from './mensajes/errors.json';
require('dotenv').config();
import schemas from './schemas';
import resolvers from './resolvers';
import userModel from './models/usuario';
const app = express();
app.use(cors());
const getUser = async (req) => {
const token = req.headers.token;
if (token) {
try {
return await jwt.verify(token, process.env.JWT_SECRET);
} catch (e) {
throw new AuthenticationError(mensajesError.sesionExpirada);
}
}
};
const server = new ApolloServer({
typeDefs: schemas,
resolvers,
context: async ({ req }) => {
if (req) {
const me = await getUser(req);
return {
me,
models: {
userModel
},
};
}
}
});
server.applyMiddleware({ app, path: process.env.GRAPHQL_PATH });
const options = {
useNewUrlParser: true,
useUnifiedTopology: true,
useCreateIndex: true
};
app.listen(process.env.PORT, () => {
console.clear();
mongoose.connect('mongodb://.../sandbox', options)
.then(() => {
console.log(`Database and server running on port ${process.env.PORT}`);
})
.catch(error => {
console.error(`The server or the database cannot start:`);
console.error(error);
});
});
然后我根据之前的 Apollo 文档将代码更改为:
import { graphqlExpress } from 'apollo-server-express';
import { createServer } from 'http';
import { execute, subscribe } from 'graphql';
import { PubSub } from 'graphql-subscriptions';
import { SubscriptionServer } from 'subscriptions-transport-ws';
require('dotenv').config();
import schema from './schemas';
import resolvers from './resolvers';
import userModel from './models/usuario';
const app = express();
app.use(
process.env.GRAPHQL_PATH,
bodyParser.json(),
graphqlExpress({ schema }) // <-- Line 83
);
const pubsub = new PubSub();
const server = createServer(app);
server.listen(process.env.PORT, () => {
new SubscriptionServer({
execute,
subscribe,
schema,
}, {
server,
path: '/subscriptions'
});
});
当然,有很多信息缺失,但我想我仍然需要理解这一点。 你明白那个错误吗? 任何意见表示赞赏。
我也尝试使用subscriptions-transport-ws
但由于此问题而无法正常工作。
这是一个对我有用的配置。
const http = require('http');
const { ApolloServer } = require('apollo-server-express');
const express = require('express');
const graphQlSchema = require("./graphql/schema");
const grapgQlResolvers = require("./graphql/resolvers");
const PORT = 3000;
const app = express();
const server = new ApolloServer({
typeDefs: graphQlSchema,
resolvers: grapgQlResolvers,
});
server.applyMiddleware({ app, cors: true })
const httpServer = http.createServer(app);
server.installSubscriptionHandlers(httpServer);
httpServer.listen(PORT, () => {
console.log(`🚀 Server ready at http://localhost:${PORT}${server.graphqlPath}`)
console.log(`🚀 Subscriptions ready at ws://localhost:${PORT}${server.subscriptionsPath}`)
})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.