fetch各类报跨域错误,数据没法获取的解决方案

一、介绍

    fetch 提供了一个获取资源的接口 (包括跨域)。javascript

    fetch 的核心主要包括:Request , Response , Header , Bodyhtml

    利用了请求的异步特性 --- 它是基于 promise 的前端

 

二、用法

var request = new Request('/users.json', {
    method: 'POST',
    mode: 'cors',
    redirect: 'follow',
    headers: new Headers({
        'Content-Type': 'text/plain'
    })
});

  

 

三、错误一

 

  后端没有设置 跨域头部java

 

  处理方法:后端加跨域头部json

res.setHeader('Access-Control-Allow-Origin', '*'); //最简单的设置跨域 *

  

 

四、错误二

 

 

这个错误是是一系列的错误,这里显示的是  Content-Type,还有多是 Origin 等后端

 

  处理方法:后端加容许headers头部跨域

    res.setHeader('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept');

  

 

五、错误三

 

这里的错误是什么呢,前端设置了promise

fetch(url,{
    credentails:true,   // 容许容许传递 cookie
})

 在请求时候报错了。cookie

 

  错误方法:后端加头部 credentialscors

 res.setHeader('Access-Control-Allow-Credentials', true);//告诉客户端能够在HTTP请求中带上Cookie

  

 

六、错误四

 

  有时候,后端设置跨域,而且跨域设置为 *

  可是前端仍然会报错,就像这个

 

  处理方法:修改后端跨域头部

res.setHeader('Access-Control-Allow-Origin', origin);//注意这里不能使用 *
// origin 是你须要请求跨域资源的来源地址
// 如上面错误就能够是 http://127.0.0.1:8082

  

 

七、错误五

  当咱们使用 fetch 设置 mode :‘ no-cors ’,如:

fetch(url,{
    mode:'no-cors',   
})

  在 network 的相应请求中,

  有数据返回来,请求能够看到

  可是就是得不到数据,fetch 无反应

  这时候在控制台 console 上会出来这样错误

 

 

 

   处理方法:将 no-cors 改成 cors

fetch(url,{
    mode:'cors',   
})

  

 

8.还有一种报错是后端返回的格式不对。

 

 

不能直接返回字符串,须要后端 toJson 下 

 

 

 

想了解更多知识(源码等),想知道更多精华,看看个人博客吧   https://gilea.cn/

https://blog.csdn.net/qq_38323724

http://www.javashuo.com/article/p-sfdpvknf-u.html 

相关文章
相关标签/搜索