美文网首页
React 解决fetch跨域请求时session失效

React 解决fetch跨域请求时session失效

作者: RaoMeng | 来源:发表于2018-11-02 10:47 被阅读0次

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

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

确实这样是可以解决跨域请求的问题,但是如果我们要在请求的时候添加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指定域名


image.png

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

相关文章

  • React 解决fetch跨域请求时session失效

    在解决fetch跨域请求接口的时候,一般都是让后台接口在返回头里添加 确实这样是可以解决跨域请求的问题,但是如果我...

  • use fetch post send json can not

    情景描述 create React app中使用fetch 发送跨域http请求 使用create React a...

  • react 数据交互

    axios fetch语法: react跨域: vue跨域方案:https://www.jianshu.com/p...

  • cookies/ session / token概念

    cookies session session与cookie的区别 cookie跨域请求携带如何解决 浏览器同源策...

  • JavaScript - GET/POST及跨域方法

    xhr 原生方法请求 window fetch 方法 关于跨域 利用JSONP实现跨域调用 使用 CORS(跨域资...

  • Vue2.x-实现跨域请求(fetch/axios/proxyt

    Vue2.x-实现跨域请求(fetch/axios/proxytable)跨域问题,修改proxyTable,然后...

  • 跨域

    默认情况下,XMLHttpRequest 或 Fetch 发起的跨域请求,浏览器会限制。 什么是跨域请求? 什么是...

  • 跨域

    ??JSONP只能解决GET请求跨域,不能解决POST请求跨域问题,XHR2可以解决GET,POST方式的请求跨域...

  • fetch 跨域请求

    CORS cors是"Cross-Origin Resource Sharing"的简称,是实现跨域的一种方式,相...

  • React开发环境跨域问题解决

    前言 create-react-app搭建的项目中,请求需要处理跨域问题 解决方案 找到webpackDevSer...

网友评论

      本文标题:React 解决fetch跨域请求时session失效

      本文链接:https://www.haomeiwen.com/subject/ctyqxqtx.html