使用Apollo响应本机授权:使用令牌创建客户端。无法将令牌设置为标题

问题描述 投票:1回答:1
let [loading, setLoading] = useState(true);
let client = new ApolloClient({
    uri: 'https://39990dea.ngrok.io/graphql',
});

let init = async () => {
    let token = await AsyncStorage.getItem('token');
    if (!!token) {
        store.dispatch(userLoaded(token));
        client = new ApolloClient({
            request: (operation) => {
                operation.setContext({
                    headers: {
                        authorization: token ? token : '',
                    },
                });
            },
        });
        console.warn('user with token created');
        console.warn(token);
        console.warn('token is taken');
    }
    setLoading(false);
};
useEffect(init, []);

我正在创建阿波罗客户端。然后,如果AsyncStorage中有令牌,则设置标头以请求令牌。

return (
<ApolloProvider client={client}>
    <Provider store={store}>
        <AppNavigator/>
    </Provider>
</ApolloProvider>

);

但是当我发出请求时,出现Graphql错误:未显示。我在做错什么吗?

react-native authentication graphql apollo apollo-client
1个回答
1
投票

您正在初始化客户端并异步更改它,但是您的组件没有重新呈现。因此,您有两个选择:

useState,以便重新渲染您的应用

调用forceUpdate功能

© www.soinside.com 2019 - 2024. All rights reserved.