如何更新 apolloProvider 的标头?
请查看 nativescript-vue 应用程序存储库:
https://github.com/kaanguru/vue-apollo-login https://github.com/kaanguru/vue-apollo-login
我无法正确解释,所以请查看该应用程序。我不知道如何更新 appolloClient 标头。
应用程序存储库有自己的注释和指令。您可以轻松安装和查看。
当前代码结构:
Post请求提交用户的标识符和密码凭据以进行身份验证和获取令牌在登录页面。
Apollo 需要将 jwt 令牌放入 Authorization 标头中。
import ApolloClient from 'apollo-boost'
import VueApollo from 'vue-apollo'
Vue.use(VueApollo)
const apolloClient = new ApolloClient({
uri: 'http://sebapi.com/graphql',
// HEADERS WORK FINE IF TOKEN WAS IN MAIN
// headers: {
// authorization: `Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6MSwiaWF0IjoxNTg2MzU2NzM2LCJleHAiOjE1ODg5NDg3MzZ9.wpyhPTWuqxrDgezDXJqIOaAIaocpM8Ehd3BhQUWKK5Q`,
// }
})
const apolloProvider = new VueApollo({
defaultClient: apolloClient,
})
登录.VUE
.then(
(response) => {
const result = response.content.toJSON();
console.log("Result from Server: ", result);
const token = result.jwt;
// HOW TO ADD HEADERS TO APOLLOCLIENT this.$apollo.provider.defaultClient
// this.$apollo.provider.defaultClient({
// request: (operation) => {
// operation.setContext({
// headers: {
// authorization: `Bearer ${result.jwt}` ,
// },
// });
// },
// });
},
感谢您的关注。
NOTE: 请评论了解更多详情。 sebapi.com 后端是一个 Strapi graphql 服务器。
相关文档:
阿波罗认证 https://www.apollographql.com/docs/react/networking/authentication/
Apollo链接组成 https://www.apollographql.com/docs/link/composition/
Vue apolloProvider 用法 https://vue-apollo.netlify.com/guide/apollo/#apollo