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基础资料整理2
Dec 06 Javascript
JavaScript字符串String和Array操作的有趣方法
Dec 18 Javascript
document.write的几点使用心得
May 14 Javascript
浅析js预加载/延迟加载
Sep 25 Javascript
JavaScript中逗号运算符介绍及使用示例
Mar 13 Javascript
js实现简单计算器
Nov 22 Javascript
Bootstrap面板学习使用
Feb 09 Javascript
Bootstrap 3多级下拉菜单实例
Nov 23 Javascript
vue3.0 CLI - 3.2 路由的初级使用教程
Sep 20 Javascript
详解微信小程序框架wepy踩坑记录(与vue对比)
Mar 12 Javascript
file-loader打包图片文件时路径错误输出为[object-module]的解决方法
Jan 03 Javascript
vue中解决chrome浏览器自动播放音频和MP3语音打包到线上的实现方法
Oct 09 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
一个php作的文本留言本的例子(五)
2006/10/09 PHP
APMServ使用说明
2006/10/23 PHP
PHP实现将视频转成MP4并获取视频预览图的方法
2015/03/12 PHP
基于CI框架的微信网页授权库示例
2016/11/25 PHP
Laravel5中Cookie的使用详解
2017/05/03 PHP
实现点击列表弹出列表索引的两种方式
2013/03/08 Javascript
window.location.href = window.location.href 跳转无反应 a超链接onclick事件写法
2013/08/21 Javascript
JS获取计算机mac地址以及IP的实现方法
2014/01/08 Javascript
jquery实现图片放大镜功能
2015/11/23 Javascript
借助FileReader实现将文件编码为Base64后通过AJAX上传
2015/12/24 Javascript
jQuery Validation Plugin验证插件手动验证
2016/01/26 Javascript
【经验总结】编写JavaScript代码时应遵循的14条规律
2016/06/20 Javascript
利用javascript实现的三种图片放大镜效果实例(附源码)
2017/01/23 Javascript
canvas实现图像布局填充功能
2017/02/06 Javascript
JavaScript实现多态和继承的封装操作示例
2018/08/20 Javascript
微信小程序提取公用函数到util.js及使用方法示例
2019/01/10 Javascript
layui点击按钮页面会自动刷新的解决方案
2019/10/25 Javascript
ant design vue嵌套表格及表格内部编辑的用法说明
2020/10/28 Javascript
Python中max函数用法实例分析
2015/07/17 Python
Python中%r和%s的详解及区别
2017/03/16 Python
python机器学习理论与实战(六)支持向量机
2018/01/19 Python
numpy找出array中的最大值,最小值实例
2018/04/03 Python
Python格式化输出字符串方法小结【%与format】
2018/10/29 Python
Python list与NumPy array 区分详解
2019/11/06 Python
深入浅析pycharm中 Make available to all projects的含义
2020/09/15 Python
英国女士家居服网站:hush
2017/08/09 全球购物
英国玛莎百货美国官网:Marks & Spencer美国
2018/11/06 全球购物
小学教师的自我评价范例
2013/10/31 职场文书
简单的个人租房协议书范本
2014/11/26 职场文书
幼师中班个人总结
2015/02/12 职场文书
2015年销售工作总结范文
2015/03/30 职场文书
公司清洁工岗位职责
2015/04/15 职场文书
道歉信范文
2015/05/12 职场文书
2015年审计人员工作总结
2015/05/26 职场文书
postman中form-data、x-www-form-urlencoded、raw、binary的区别介绍
2022/01/18 HTML / CSS
漫画「处刑少女的生存之道」第3卷封面公开
2022/03/21 日漫