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 相关文章推荐
Js+XML 操作
Sep 20 Javascript
JavaScript面象对象设计
Apr 28 Javascript
jquery 最简单易用的表单验证插件
Feb 27 Javascript
jquery左右滚动焦点图banner图片鼠标经过显示上下页按钮
Oct 11 Javascript
jQuery选择器源码解读(二):select方法
Mar 31 Javascript
HTML5canvas 绘制一个圆环形的进度表示实例
Dec 16 Javascript
JavaScript数组_动力节点Java学院整理
Jun 26 Javascript
js实现复制功能(多种方法集合)
Jan 06 Javascript
vue+echarts实现动态绘制图表及异步加载数据的方法
Oct 17 Javascript
react基本安装与测试示例
Apr 27 Javascript
JS实现悬浮球只在一侧滑动并且是横屏状态下
Aug 19 Javascript
JS实现九宫格拼图游戏
Jun 28 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
星际实力自我测试
2020/03/04 星际争霸
php缓存技术介绍
2006/11/25 PHP
弄了个检测传输的参数是否为数字的Function
2006/12/06 PHP
JavaScript加密解密7种方法总结分析
2007/10/07 Javascript
锋利的jQuery 要点归纳(二) jQuery中的DOM操作(下)
2010/03/23 Javascript
jQuery中阻止冒泡事件的方法介绍
2014/04/12 Javascript
基于jquery实现放大镜效果
2015/08/17 Javascript
继续学习javascript闭包
2015/12/03 Javascript
node.js 和HTML5开发本地桌面应用程序
2016/12/13 Javascript
基于jQuery实现顶部导航栏功能
2016/12/27 Javascript
vue双花括号的使用方法 附练习题
2017/11/07 Javascript
vue购物车插件编写代码
2017/11/27 Javascript
JS实现多物体运动的方法详解
2018/01/23 Javascript
JavaScript中发出HTTP请求最常用的方法
2018/07/12 Javascript
react native 仿微信聊天室实例代码
2019/09/17 Javascript
vue 开发企业微信整合案例分析
2019/12/02 Javascript
动态实现element ui的el-table某列数据不同样式的示例
2021/01/22 Javascript
[31:47]夜魇凡尔赛茶话会 第三期01:选手知多少
2021/03/11 DOTA
在RedHat系Linux上部署Python的Celery框架的教程
2015/04/07 Python
Python自定义函数定义,参数,调用代码解析
2017/12/27 Python
python编程嵌套函数实例代码
2018/02/11 Python
Python opencv实现人眼/人脸识别以及实时打码处理
2019/04/29 Python
浅谈django不使用restframework自定义接口与使用的区别
2020/07/15 Python
美国羊皮公司:Overland
2018/01/15 全球购物
英国鲜花递送:Blossoming Gifts
2020/07/10 全球购物
What is view? why do we have view?
2012/06/22 面试题
《草原》教学反思
2014/02/15 职场文书
2014年元旦感言
2014/03/06 职场文书
父亲节活动策划方案
2014/08/24 职场文书
创先争优活动承诺书
2014/08/30 职场文书
幼儿园六一主持词
2015/06/30 职场文书
2016特色励志班级口号
2015/12/24 职场文书
坚持不是死撑,更重要的是心态
2019/08/19 职场文书
纯CSS实现酷炫的霓虹灯效果
2021/04/13 HTML / CSS
react中的DOM操作实现
2021/06/30 Javascript
Web应用开发TypeScript使用详解
2022/05/25 Javascript