国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > CSS > 正文

前端面試必備之同源和跨域詳解

2024-07-11 09:07:52
字體:
供稿:網(wǎng)友

前言

眾所周知瀏覽器的同源策略及跨域的方法在前端面試中也是出場率極高的問題,本文主要跟大家分享了關(guān)于前端面試時會遇到的同源和跨域問題,下面話不多說了,來一起看看詳細的介紹吧。

什么是同源策略

同源策略是用來限制從一個源加載的文檔或者腳本如何與來自另一個源的資源進行交互,是一種用于隔離潛在的惡意文件的關(guān)鍵的安全機制。

何謂同源

如果協(xié)議、域名和端口對于兩個頁面來說是相同的,則這兩個頁面就是同源的。比如:http://www.hyuhan.com/index.html 這個網(wǎng)站,協(xié)議是http,域名是www.hyuhan.com,端口是80(默認端口),它的同源情況如下:

  • http://www.hyuhan.com/other.html:同源
  • http://hyuhan.com/other.html:不同源(域名不同)
  • https://www.hyuhan.com/other.html:不同源(協(xié)議不同)
  • http://www.hyuhan.com:81/other.html:不同源(端口不同)

同源策略是為了保護用戶信息的安全,受到同源策略限制的主要有以下幾種行為:

  1. Cookie、LocalStorage和IndexDB無法讀取
  2. DOM無法操作
  3. AJAX請求不能發(fā)送

如何進行跨域訪問

怎么跨域進行AJAX請求

主要由三種方法可以繞過同源策略的限制,來進行跨域的AJAX請求。

JSONP

JSONP是客戶端與服務(wù)端跨域通信的常用的方法。利用可以跨域的<script&bt;元素,向服務(wù)器請求json數(shù)據(jù),服務(wù)端收到請求后,將數(shù)據(jù)放在一個回調(diào)函數(shù)中傳回來。實現(xiàn)如下:

window.onload = function() {    var script = document.createElement('script');    script.src = "http://example.com/callback=test";    document.appendChild(script);}function test(res) {    console.log(res);}

src的callback參數(shù)是用來設(shè)置后端需要調(diào)用的回調(diào)函數(shù)的名字的,服務(wù)器返回的數(shù)據(jù)如下:

test({    "name": "小明",    "age": 24    })

這樣,前端就能跨域讀取后端的數(shù)據(jù)了。但是jsopn只能發(fā)生get請求,不能發(fā)送post請求。

WebSocket

WebSocket是一種基于TCP的新的網(wǎng)絡(luò)協(xié)議,它不實行同源策略,只要服務(wù)器支持,就可以進行跨域訪問。而且WebSocket并不限于以Ajax方式通信,因為Ajax技術(shù)需要客戶端發(fā)起請求,而WebSocket服務(wù)器和客戶端可以彼此相互推送信息。

CORS

CORS是Access-Control-Allow-Origin(跨域資源共享)的縮寫,它是一個W3C的標準。CORS需要瀏覽器和服務(wù)器同時支持,目前基本所有的瀏覽器都支持該功能。服務(wù)器端對于CORS的支持,主要就是通過設(shè)置Access-Control-Allow-Origin來進行的。如果瀏覽器檢測到相應(yīng)的設(shè)置,就可以允許Ajax進行跨域的訪問。

document.domain

Cookie是服務(wù)器寫入瀏覽器的信息,安全起見,只有同源的網(wǎng)頁才能共享。但是,如果兩個網(wǎng)頁的一級域名相同,但是耳機域名不同的話,可以通過設(shè)置document.domain來共享Cookie。

比如,一個網(wǎng)頁域名是http://w1.example.com/a.html ,另一個網(wǎng)頁域名是http://w2.example.com/b.html ,只要給們設(shè)置相同的document.domain,這兩個網(wǎng)頁就可以共享Cookie。

postMessage API

postMessage()方法允許來自不同源的腳本采用異步方式進行有限的通信,可以實現(xiàn)跨文檔、多窗口、跨域消息傳遞。用postMessage()函數(shù)傳遞消息,目標頁面監(jiān)聽window的message事件接收消息。利用postMessage,我們可以跨域讀取LocalStorage和IndexDB還有DOM數(shù)據(jù)。

window.name

瀏覽器窗口有window.name的屬性,該屬性規(guī)定無論是否同源,只要在一個窗口里,前一個網(wǎng)頁設(shè)置了這個屬性,后一個網(wǎng)頁就可以讀取它。即在一個窗口(window)的生命周期內(nèi),窗口載入的所有的頁面都是共享一個window.name的,每個頁面對window.name都有讀寫的權(quán)限,window.name是持久存在一個窗口載入過的所有頁面中的。顯然,這是可以實現(xiàn)跨域訪問的。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網(wǎng)的支持。


注:相關(guān)教程知識閱讀請移步到CSS教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 南昌县| 化德县| 上虞市| 荔浦县| 永安市| 资源县| 容城县| 黄浦区| 平山县| 达州市| 新乡县| 平远县| 蓝田县| 长白| 抚宁县| 虎林市| 巨鹿县| 拜城县| 南澳县| 通榆县| 白河县| 开江县| 岚皋县| 扶沟县| 若尔盖县| 定西市| 上高县| 大英县| 吉隆县| 宁河县| 孝义市| 松桃| 东丽区| 铜川市| 中方县| 太仓市| 开远市| 突泉县| 阜新市| 凤阳县| 衡阳县|