GraphQL "Must provide a query string" graphql-tag 反应阿波罗
GraphQL "Must provide a query string" graphql-tag react-apollo
我正在使用 react-apollo 和 graphql-tag 但似乎有些地方失败了。服务器 运行正在使用 express 和 postgraphile。
我是不是做错了什么?
邮递员(工作):
{
"query": "{\n allPosts(first:10) {\n nodes {\n \tnodeId,\n id,\n content\n }\n }\n}"
}
反应(失败);
Status Code: 400 Bad Request
Response: {"errors":[{"message":"Must provide a query string."}]}
代码:
export const allPostsQuery = gql`
{
allPosts(first: 10) {
nodes {
nodeId,
id,
content
}
}
}
`;
. . .
<Query query={ allPostsQuery }> . . . </Query>
生成的请求负载相应地看起来:
{"operationName":null,"variables":{},"query":"{\n allPosts(first: 10) {\n nodes {\n nodeId\n id\n content\n __typename\n }\n __typename\n }\n}\n"}
我也尝试通过 Postman 运行 这个 payload,看起来没问题。
这是我的 Apollo 客户端配置:
return new ApolloClient({
connectToDevTools: process.browser,
ssrMode: !process.browser,
link: new HttpLink({
uri: 'http://127.0.0.1:8181/graphql',
credentials: 'include',
headers: {
'Content-Type': 'application/json'
}
}),
cache: new InMemoryCache().restore(initialState || {})
});
感谢 @azium 我弄明白了。再次感谢。 Content-Type
正在自我复制:
Request Headers -> content-type: application/json, application/json
因此,删除 headers object 可以解决问题。
function create (initialState) {
return new ApolloClient({
connectToDevTools: process.browser,
ssrMode: !process.browser,
link: new HttpLink({
uri: 'http://127.0.0.1:8181/graphql',
credentials: 'include'
// headers:
// 'Content-Type': 'application/json' <-- remove the duplicate
//}
}),
cache: new InMemoryCache().restore(initialState || {})
});
}
我正在使用 react-apollo 和 graphql-tag 但似乎有些地方失败了。服务器 运行正在使用 express 和 postgraphile。
我是不是做错了什么?
邮递员(工作):
{
"query": "{\n allPosts(first:10) {\n nodes {\n \tnodeId,\n id,\n content\n }\n }\n}"
}
反应(失败);
Status Code: 400 Bad Request
Response: {"errors":[{"message":"Must provide a query string."}]}
代码:
export const allPostsQuery = gql`
{
allPosts(first: 10) {
nodes {
nodeId,
id,
content
}
}
}
`;
. . .
<Query query={ allPostsQuery }> . . . </Query>
生成的请求负载相应地看起来:
{"operationName":null,"variables":{},"query":"{\n allPosts(first: 10) {\n nodes {\n nodeId\n id\n content\n __typename\n }\n __typename\n }\n}\n"}
我也尝试通过 Postman 运行 这个 payload,看起来没问题。
这是我的 Apollo 客户端配置:
return new ApolloClient({
connectToDevTools: process.browser,
ssrMode: !process.browser,
link: new HttpLink({
uri: 'http://127.0.0.1:8181/graphql',
credentials: 'include',
headers: {
'Content-Type': 'application/json'
}
}),
cache: new InMemoryCache().restore(initialState || {})
});
感谢 @azium 我弄明白了。再次感谢。 Content-Type
正在自我复制:
Request Headers -> content-type: application/json, application/json
因此,删除 headers object 可以解决问题。
function create (initialState) {
return new ApolloClient({
connectToDevTools: process.browser,
ssrMode: !process.browser,
link: new HttpLink({
uri: 'http://127.0.0.1:8181/graphql',
credentials: 'include'
// headers:
// 'Content-Type': 'application/json' <-- remove the duplicate
//}
}),
cache: new InMemoryCache().restore(initialState || {})
});
}