zoukankan      html  css  js  c++  java
  • javascript fetch 跨域请求时 session失效问题

    javascript 使用fetch进行跨域请求时默认是不带cookie的,所以会造成 session失效。

    fetch(url, {
        method: 'POST',
        credentials: 'include',
        headers: {
          'Content-Type': 'application/x-www-form-urlencoded',
        },
        body: JSON.stringify({
          data: options.data
        })
      })
    credentials: 'include' 可以是fetch 带上cookie。但是问题了来。
    原来在服务器端设置header (php 服务器)
        header("Access-Control-Allow-Origin: *");

    会报错:

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

    可以看到不允许 使用‘*’ 号了,那么就改成 访问域名(这里是本地调用所以是 http://localhost:8000)

    header("Access-Control-Allow-Origin: http://localhost:8000");

    改完后再次发送请求,还是报错

    Credentials flag is 'true', but the 'Access-Control-Allow-Credentials' header is ''. It must be 'true' to allow credentials. Origin 'http://localhost:8000' is therefore not allowed access.

    说'Access-Control-Allow-Credentials 头必须是true,那么继续增加

    header("Access-Control-Allow-Credentials: true");

    增加完后可以正常访问了,而且session也有了。

    ps: fetch 有个mode 是no-cors ,发现设置后返回的status是0,查资料后

    no-cors mode is only to CDN content, such as scripts, CSS and image, you cannot be used for getting data,response.status = 0 is right behavior

    no-cors 模式只能用来获取CDN内容,比如脚本,css文件和图片,如果用来获取数据比如json格式就会返回status=0

     
  • 相关阅读:
    Hibernate 系列教程13-继承-鉴别器与内连接相结合
    Hibernate 系列教程12-继承-Join策略
    Hibernate 系列教程11-继承-Single Table策略
    Hibernate 系列教程10-组成关系
    Hibernate 系列教程9-自关联
    Hibernate 系列教程8-复合主键
    Hibernate 系列教程7-双向一对一
    Hibernate 系列教程6-双向多对多
    Hibernate 系列教程5-双向多对一
    第三章:3.6 使用 Session
  • 原文地址:https://www.cnblogs.com/neverleave/p/6533133.html
Copyright © 2011-2022 走看看