为了账号安全,请及时绑定邮箱和手机立即绑定

变量“$file”的值无效 {};上传值无效

变量“$file”的值无效 {};上传值无效

jeck猫 2023-07-06 16:37:14
我正在使用 GraphQLClient 将graphql-request请求发送到我的服务器。我正在尝试通过执行以下操作来上传文件:const graphQLClient = new GraphQLClient('http://localhost:4000/graphql', {    credentials: 'include',    mode: 'cors',});const source = gql`    mutation uploadImage($file: Upload!) {        uploadImage(file: $file)    }`;const file: RcFile = SOME_FILE; // RcFile (from antd) extends Fileawait graphQLClient.request<{uploadImage: boolean}>(source, { file });但是,当我以这种方式向服务器发送请求时,出现以下错误:GraphQLError: Variable \"$file\" got invalid value {}; Upload value invalid这就是我的请求在控制台中的样子:operations: {    "query":"\n mutation uploadProfileImage($file: Upload!){\n uploadProfileImage(file: $file)\n }\n",      "variables":{"file":null}}map: {"1":["variables.file"]}1: (binary)其他人遇到过这个问题吗?我似乎无法将文件上传到我的后端。
查看完整描述

4 回答

?
慕田峪9158850

TA贡献1794条经验 获得超7个赞

我通过在配置中将上传选项设置为 false 解决了该问题ApolloServer

new ApolloServer({ schema, context, uploads: false })

然后使用graphqlUploadExpress()来自 的中间件graphql-upload

app.use(graphqlUploadExpress({ maxFileSize: 10000, maxFiles: 10 }));

希望这对遇到与我相同问题的人有所帮助😊


查看完整回答
反对 回复 2023-07-06
?
呼唤远方

TA贡献1856条经验 获得超11个赞

请确保您还使用以下客户端实现apollo-upload-client:


import { ApolloClient, InMemoryCache } from "@apollo/client";

import { createUploadLink } from 'apollo-upload-client';


const client = new ApolloClient({

  cache: new InMemoryCache(),

  link: createUploadLink({

      uri: 'http://localhost:4000/graphql'

  }),

});


查看完整回答
反对 回复 2023-07-06
?
红颜莎娜

TA贡献1842条经验 获得超12个赞

这取决于您使用的 ApolloClient。


1-如果使用 import { ApolloClient } from 'apollo-client' 必须使用“ createUploadLink ”而不是“ createHttpLink ”意味着,


import { createUploadLink } from 'apollo-upload-client'

const httpLink = createUploadLink({

  uri: httpEndpoint,

})

2-如果使用createApolloClient,则精确这个包:


import { createApolloClient, restartWebsockets } from 'vue-cli-plugin-apollo/graphql-client'

const { apolloClient, wsClient } = createApolloClient({

    ...defaultOptions,

    ...options,

  })

``

You do not need to set anything and Upload work complete.


查看完整回答
反对 回复 2023-07-06
?
万千封印

TA贡献1891条经验 获得超3个赞

此外,请尝试确保csrfPrevention您的 ApolloServer 配置中未将其设置为 true


  const server = new ApolloServer({

    typeDefs,

    resolvers,

    csrfPrevention: false, // if this is set to true, uploads will fail

    uploads: false,

    cache: "bounded",

    plugins: [ApolloServerPluginLandingPageLocalDefault({ embed: true })],

  });


查看完整回答
反对 回复 2023-07-06
  • 4 回答
  • 0 关注
  • 177 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信