React如何解决fetch跨域请求时session失效问题


Posted in Javascript onNovember 02, 2018

前言

fetch在reactjs中等同于 XMLHttpRequest,它提供了许多与XMLHttpRequest相同的功能,但被设计成更具可扩展性和高效性。

Fetch 的核心在于对 HTTP 接口的抽象,包括 Request,Response,Headers,Body,以及用于初始化异步请求的 global fetch。得益于 JavaScript 实现的这些抽象好的 HTTP 模块,其他接口能够很方便的使用这些功能;除此之外,Fetch 还利用到了请求的异步特性——它是基于 Promise 的。

请注意,fetch 规范与 jQuery.ajax() 主要有两种方式的不同,牢记:

  • 当接收到一个代表错误的 HTTP 状态码时,从 fetch()返回的 Promise 不会被标记为 reject, 即使该 HTTP 响应的状态码是 404 或 500。相反,它会将 Promise 状态标记为 resolve (但是会将 resolve 的返回值的 ok 属性设置为 false ), 仅当网络故障时或请求被阻止时,才会标记为 reject。
  • 默认情况下, fetch 不会从服务端发送或接收任何 cookies, 如果站点依赖于用户 session,则会导致未经认证的请求(要发送 cookies,必须设置 credentials 选项).

发现问题

在解决fetch跨域请求接口的时候,一般都是让后台接口在返回头里添加

//允许所有域名的脚本访问该资源
header("Access-Control-Allow-Origin: *");

React如何解决fetch跨域请求时session失效问题

确实这样是可以解决跨域请求的问题,但是如果我们要在请求的时候添加session,那么这样设置就会出现问题了。

fetch添加Cookie验证的方法是设置credentials: 'include'

fetch(url, {
  method: 'POST',
  body: JSON.stringify(params),
  mode: 'cors',
  //请求时添加Cookie
  credentials: 'include',
  headers: new Headers({
   'Accept': 'application/json',
   "Content-Type": "application/x-www-form-urlencoded; charset=utf-8",
  })
 })

设置好了之后,信心满满的发起请求。却发现网络请求报错了

A wildcard '*' cannot be used in the 'Access-Control-Allow-Origin' header when the credentials flag is true. Origin 'http://localhost:3000' is therefore not allowed access

解决方法

原因是网络请求需要携带Cookie时Access-Control-Allow-Origin是不能设置为*的,这个时候应该要给Access-Control-Allow-Origin指定域名

React如何解决fetch跨域请求时session失效问题

这样就可以达到跨域请求的同时传递Cookie的目的了

  • 列表项目

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
用javascript实现自定义标签
May 08 Javascript
JObj预览一个JS的框架
Mar 13 Javascript
JavaScript中的原型链prototype介绍
Dec 30 Javascript
js+HTML5基于过滤器从摄像头中捕获视频的方法
Jun 16 Javascript
jQuery ajax MD5实现用户注册即时验证功能
Oct 11 Javascript
微信小程序遇到修改数据后页面不渲染的问题解决
Mar 09 Javascript
微信小程序三级联动地址选择器的实例代码
Jul 12 Javascript
如何进行微信公众号开发的本地调试的方法
Jun 16 Javascript
jQuery实现input[type=file]多图预览上传删除等功能
Aug 02 jQuery
javascript实现动态时钟的启动和停止
Jul 29 Javascript
JavaScript中的相等操作符使用详解
Dec 21 Javascript
解决vue项目运行npm run serve报错的问题
Oct 26 Javascript
element ui table 增加筛选的方法示例
Nov 02 #Javascript
Vue请求JSON Server服务器数据的实现方法
Nov 02 #Javascript
详解使用element-ui table组件的筛选功能的一个小坑
Nov 02 #Javascript
如何使用vuex实现兄弟组件通信
Nov 02 #Javascript
JavaScript 复制对象与Object.assign方法无法实现深复制
Nov 02 #Javascript
vue头部导航动态点击处理方法
Nov 02 #Javascript
angular6 利用 ngContentOutlet 实现组件位置交换(重排)
Nov 02 #Javascript
You might like
全国FM电台频率大全 - 18 湖南省
2020/03/11 无线电
一个PHP操作Access类(PHP+ODBC+Access)
2007/01/02 PHP
php mysql数据库操作类
2008/06/04 PHP
php xml留言板 xml存储数据的简单例子
2009/08/24 PHP
php将gd生成的图片缓存到memcache的小例子
2013/06/05 PHP
discuz免激活同步登入代码修改方法(discuz同步登录)
2013/12/24 PHP
Tinymce+jQuery.Validation使用产生的BUG
2010/03/29 Javascript
javascript 设为首页与加入收藏兼容多浏览器代码
2011/01/11 Javascript
jQuery 关于伪类选择符的使用说明
2013/04/24 Javascript
如何使用jQuery Draggable和Droppable实现拖拽功能
2013/07/05 Javascript
HTML5 Shiv完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法
2015/11/25 Javascript
vue.js中$watch的用法示例
2016/10/04 Javascript
12306 刷票脚本及稳固刷票脚本(防挂)
2017/01/04 Javascript
BootStrap中的Fontawesome 图标
2017/05/25 Javascript
微信小程序中换行空格(多个空格)写法详解
2018/07/10 Javascript
vue解决使用$http获取数据时报错的问题
2019/10/30 Javascript
Node使用Nodemailer发送邮件的方法实现
2020/02/24 Javascript
[01:12:40]DOTA2-DPC中国联赛 正赛 DLG vs XG BO3 第三场 1月25日
2021/03/11 DOTA
Python利用multiprocessing实现最简单的分布式作业调度系统实例
2017/11/14 Python
python变量赋值方法(可变与不可变)
2019/01/12 Python
selenium+python自动化测试之环境搭建
2019/01/23 Python
python matplotlib库绘制散点图例题解析
2019/08/10 Python
Python装饰器用法与知识点小结
2020/03/09 Python
Python threading.local代码实例及原理解析
2020/03/16 Python
Python能做什么
2020/06/02 Python
scrapy与selenium结合爬取数据(爬取动态网站)的示例代码
2020/09/28 Python
详解基于 Canvas 手撸一个六边形能力图
2019/09/02 HTML / CSS
品质主管的岗位职责
2013/12/04 职场文书
《水上飞机》教学反思
2014/04/10 职场文书
博士生专家推荐信
2015/03/25 职场文书
2015年员工工作表现评语
2015/03/25 职场文书
如何起草一份正确的合伙创业协议书?
2019/07/04 职场文书
利用Matlab绘制各类特殊图形的实例代码
2021/07/16 Python
Python torch.flatten()函数案例详解
2021/08/30 Python
Golang日志包的使用
2022/04/20 Golang
python 单机五子棋对战游戏
2022/04/28 Python