jsonp-script标签的src属性不受同源策略限制,用此方式对非同源服务器请求资源,返回的JS代码会调用指定的函数,携带的参数就是所需的数据,这样就完成了跨域请求。javascript
let scriptDom = document.createElement("script");
scriptDom.src="请求地址?callback=函数名";
document.body.appendChild(scriptDom);
复制代码
CORS -Cross-Origin Resource
Sharing(跨域资源共享)是一种容许当前域(origin)的资源(好比html/js/web service)被其余域(origin)的脚本请求访问的机制。当使用XMLHttpRequest发送请求时,浏览器若是发现违反了同源策略就会自动加上一个请求头:origin,后端在接受到请求后肯定响应后会在Response Headers中加入一个属性:Access-Control-Allow-Origin,值就是发起请求的源地html
》 服务器处理跨域:在先后端分离的项目中能够借助服务器实现跨域,具体作法是:前端向本地服务器发送请求,本地服务器代替前端再向api服务器接口发送请求进行服务器间通讯,本地服务器其实就是个中转站的角色,再将响应的数据返回给前端前端
方便的跨域方案Nginx nginx是一款极其强大的web服务器,其优势就是轻量级、启动快、高并发。html5
如今的新项目中nginx几乎是首选,咱们用node或者java开发的服务一般都须要通过nginx的反向代理。java
反向代理的原理很简单,即全部客户端的请求都必须先通过nginx的处理,nginx做为代理服务器再讲请求转发给node或者java服务,这样就规避了同源策略。node
html5 提供的 PostMessage(data:须要传递的数据,origin: 协议+主机+端口号【+URL】)react
1.页面和其打开的新窗口的数据传递
2.多窗口之间消息传递
3.页面与嵌套的iframe消息传递
4.上面三个问题的跨域数据传递
复制代码