前端跨域问题解决Access to XMLHttpRequest at xxx from has been blocked by CORS policy

在前端开发中,跨域资源共享(CORS)是一个常见的问题。它涉及到浏览器安全机制,防止网页从一个域获取资源时被另一个域阻止。错误信息如“Access to XMLHttpRequest at 'xxx' from origin 'has been blocked by CORS policy'”是典型的跨域问题。本文将详细解释CORS的工作原理,并提供几种解决跨域问题的方法。

一、CORS的基本原理

CORS(Cross-Origin Resource Sharing)是一种浏览器技术,它允许服务器通过设置HTTP头来决定哪些来源可以访问资源。CORS头包括:

  • Access-Control-Allow-Origin:指定哪些域可以访问资源。
  • Access-Control-Allow-Methods:指定允许的HTTP方法(如GET, POST)。
  • Access-Control-Allow-Headers:指定允许的HTTP头。
  • Access-Control-Allow-Credentials:指示是否可以发送Cookie。

二、解决跨域问题的方法

1. 服务器设置CORS头

在服务器端,通过设置适当的CORS头来允许跨域访问。

示例:在Node.js Express服务器中设置CORS头

const express = require('express');
const app = express();app.use((req, res, next) => {res.header('Access-Control-Allow-Origin', '*'); // 允许所有来源res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE'); // 允许的方法res.header('Access-Control-Allow-Headers', 'Content-Type'); // 允许的头next();
});app.get('/api/data', (req, res) => {res.json({ message: 'This is CORS-enabled for all origins!' });
});app.listen(3000, () => {console.log('CORS-enabled web server listening on port 3000');
});
​

注意Access-Control-Allow-Origin: * 允许所有来源访问资源,在生产环境中应慎用,可以改为特定域名。

2. JSONP(JSON with Padding)

JSONP是跨域请求的一种传统方法,但仅限于GET请求。它通过动态插入script标签来实现。

示例

<script>function handleResponse(response) {console.log('Data:', response);}
</script>
<script src="https://example.com/api/data?callback=handleResponse"></script>
​

服务器端(Node.js Express):

app.get('/api/data', (req, res) => {const callback = req.query.callback;const data = { message: 'This is a JSONP response' };res.send(`${callback}(${JSON.stringify(data)})`);
});
​
3. 使用代理服务器

通过设置代理服务器,将请求转发到目标服务器,避免直接跨域。

示例:在Vue CLI中配置代理

// vue.config.js
module.exports = {devServer: {proxy: {'/api': {target: 'https://example.com',changeOrigin: true,pathRewrite: {'^/api': ''}}}}
};
​
4. 在Nginx中配置CORS

通过Nginx反向代理设置CORS头。

示例

