reactjs - 如何在反应js前端的cookie中存储不记名令牌
问题描述
我在代码的前端部分使用 React JS。我想将不记名令牌存储在 cookie 中,然后在成功调用 API 时在内容字段中返回不记名令牌。由于我之前没有使用过 cookie,所以想知道如何完成这项任务。后端部分也不是我做的。以下是我调用 API 的代码
onSubmitSignup = () => {
fetch('https://cors-anywhere.herokuapp.com/http://35.154.16.105:8080/signup/checkMobile',{
method:'post',
headers:{'Content-Type':'application/json'},
body: JSON.stringify({
mobile:this.state.mobile
})
})
.then(response => response.json())
.then(data =>{
if(data.statusCode === '2000'){
localStorage.setItem('mobile',this.state.mobile);
// this.props.loadNewUser(this.state.mobile);
this.props.onRouteChange('otp','nonav');
}
})
// this.props.onRouteChange('otp','nonav');
}
解决方案
首先,在这一行:
if(data.statusCode === '2000'){
你确定状态码不应该是 200 而不是 2000。
其次,有一些用于管理 cookie 的包。浮现在脑海中的是:
但是您可以使用 vanilla js 来管理 cookie,更多信息可以在 Mozilla 网站上找到:
当您进行初始 API 调用时,在返回的数据中,我假设不记名令牌也被返回。像这样初始化cookie:
document.cookie = "Bearer=example-bearer-token;"
当您以后需要访问 cookie 时,您可以使用以下代码:
const cookieValue = document.cookie
.split('; ')
.find(row => row.startsWith('Bearer'))
.split('=')[1];
然后通过下一个呼叫转发承载。
编辑
像这样设置 cookie 持有者令牌:
document.cookie = "Bearer=example-bearer-token;"
像这样获取 cookie 持有者令牌:
const cookieValue = document.cookie
.split('; ')
.find(row => row.startsWith('Bearer'))
.split('=')[1];
cookie 由以分号分隔的键/值对组成。因此,上面获取“Bearer”值的代码首先获取 cookie,将其拆分为键/值对,找到键为“Bearer”的行并拆分该行以获得 Bearer 令牌。
在您的评论中,您说开发团队说承载者将在“内容”中。在您的 ajax 请求中,您已经可以通过数据访问该内容。您需要调试该请求以找出它返回的内容。我假设您只需要从检查您的 statusCode 的“If”块内的返回数据中获取令牌。
它会是这样的:
document.cookie = "Bearer=" + data.bearer;
但是,我没有你的数据的形状,所以你只能自己完成最后一部分。
推荐阅读
- r - Problem with Goodness-Of-Fit tests for objects of class kppm in spatstat version 1.61-0
- c# - 如何根据层次结构中的场景顺序对循环进行排序以 debug.log 游戏对象?
- r - 为什么在 x 和 y 轴列选择之间使用 ~ 而不是 R 文档中看到的 plot(x,y, xlab, ylab) 中的常规 plot(x,y )?
- flutter - instagram 的“heart-ing”背后的逻辑发布了流畅的 api 调用
- c++ - 生命游戏编程问题 C++
- sql-server - SQL Server Reporting Server 第一次连接速度慢
- java - 创建 URI 时出现非法语法错误
- r - 在 geom_bspline() 下填充区域?
- list - 根据长度过滤子集?
- python - 让 matplotlib 图表轴在原点 (0,0) 相交