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

简介: 1、介绍     fetch 提供了一个获取资源的接口 (包括跨域)。     fetch 的核心主要包括:Request , Response , Header , Body     利用了请求的异步特性 --- 它是基于 promise 的   2、用法 var request = new Request('/users.

1、介绍

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

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

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

 

2、用法

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

  

 

3、错误一

 

  后端没有设置 跨域头部

 

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

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

  

 

4、错误二

 

 

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

 

  处理方法:后端加允许headers头部

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

  

 

5、错误三

 

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

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

 在请求时候报错了。

 

  错误方法:后端加头部 credentials

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

  

 

6、错误四

 

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

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

 

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

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

  

 

7、错误五

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

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

  在 network 的相应请求中,

  有数据返回来,请求可以看到

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

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

 

 

 

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

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

  

 

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

https://blog.csdn.net/qq_38323724

https://www.cnblogs.com/jiebba/p/9591534.html 

 

 

 

 

 
相关文章
|
6天前
|
开发框架 中间件 Java
如何处理跨域资源共享(CORS)的 OPTIONS 请求?
处理 CORS 的 OPTIONS 请求的关键是正确设置响应头,以告知浏览器是否允许跨域请求以及允许的具体条件。根据所使用的服务器端技术和框架,可以选择相应的方法来实现对 OPTIONS 请求的处理,从而确保跨域资源共享的正常进行。
|
10天前
|
缓存 安全 API
GET 请求和 POST 请求的安全性有何区别?
【10月更文挑战第29天】GET请求和POST请求在安全性方面各有特点和风险。在实际应用中,应根据具体的业务场景和安全需求,合理选择使用GET请求或POST请求,并采取相应的安全措施来保障系统的安全性,如对敏感信息进行加密、实施访问控制、防范CSRF攻击等。
|
5月前
|
存储 监控 Serverless
函数计算操作报错合集之实例请求Header里面带 "xweb_xhr: 1" 就出现超时,该如何解决
在使用函数计算服务(如阿里云函数计算)时,用户可能会遇到多种错误场景。以下是一些常见的操作报错及其可能的原因和解决方法,包括但不限于:1. 函数部署失败、2. 函数执行超时、3. 资源不足错误、4. 权限与访问错误、5. 依赖问题、6. 网络配置错误、7. 触发器配置错误、8. 日志与监控问题。
|
前端开发 PHP
php解决ajax使用post请求时提交的数据过多而导致et::ERR_CONNECTION_RESET的解决方案
php解决ajax使用post请求时提交的数据过多而导致et::ERR_CONNECTION_RESET的解决方案
186 0
jira学习案例25-用fetch封装http请求
jira学习案例25-用fetch封装http请求
63 0
jira学习案例25-用fetch封装http请求
|
JavaScript 前端开发 网络协议
|
JSON 缓存 前端开发
【Ajax入门技术】如何设置请求头 体 ,利用ajax进行取消请求数据操作,解决重复请求问题,请求超时网络异常以及获取json数据
【Ajax入门技术】如何设置请求头 体 ,利用ajax进行取消请求数据操作,解决重复请求问题,请求超时网络异常以及获取json数据
283 0
【Ajax入门技术】如何设置请求头 体 ,利用ajax进行取消请求数据操作,解决重复请求问题,请求超时网络异常以及获取json数据
|
JSON 前端开发 JavaScript
fetch-基础-配置-get-post-上传
1.之前写了篇文章前端请求的5种方式 2.其中 fetch 的方式应该还是 不熟悉 3.所以这篇文章详细的梳理下 fetch
400 0
|
前端开发
前后端交互的五种方式-fetch-xhr区别
简单的总结下前端的请求方式
215 0