js實現(xiàn)跨域的幾種方法匯總(圖片ping、JSONP和CORS)
跨域
雖然有同源策略的存在,但是在js中跨域也依然很常見,有document.domain、window.name、圖片ping、jsonp、CORS,在這里簡單總結(jié)下圖片ping、jsonp和CORS備忘。
圖片ping
圖片可以從任何URL中加載,所以將img的src設(shè)置成其他域的URL,即可以實現(xiàn)簡單的跨域,可以使用onload和onerror事件來確定是否接受到了響應(yīng)。
var img=new Image(); img.src='http://chabaoo.cn'; img.onerror=function(){ alert('error'); } img.onload=function(){ alert('success'); }
這里新建了一個img對象,給出的url是博客地址,這里是個error事件,所以彈出error;如果將URL改為一張圖片http://images.jb51.net//710118/o_MacBook%20Air.png,就會彈出onload加載信息success,從而實現(xiàn)了簡單的跨域。
使用圖片ping跨域只能發(fā)送get請求,并且不能訪問響應(yīng)的文本,只能監(jiān)聽是否響應(yīng)而已,可以用來追蹤廣告點擊。
jsonp
jsonp是帶有回調(diào)函數(shù)callback的json,原名json with padding,翻譯是填充式j(luò)son,參數(shù)式j(luò)son。
因為script的src可以跨域,所以在發(fā)送的URL后添加一個callback參數(shù)傳遞給服務(wù)器,然后服務(wù)器返回的數(shù)據(jù)會作為callback的參數(shù),因為這個callback是我們自己來實現(xiàn)的,所以可以對接受到的json數(shù)據(jù)進行處理。
簡單代碼如下:
<script type="text/javascript"> function call(data){ alert(data.city); } </script> <script type="text/javascript" src='http://freegeoip.net/json/?callback=call'></script>
這里,我們把腳本的src設(shè)置為http://freegeoip.net/json/?callback=call,這是一個獲取用戶ip地址的api(有興趣的可以點擊這里查看),然后將callback作為一個參數(shù)拼接在URL后,返回的json數(shù)據(jù)就會作為callback的參數(shù),在這里callback我們定義為call函數(shù),即返回的json數(shù)據(jù)就會作為call的參數(shù)傳進去,這個call函數(shù)僅僅彈出用戶的城市city。筆者這里的輸出結(jié)果是河北。其他ip信息可以查看官網(wǎng),上面有詳細的列表,比如country_name,time_zone等。
CORS(跨資源共享)
CORS是跨資源共享,cross site resourse sharing,它和ajax其實是大體相同的,對于ie實例化的是xdr對象,XDomainRequest,我們能訪問的也只有responseText,觸發(fā)的事件有l(wèi)oad和error,寫法和xhr大體相同,也需要open和send。
對于ff,chrome等其他瀏覽器實例化的是xhr,在這里myvin僅僅拿xhr來演示下,如果要實現(xiàn)跨瀏覽器,可以配合xdr實現(xiàn)兼容。
xhr如下:
var xhr=new XMLHttpRequest(); var url="http://chabaoo.cn"; xhr.open('GET', url); xhr.send(null);
這里使用的url是http://chabaoo.cn,和ajax唯一的區(qū)別就是url使用的是跨域的絕對地址,在ajax中使用的本頁面內(nèi)的相對地址或絕對地址。
看一下控制臺,這里用的是ff40.0.3,顯示信息如下:
已阻止跨源請求:同源策略禁止讀取位于 http://chabaoo.cn 的遠程資源。(原因:CORS 頭缺少 'Access-Control-Allow-Origin')。
所以用CORS實現(xiàn)跨域還有一步要做,就是在服務(wù)器端設(shè)置Access-Control-Allow-Origin。
相關(guān)文章
HTML5游戲引擎LTweenLite實現(xiàn)的超帥動畫效果(附demo源碼下載)
這篇文章主要介紹了HTML5游戲引擎LTweenLite實現(xiàn)的超帥動畫效果,詳細分析了LTweenLite的下載,動畫效果的實現(xiàn)步驟,并附帶完整的demo實例源碼供讀者下載,需要的朋友可以參考下2016-01-01uniapp微信小程序獲取當(dāng)前定位城市信息的實例代碼
因為uniapp官網(wǎng)文檔的定位功能,只能提供經(jīng)緯度,如果要獲取當(dāng)前具體的位置信息,必須要調(diào)取官方的地圖方法,然后在地圖上選點,下面這篇文章主要給大家介紹了關(guān)于uniapp微信小程序獲取當(dāng)前定位城市信息的相關(guān)資料,需要的朋友可以參考下2022-08-08如何在JavaScript中優(yōu)雅的提取循環(huán)內(nèi)數(shù)據(jù)詳解
這篇文章主要給大家介紹了關(guān)于如何在JavaScript中優(yōu)雅的提取循環(huán)內(nèi)數(shù)據(jù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03js實現(xiàn)完全自定義可帶多級目錄的網(wǎng)頁鼠標(biāo)右鍵菜單方法
這篇文章主要介紹了js實現(xiàn)完全自定義可帶多級目錄的網(wǎng)頁鼠標(biāo)右鍵菜單方法,實例分析了javascript實現(xiàn)自定義網(wǎng)頁鼠標(biāo)右鍵彈出菜單的技巧,非常具有實用價值,需要的朋友可以參考下2015-02-02利用weixin-java-miniapp生成小程序碼并直接返回圖片文件流的方法
這篇文章主要介紹了利用weixin-java-miniapp生成小程序碼并直接返回圖片文件流的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03Vant+postcss-pxtorem 實現(xiàn)瀏覽器適配功能
這篇文章主要介紹了Vant+postcss-pxtorem 實現(xiàn)瀏覽器適配,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02