server {listen 80;server_name example.com;location /api/ {proxy_pass http://backend_server;add_header Access-Control-Allow-Origin *;add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';add_header Access-Control-Allow-Headers 'Content-Type, Authorization';add_header Access-Control-Allow-Credentials true;}
}
​
5. 使用浏览器插件

在开发过程中,可以使用浏览器插件来临时解决CORS问题,如CORS Unblock。

三、CORS的常见配置错误及解决方法

1. Access-Control-Allow-Origin设置不正确

错误:服务器未设置 Access-Control-Allow-Origin或设置不正确。

解决:确保服务器正确设置 Access-Control-Allow-Origin头。

res.header('Access-Control-Allow-Origin', 'https://your-allowed-origin.com');
​
2. 预检请求(OPTIONS)失败

错误:服务器未处理预检请求,导致跨域请求失败。

解决:确保服务器正确处理OPTIONS请求。

app.options('/api/data', (req, res) => {res.header('Access-Control-Allow-Origin', 'https://your-allowed-origin.com');res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE');res.header('Access-Control-Allow-Headers', 'Content-Type');res.send();
});
​
3. Access-Control-Allow-Credentials设置不正确

错误Access-Control-Allow-Credentials设置为 true,但 Access-Control-Allow-Origin设置为 *

解决:当设置 Access-Control-Allow-Credentials为 true时,Access-Control-Allow-Origin不能为 *,必须为具体的域名。

res.header('Access-Control-Allow-Origin', 'https://your-allowed-origin.com');
res.header('Access-Control-Allow-Credentials', 'true');

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/912762.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/912762.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[ linux-系统 ] 软硬链接与动静态库

软硬链接 介绍 软链接 通过下图可以看出软链接和原始文件是两个独立的文件&#xff0c;因为软链接有着自己的inode编号&#xff1a; 具有独立的 inode &#xff0c;也有独立的数据块&#xff0c;它的数据块里面保存的是指向的文件的路径&#xff0c;公用 inode 硬链接 通过…

3D 商品展示与 AR 试戴能为珠宝行业带来一些便利?

对于珠宝行业而言&#xff0c;长久以来&#xff0c;如何让消费者在做出购买决策之前&#xff0c;便能真切且直观地领略到珠宝独一无二的魅力&#xff0c;始终是横亘在行业发展道路上的一道棘手难题。而 3D 互动营销的横空出世&#xff0c;恰似一道曙光&#xff0c;完美且精准地…

电子电气架构 --- SOVD功能简单介绍

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 简单,单纯,喜欢独处,独来独往,不易合同频过着接地气的生活,除了生存温饱问题之外,没有什么过多的欲望,表面看起来很高冷,内心热情,如果你身…

【Java编程动手学】 Java中的运算符全解析

文章目录 一、引言二、算术运算符1、基本概念2、具体运算符及示例 三、关系运算符1、基本概念2、具体运算符及示例 四、自增减运算符1、基本概念2、具体运算符及示例 五、逻辑运算符1、基本概念2、具体运算符及示例 六、位运算符1、基本概念2、具体运算符及示例 七、移位运算符…

【前端】1 小时实现 React 简历项目

近期更新完毕。仅包括核心代码 目录结构 yarn.lock保证开发者每次能下载到同版本依赖&#xff0c;一般不需要特别留意 package.json 是 Node.js 项目、前端项目、npm/yarn的配置文件。 Dockerfile 是用来 定义 Docker 镜像构建过程的文本文件。它是一份脚本&#xff0c;告诉 …

python中的pydantic是什么?

Pydantic 是 Python 中一个用于数据验证和设置管理的库&#xff0c;主要通过 Python 类型注解&#xff08;Type Hints&#xff09;来定义数据结构&#xff0c;并自动验证输入数据的合法性。它广泛应用于 API 开发&#xff08;如 FastAPI&#xff09;、配置管理、数据序列化等场…

腾讯云市场目前饱和度

首先我需要理解市场饱和度的概念。市场饱和度通常指一个产品或服务在潜在市场中的渗透程度&#xff0c;高饱和度意味着市场增长空间有限&#xff0c;低饱和度则表明还有较大发展潜力。 从搜索结果看&#xff0c;腾讯云目前在中国云服务市场排名第三&#xff0c;市场份额约为15%…

EDR、NDR、XDR工作原理和架构及区别

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; EDR、NDR、XDR是网络安全中关键的检测与响应技术&#xff0c;它们在覆盖范围、数据源和响应机制上有显著差异。以下是它们的工作原理和架构详解&#xff1a; --- ### &#x1f50d; 一、EDR&#xff0…

vue3 + luckysheet 实现在线编辑Excel

效果图奉上&#xff1a; 引入的依赖&#xff1a; "dependencies": {"types/jquery": "^3.5.32","types/xlsx": "^0.0.36","jquery": "^3.7.1","xlsx": "^0.18.5",}在index.html中…

Linux下MinIO分布式安装部署

文章目录 一、MinIO简单说明二、MinIO分布式安装部署1、关闭SELINUX2、开启防火墙2.1、关闭firewall&#xff1a;2.2、安装iptables防火墙 3、安装MinIO4、添加MinIO集群控制脚本4.1添加启动脚本4.2添加关闭脚本 5、MinIO控制台使用 一、MinIO简单说明 1、MinIO是一个轻量的对…

Codeforces Round 980 (Div. 2)

ABC 略 D 这个过程一定是由1向后跳的过程中穿插有几次向前一步一步走。直到跳到一个位置后再把前面所有没有走过的位置倒序走一遍。总分就等于最大位置的前缀和-前面所有起跳位置和。前缀和固定我们只需要求到每个位置的最小起跳和即可。对于这个向后跳和向前走的过程我们可以…

Langchain实现rag功能

RAG&#xff08;检索增强生成&#xff09;的核心是通过外部知识库增强大模型回答的准确性和针对性&#xff0c;其工作流程与优化策略如下&#xff1a; 一、RAG 核心流程 ‌知识库构建‌ ‌文档加载与分割‌&#xff1a;将非结构化文档&#xff08;PDF、Markdown等&#xff09;…

算法笔记上机训练实战指南刷题

算法笔记上机训练实战指南刷题记录 文章目录 算法笔记上机训练实战指南刷题记录模拟B1001 害死人不偿命的(3n1)猜想B1011 AB 和 CB1016 部分ABB1026 程序运行时间B1046划拳B1008数组元素循环右移问题B1012 数字分类B1018 锤子剪刀布A1042 Shuffling Machine 每天两题&#xff0…

MYSQL基础内容

一、介绍 1.不用数据库&#xff1a;使用IO流对数据进行管理 2.使用数据库&#xff1a;使用SQL语句对开发的数据进行管理&#xff0c;能储存上亿条数据 3.MYSQL&#xff1a; 是流行的关系型数据库管理系统之一&#xff0c;将数据保存在不同的数据表中&#xff0c;通过表与表之…

音视频会议服务搭建(设计方案)-01

前言 最近在做音视频会议系统服务搭建的工作任务&#xff0c;因为内容过多&#xff0c;我会逐篇分享相关的设计方案、开发思路、编程语言、使用的组件集合等等。如果你也有大型音视频会议系统搭建架构的需求&#xff0c;希望这些可以对你有所帮助。 EchoMeet 音视频会议系统架构…

刷leetcode hot100/准备机试--图

图的基础知识【这部分建议使用acm模式】 图论理论基础 | 代码随想录 存储&#xff1a; 一般有邻接表【适合稀疏图】【数组 链表 】和邻接矩阵【适合稠密图】存储方式 注意邻接表 和 邻接矩阵的写法都要掌握&#xff01; 邻接矩阵 n个节点&#xff0c;申请n*n或者&#xf…

无代码自动化测试工具介绍

无代码自动化测试工具允许用户无需编写代码即可创建和运行测试,通过拖拽式界面或录制回放等可视化界面进行操作。 这些工具利用图形用户界面和预定义命令来创建测试,使非编程人员也能进行自动化测试。 无代码自动化测试工具使团队能够: 使用直观的拖拽界面开发和执行自动化…

python学习打卡day58

DAY 58 经典时序预测模型2 知识点回顾&#xff1a; 时序建模的流程时序任务经典单变量数据集ARIMA&#xff08;p&#xff0c;d&#xff0c;q&#xff09;模型实战SARIMA摘要图的理解处理不平稳的2种差分 n阶差分---处理趋势季节性差分---处理季节性 建立一个ARIMA模型&#xf…

分布式锁的实现方式:使用 Redisson 实现分布式锁( Spring Boot )

Redisson提供了分布式和可扩展的Java数据结构&#xff0c;包括分布式锁的实现。 1. 添加依赖 在pom.xml中添加Redisson依赖&#xff1a; <dependency><groupId>org.redisson</groupId><artifactId>redisson-spring-boot-starter</artifactId>…

Web基础关键_004_CSS(二)

目 录 一、样式 1.行内样式 2.内部样式 3.外部样式 二、选择器优先级 1.非关系选择器 2.关系选择器 三、属性 四、盒子模型 五、元素 1.块级元素 2.行内元素 3.行内块级元素 4.元素类型转换 六、浮动 七、定位 1.静态定位 2.相对定位 3.绝对定位 4.固定定位 …