未从突变中获取 server.js 文件中邮递员发送的数据
Not getting data sent from postman in server.js file from mutation
我正在使用 graphql、prisma 和 express 来测试简单的查询和变异,但是当我从邮递员发送数据时,我没有收到邮递员发送的数据,
我正在将此突变发送到 graphql,但在 server.js 文件
中
mutation{
createUser(user_name:"test"){
user_name
}
}
,我变得不确定,
在 REST API 中,您可以使用正文解析器为 json 修复此问题,是否有类似的东西来处理 graphql 的查询和变异与 prisma & express
const { PrismaClient } = require('@prisma/client');
const express = require('express');
const { graphqlHTTP } = require('express-graphql');
const { makeExecutableSchema } = require('@graphql-tools/schema');
const prisma = new PrismaClient();
const typeDefs = `
type User {
user_name: String
}
type Query {
allUsers: [User!]!
}
type Mutation {
createUser(user_name:String):User
}
`;
const resolvers = {
Query: {
allUsers: () => {
console.log(prisma)
return prisma.user.findMany();
}
},
Mutation:{
createUser:async(user_name)=>{
console.log(user_name)
user={
"user_name":user_name
}
const test= await prisma.user.create({ data: user })
return test
}
}
};
const schema = makeExecutableSchema({
resolvers,
typeDefs,
});
const app = express();
app.use('/graphql', graphqlHTTP({
schema,
}));
app.listen(5000);
GraphQl 的参数 query/mutation 通过解析器的第二个参数(通常定义为 args
)传递。像这样更新你的Mutation
Mutation: {
createUser: async (parent, args, context) => {
console.log(args.user_name);
user = {
user_name: args.user_name,
};
const test = await prisma.user.create({ data: user });
return test;
},
},
我能够 运行 修改后的代码。
我建议查看 express-graphql 的文档或一些示例代码,以更熟悉该库的工作原理。 This example 是开始使用 express、graphql 和 prisma 的好地方。它是打字稿,但与您需要的非常相似。
我正在使用 graphql、prisma 和 express 来测试简单的查询和变异,但是当我从邮递员发送数据时,我没有收到邮递员发送的数据, 我正在将此突变发送到 graphql,但在 server.js 文件
中mutation{
createUser(user_name:"test"){
user_name
}
}
,我变得不确定, 在 REST API 中,您可以使用正文解析器为 json 修复此问题,是否有类似的东西来处理 graphql 的查询和变异与 prisma & express
const { PrismaClient } = require('@prisma/client');
const express = require('express');
const { graphqlHTTP } = require('express-graphql');
const { makeExecutableSchema } = require('@graphql-tools/schema');
const prisma = new PrismaClient();
const typeDefs = `
type User {
user_name: String
}
type Query {
allUsers: [User!]!
}
type Mutation {
createUser(user_name:String):User
}
`;
const resolvers = {
Query: {
allUsers: () => {
console.log(prisma)
return prisma.user.findMany();
}
},
Mutation:{
createUser:async(user_name)=>{
console.log(user_name)
user={
"user_name":user_name
}
const test= await prisma.user.create({ data: user })
return test
}
}
};
const schema = makeExecutableSchema({
resolvers,
typeDefs,
});
const app = express();
app.use('/graphql', graphqlHTTP({
schema,
}));
app.listen(5000);
GraphQl 的参数 query/mutation 通过解析器的第二个参数(通常定义为 args
)传递。像这样更新你的Mutation
Mutation: {
createUser: async (parent, args, context) => {
console.log(args.user_name);
user = {
user_name: args.user_name,
};
const test = await prisma.user.create({ data: user });
return test;
},
},
我能够 运行 修改后的代码。
我建议查看 express-graphql 的文档或一些示例代码,以更熟悉该库的工作原理。 This example 是开始使用 express、graphql 和 prisma 的好地方。它是打字稿,但与您需要的非常相似。