news 2026/5/14 21:43:22

Web前端入门第 89 问:总结 8 种跨域通信处理方案

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Web前端入门第 89 问:总结 8 种跨域通信处理方案

首先跨域问题是由于浏览器的同源策略(Same-Origin Policy)导致的,基本上所有浏览器都有限制,默认情况是不允许跨域访问的!!

APP 的请求不受浏览器的同源策略限制,所以不存在跨域。类似一个服务器像另一个服务器发起请求一样,也不会受跨域影响。

想想一下:如果浏览器没有同源策略限制,A 网站可以随意访问 B 网站内容,那么现在 BAT 这些一线大厂还有护城河吗?所有网站的数据都无隐私可言了,各种钓鱼网站在浏览器中横飞!!那世道...简直太美~~

什么是同源

同源:指的是协议、域名和端口都相同。任意一个不同,都会触发浏览器的同源策略,从而导致跨域。

以 MDM 的一个文档地址为例,看看 URL 不同的组成部分:https://developer.mozilla.org:443/zh-CN/docs/Web/JavaScript?a=b#hash

1

跨域解决方案

虽然默认情况下浏览器是不允许跨域访问的,但通过一些配置手段,还是能够实现资源共享~~

1、跨域资源共享 CORS

目前主流的跨域共享方案,由服务器配置响应头告诉浏览器是否允许跨域访问:

// 或 * 表示所有源都可以访问

Access-Control-Allow-Origin: https://domain.com

// 允许的方法

Access-Control-Allow-Methods: GET, POST, OPTIONS

// 允许的自定义头

Access-Control-Allow-Headers: Content-Type, Authorization

// 允许携带 Cookie

Access-Control-Allow-Credentials: true

2、反向代理

原理就是前端请求同源服务器,由同源服务器向跨域目标发起请求,再由同源服务器返回结果给前端。绕过了浏览器同源策略,但需要服务器支持,如果请求量太大,对自己的服务器要求很高。

比如 nginx / node 中间件 / 开发环境的 dev-server 都是这种方式,以 nginx 跨域配置为例:

location /api/ {

proxy_pass https://domain.com/; # 需要请求的跨域目标

proxy_set_header Host $host;

}

3、WebSocket

WebSocket 是 HTML5 新增的协议,允许浏览器和服务器之间进行全双工通信,天然支持跨域访问。由于是双向通信,所以对服务器压力也不小。

const ws = new WebSocket('wss://domain.com');

ws.onmessage = (event) => console.log(event.data);

4、JSONP

利用 <script> 标签,向目标服务器发起请求,目标服务器需要返回一段函数调用,将数据返回给前端。缺点是仅支持 get 请求,还容易引发 XSS 攻击!

function handleResponse(data) {

console.log(data);

}

const script = document.createElement('script');

script.src = 'https://domain.com/data?callback=handleResponse';

document.head.appendChild(script);

https://domain.com/data?callback=handleResponse 需要返回 JS 代码调用函数执行:

handleResponse({ data: 'hello' });

5、postMessage

此方式一般多用于 iframe 的跨域通信,比如 A 网页使用 iframe 嵌入 B 网页,这种情况就可以使用 postMessage 通信:

发送者:

// 发送方

iframe.contentWindow.postMessage('data', 'https://target-domain.com');

接收者:

// 接收方

window.addEventListener('message', (event) => {

if (event.origin !== 'https://source-domain.com') {

return;

}

console.log(event.data);

});

不推荐的方案

浏览器的版本升级后,一些老旧的跨域方案被弃用,比如:

6、document.domain + iframe

在过去,如果同一个主域名,子域名不同的情况,比如:a.domain.com 和 b.domain.com 之间进行通信,可以通过设置 document.domain = 'domain.com' 来解决,但现在的浏览器已经限制使用了!!

7、window.name + iframe

此方案有一些复杂,需要一个空白的同源页面用于绕过浏览器的同源策略,然后获取 iframe 的 name 属性值,此处有大小限制,最多 2MB 的数据。

