引言

在前端开发中,跨域问题是一个非常常见的问题。本文将详细介绍什么是跨域,常见的跨域场景,以及各种常用的跨域解决方案。

什么是跨域

跨域是指一个网页或者Web应用在浏览器中发起对另一个域名下资源的请求。由于浏览器的同源策略限制,这种跨域请求会被浏览器拦截。
同源策略指的是:

  • 同源是指协议、域名、端口都完全相同时才被认为是同源。
  • 不同源的网页,由于安全性考虑,不能读取对方网页的内容或使用对方网页的JS接口。

常见的跨域场景

  • 前后端分离开发中,前端请求后端API
  • 使用CDN加载第三方JS库
  • 前端页面嵌入其他网站的评论/分享等组件
  • H5页面与小程序/App通信

常用的跨域解决方案

1. JSONscript标签不受同源策略限制,可以实现JSON

<script>
function callback(data) {
  console.log(data);
}
</script>
<script src="http://other.com/api?callback=callback"></script>

2. CORS

CORS是W3同时支持。

let xhr = new XMLHttpRequest();
xhr.('GET', 'http://other.com/api');
xhr.send();

3. Nginx代理

利用Nginx反向代理实现跨域请求。

4. postMessage

利用iframe+postMessage实现跨窗口通信。

5. window.name

利用name属性传输小数据实现跨源通信。

6. WebSocket

支持跨域通信的协议。


09-16 01:17