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 相关文章推荐
ASP中进行HTML数据及JS数据编码函数
Nov 11 Javascript
JQuery Tips(2) 关于$()包装集你不知道的
Dec 14 Javascript
Javascript中的getUTCHours()方法使用详解
Jun 10 Javascript
浅析Node.js的Stream模块中的Readable对象
Jul 29 Javascript
微信小程序之小豆瓣图书实例
Nov 30 Javascript
Vue实现百度下拉提示搜索功能
Jun 21 Javascript
Webpack性能优化 DLL 用法详解
Aug 10 Javascript
webpack使用 babel-loader 转换 ES6代码示例
Aug 21 Javascript
webpack4 optimization使用总结
Nov 10 Javascript
如何基于JS截获动态代码
Dec 25 Javascript
详解vue3.0 diff算法的使用(超详细)
Jul 01 Javascript
vue中的循环对象属性和属性值用法
Sep 04 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面向对象
2012/02/22 PHP
PHP配置把错误日志以邮件方式发送方法(Windows系统)
2015/06/23 PHP
详解PHP执行定时任务的实现思路
2015/12/21 PHP
解决Laravel 使用insert插入数据,字段created_at为0000的问题
2019/10/11 PHP
验证javascript中Object和Function的关系的三段简单代码
2010/06/27 Javascript
提升你网站水平的jQuery插件集合推荐
2011/04/19 Javascript
jQuery轻松实现表格的隔行变色和点击行变色的实例代码
2016/05/09 Javascript
利用10行js代码实现上下滚动公告效果
2017/12/08 Javascript
微信小程序实现消息框弹出动画
2020/04/18 Javascript
详解如何在Javascript和Sass之间共享变量
2019/11/13 Javascript
JavaScript 监听组合按键思路及代码实现
2020/07/28 Javascript
Python使用一行代码获取上个月是几月
2018/08/30 Python
python处理multipart/form-data的请求方法
2018/12/26 Python
详解python列表生成式和列表生成式器区别
2019/03/27 Python
Python使用python-docx读写word文档
2019/08/26 Python
浅析python 字典嵌套
2020/09/29 Python
使用CSS3来制作消息提醒框
2015/07/12 HTML / CSS
HTML中meta标签及Keywords
2020/04/15 HTML / CSS
美国温暖商店:The Warming Store
2018/12/15 全球购物
The Kooples美国官方网站:为情侣提供的法国当代时尚品牌
2019/01/03 全球购物
娇韵诗法国官网:Clarins法国
2019/01/29 全球购物
银行实习生的自我评价
2014/01/13 职场文书
运动会邀请函范文
2014/01/31 职场文书
行政管理毕业生自荐信
2014/02/24 职场文书
高中军训感言800字
2014/03/05 职场文书
党员公开承诺书
2014/03/25 职场文书
2014年创先争优活动总结
2014/05/04 职场文书
硕士研究生就业推荐信
2014/05/18 职场文书
教师查摆问题自查报告
2014/10/11 职场文书
2015年度服装销售工作总结
2015/03/31 职场文书
文明礼仪倡议书
2015/04/28 职场文书
2015年小学教科研工作总结
2015/07/20 职场文书
关于开学的感想
2015/08/10 职场文书
关于运动会的广播稿
2015/08/19 职场文书
详解python的异常捕获
2022/03/03 Python
漫画《尖帽子的魔法工坊》宣布动画化
2022/04/06 日漫