如何更新apolloProvider的头信息?
请查看nativescript-vue应用程序仓库:
https://github.com/kaanguru/vue-apollo-login
我无法很好地解释,请查看应用程序。我不知道如何更新appolloClient标头。 应用程库有自己的注释和指令。安装和查看非常容易。当前代码结构:
提交用户的标识符和密码凭据以进行身份验证并在登录页面获取令牌的帖子请求。
Apollo需要将jwt令牌放入Authorization标头中。
- Main.js:如果有JWT,则启动apollo客户端开始使用标头 - 如果没有JWT,则转到登录页 - 如果有JWT,则转到鸟列表 - 登录:从服务器获取jwt并将其写入本地存储 - 转到鸟列表(因为apollo在主js中初始化,所以不显示数据)
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,
})
LOGIN.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}` ,
// },
// });
// },
// });
},
感谢您的关注。 注意:如需更多细节,请留言。sebapi.com后端是一个Strapi GraphQL服务器。 相关文档: