【发布时间】:2017-07-03 12:32:43
【问题描述】:
我正在尝试从 refreshToken 生成新的 accessToken。使用 Oauth2 登录。我有这个代码:
componentWillMount(){
AsyncStorage.multiGet([USER_TOKEN, USER_REFRESH_TOKEN,USER_REMEMBERED]).then((data) => {
console.log(data)
const userRemembered = JSON.parse(data[2][1])
console.log(userRemembered)
const userAccessToken = data[0][1]
console.log(userAccessToken)
const userRefreshToken = data[1][1]
console.log(userRefreshToken)
if (!userAccessToken) {
fetch("SOME_URL", {
method: "POST",
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json'
},
body: JSON.stringify({
refreshToken: userRefreshToken
})
})
.then((response) => {response.json(); console.log(response)}) //this logs 200
.then(responseData => {
console.log(responseData) //this logs undefined
})
.catch((error) => {
console.log(error)
})
}
else{
this.setState({
token:userAccessToken,
refreshToken: userRefreshToken,
isLoggedIn:userRemembered
})
console.log('token not expired')
console.log(this.state);
this.changeRoute(this.state)
}
})
}
在 Insomnia 中对其进行测试时,一切正常,我能够从 refreshToken(我使用 AsyncStorage 存储的)生成 accessToken。
【问题讨论】:
标签: javascript reactjs asynchronous react-native fetch