流程:

源页面A (domainA.com)

↓ 创建iframe指向代理页面B (domainB.com)

代理页面B (domainB.com)

↓ 接收数据并存入 window.name

↓ 跳转至与A同源的空白页面C (domainA.com)

源页面A

↓ 访问iframe的window.name获取数据

流程图:

2

目前项目开发基本上已经不在使用这种方式,毕竟绕来绕去的,还不如一个 postMessage 跨域方案简单。

8、location.hash + iframe

通过修改 URL Hash 实现父子 iframe 间单向数据传输,虽然勉强也能算作一种跨域方案,但由于 URL 的长度限制,数据量也不能太大,实际使用中也不简单,所以项目上也很难见到它的身影~~

流程图:

3

写在最后

除了文章中这 8 种跨域方案外,还有一些单向数据通信的方法,比如说:

1、使用 Fetch API 的 no-cors 模式。

2、利用图片的 src 属性发起 GET 请求。

3、使用 sendBeacon 发送分析数据。

这些方法都只能向服务器发送数据,没办法获得服务器的响应,所以一般多用于一些数据统计,比如:百度统计、谷歌分析等等。

当然也有一些歪门邪道,比如说:修改浏览器的配置允许跨域,编写浏览器插件支持跨域等等。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 4:32:12

5.A.swift 使用指南

家好&#xff0c;我是K哥。一名独立开发者&#xff0c;同时也是Swift开发框架【Aquarius】的作者&#xff0c;悦记和爱寻车app的开发者。Aquarius开发框架旨在帮助独立开发者和中小型团队&#xff0c;完成iOS App的快速实现与迭代。使用框架开发将给你带来简单、高效、易维护的…

作者头像 李华
网站建设 2026/5/14 9:23:32

3个常见的降AI率工具大汇总(含免费降AI额度),AI率降到20以内!

临近毕业&#xff0c;好多学弟学妹都在问&#xff1a;有没有免费的降AI率工具&#xff1f; 一篇论文动不动10000、20000字&#xff0c;查重、查AI率、降重、降AIGC率&#xff0c;再查一次AIGC率。从写好论文到最后通过查重&#xff0c;最起码得好几百。 对学生来说&#xff0…

作者头像 李华
网站建设 2026/5/10 11:52:51

生产事故-Caffeine缓存误用之临下班的救赎

0x01 事故背景2025年7月9日17时有余&#xff0c;笔者正准备结束疲惫的一天&#xff0c;关机走人之时&#xff0c;桌面右下角安静了一天的内部通讯软件图标突然亮起&#xff0c;内心顿感不妙……打开一看&#xff0c;原来是运维小哥找过来了&#xff0c;说是某接口服务连续多次调…

作者头像 李华
网站建设 2026/5/14 20:03:08

大模型RL后训练扩展定律:66组实验揭示的幂律关系与效率饱和现象

中国科学技术大学与上海人工智能实验室联合研究基于Qwen2.5全系列模型(0.5B-72B)进行66组控制变量实验&#xff0c;首次系统探究RL后训练扩展定律。研究发现测试损失与计算量、数据量呈对数线性关系&#xff0c;可总结为幂律公式&#xff1b;同时定量揭示强化学习效率随参数量增…

作者头像 李华
网站建设 2026/5/13 14:23:12

大模型面试经验汇总:22家大厂面试实录+高频考点解析

本文详细记录了作者2023年参加的22家科技公司大模型岗位面试经验&#xff0c;包括面试流程、问题及感悟。文章总结了高频考点&#xff1a;多头注意力机制、框架并行方式、主流模型细节、大模型训练技巧、数据预处理和模型评估等。作者指出大模型领域竞争激烈&#xff0c;岗位对…

作者头像 李华
网站建设 2026/5/1 11:04:16

Java计算机毕设之基于springboot的村务管理系统的设计与实现springboot+mysql村务档案管理系统设计与实现(完整前后端代码+说明文档+LW,调试定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华