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 

 

 

 

 

 
相关文章
|
JavaScript 前端开发 小程序
js 实现浏览器下载视频2种方法
js 实现浏览器下载视频2种方法
2258 0
|
XML JSON JavaScript
如何在js中,读取json文件?
如何在js中,读取json文件?
|
算法 前端开发 JavaScript
JS - 前端生成 UUID 四种方法
JS - 前端生成 UUID 四种方法
7144 0
|
4月前
|
Oracle Java 关系型数据库
JDK 18详细安装教程步骤官方正版安装包
JDK是Oracle官方Java开发工具包,含JVM、类库、编译器等,支持Java SE/EE/ME。本文提供JDK 18安装包下载及详细图文安装指南,含解压、管理员运行、环境验证(java -version)等步骤,助你快速配置Java开发环境。(239字)
1510 8
|
XML JSON 前端开发
bpmn.js 使用常见问题(不定时持续更新)
bpmn.js 使用常见问题(不定时持续更新)
7131 2
|
存储 JavaScript 前端开发
如何高效实现 vue 文件批量下载及相关操作技巧
在Vue项目中,实现文件批量下载是常见需求。例如文档管理系统或图片库应用中,用户可能需要一次性下载多个文件。本文介绍了三种技术方案:1) 使用`file-saver`和`jszip`插件在前端打包文件为ZIP并下载;2) 借助后端接口完成文件压缩与传输;3) 使用`StreamSaver`解决大文件下载问题。同时,通过在线教育平台的实例详细说明了前后端的具体实现步骤,帮助开发者根据项目需求选择合适方案。
1057 0
|
存储 算法 安全
SpringBoot 接口加密解密实现
【10月更文挑战第18天】
|
存储 关系型数据库 MySQL
MVCC:深入解析多版本并发控制机制
【4月更文挑战第20天】MVCC是数据库并发控制的关键技术,通过保存数据多个版本,使读写操作无锁并发,减少锁竞争,提高并发性能。它保证事务看到一致数据快照,避免并发问题,并支持事务回滚与恢复。MVCC广泛应用于PostgreSQL、InnoDB等,提供时间旅行查询和无锁读等功能,对于构建高性能、高并发数据库系统至关重要。
1053 13
|
JavaScript
Vue2横向文字滚动
这篇文章介绍了如何在Vue 2框架中实现一个横向滚动文本的组件,允许自定义滚动文本内容、滚动区域尺寸和滚动速度等属性。
687 0
Vue2横向文字滚动
|
JSON 安全 前端开发
跨域详解及Spring Boot 3中的跨域解决方案
本文介绍了Web开发中的跨域问题,包括概念、原因、影响以及在Spring Boot 3中的解决方案。跨域是由浏览器的同源策略限制引起的,阻碍了不同源之间的数据传输。解决方法包括CORS、JSONP和代理服务器。在Spring Boot 3中,可以通过配置CorsFilter来允许跨域请求,实现前后端分离项目的正常运行。
1393 3
 跨域详解及Spring Boot 3中的跨域解决方案

热门文章

最新文章