广州北大青鸟计算机职业培训学校
互联网技术培训、软件技术培训、大数据培训、云计算培训、数据分析培训信息网
当前位置:网站首页 > 软件专业 > 前端开发专业 > 正文

Web前端开发如何实现跨域?_惠州前端培训学校

作者:hz_admin01发布时间:2022-04-11分类:前端开发专业浏览:578


导读:Web前端开发如何实现跨域?今天我们跟着惠州北大青鸟老师一起来了解一下,希望对大家有帮助。

Web前端开发如何实现跨域?今天我们跟着惠州北大青鸟老师一起来了解一下,希望对大家有帮助。

一、同源策略

同源策略是浏览器的一个安全功能,同源即协议、域名、端口三者相同。它限制了从一个源加载的文档或脚本与另一个源进行数据交互,所以abc.com下的JS脚本请求xyz.com的数据会被拒绝。

注意:跨域限制访问,其实是浏览器的同源策略限制。

二、跨域

当协议、域名、端口任意一个不同时,都算不同域。不同域之间相互请求资源,就算跨域。

注意:跨域并不是请求发不出去,请求能发出去,服务端能收到请求并正常返回结果,只是结果被浏览器拦截了。

三、跨域的几种方法

(1)有三个标签允许跨域加载资源

<img src="">

<link href="">

<script src="">

(2)JSONP

JSONP(JSON with Padding) 是 json 的一种"使用模式",可以让网页从别的域名获取资料,即跨域读取数据。

JSONP由两部分组成:回调函数和数据。回调函数是当响应到来时在页面调用的数据。数据则为传入回调函数的JSON数据。

JSONP通过<script>元素来使用,因<script>不受同源策略影响,向<script>指定一个跨域URL。

<script type="text/javascript">

function

callbackFunction(){...}

</script>

<script type="text/javascript"

src="https://www.runoob.com/try/ajax/jsonp.php?jsoncallback=callbackFunction">

</script>

(3)CORS

CORS(Cross-Origin Resource Sharing,跨域源资源共享),基本思想为使用自定义的HTTP头部让浏览器与服务器进行沟通,需要浏览器支持CORS。

客户端:发送HTTP请求时,额外添加一个Origin头部,包含请求页面的源信息,服务器根据此信息决定是否响应。

Origin:http://www.abc.com

服务端:在响应头添加Access-Control-Allow-Origin,回发相同源信息(公共资源可回“*”),若没有此头部,或头部源信息不匹配,浏览器会驳回请求。

Access-Control-Allow-Origin:http://www.abc.com

(4)WebSockets

Websocket是HTML5的一个持久化的协议,它实现了浏览器与服务器的全双工通信,同源策略对其不适用。

WebSocket 在建立连接时要借助 HTTP 协议,建立连接后会从 HTTP交换为WebSocket 协议,WebSocket 的 server (服务端)与 client (客户端)都能主动向对方发送或接收数据。只有支持WebSocket协议的服务器才能正常工作。

(5)postMessage

如果两个网页不同源,就无法拿到对方的DOM。典型的例子是iframe窗口和window.open方法打开的窗口,它们与父窗口无法通信。HTML5为了解决这个问题,引入了一个全新的API:跨文档通信 API(Cross-document messaging)。这个API为window对象新增了一个window.postMessage方法,允许跨窗口通信,不论这两个窗口是否同源。

postMessage方法的第一个参数是具体的信息内容,第二个参数是接收消息的窗口的源(origin)。也可以设为*,表示不限制域名,向所有窗口发送。

想知道更多关于前端的资讯,联系在线客服,或者来惠州北大青鸟新方舟校区了解了解。

标签:惠州前端培训学校惠州前端基础惠州前端培训北大青鸟IT计算机学校北大青鸟IT软件学校前端北大青鸟IT学校惠州北大青鸟北大青鸟


前端开发专业排行
标签列表
网站分类
文章归档
最近发表