跨域的解決方式

第一種JSONP方式

舉列說明,比如我想向一個天氣接口獲取數據,但是我當前的域名和天氣這個接口的域名不一樣,它想把自己的瀏覽器接口提供給別人用,我也想用它的接口,但是瀏覽器會它給阻止掉,那么如何繞過瀏覽器,去實現這個功能呢。
<script src="http://weather.com.cn?city=hangzhou"></script>
script 標簽里src,不管內容是什么,無外乎都是向這個內容,發送請求,把數據拿過來之后作為js去執行。但是

{
  city: 'hangzhou',
  weather: {...}
} 

這樣js肯定是會報錯的,即使不報錯,也沒有辦法將它展示頁面上。因此接口里面必須要有

showWeather({
city: 'hangzhou',
weather: {}
})

以及寫js的時候里面聲明了函數

function showWeather(json) {
xxxx
}

這樣兩者的配合,才可以將實際所需要的展示在頁面上。
因此src需要修改成 <script src="http://weather.com.cn?city=hangzhou&callback=showWeather"></script>
因此我們可以這樣去做,偽代碼如下:

script.src = 'http://127.0.01/getNews?callback=appendHtml';
document.head.appendChild(script);
document.head.removeChild(script);
function appendHtml(news) {

}

服務端 router.js 需要添加

app.get('/getNews', function(req, res) {
...
...
...
...
var cb = req.query.callback;
if(cb) { // 如果callback存在
 res.send(cb +'(' + JSON.stringify(data) + ')');
} else {
 res.send(data);
}
// appendHtml(['1xxx', '2xxx'])
}
第二種方式cors

CORS 全稱是跨域資源共享(Cross-Origin Resource Sharing),是一種ajax跨域請求資源的方式,支持現代瀏覽器,IE支持10以上。實現方式很簡單,當你使用XMLHttpRequest 發送請求時,瀏覽器發現該請求不符合同源策略,會給該請求加一個請求頭: Origin, 后臺進行一系列處理,如果確定接受請求則在返回結果中加入一個響應頭: Access-Control-Allow-Origin; 瀏覽器判斷該相應頭中是否包含Origin的值,如果有則瀏覽器會處理響應,我們就可以拿到響應數據,如果不包含瀏覽器直接駁回,這時我們無法拿到響應數據,所以CORS的表象是讓你覺得它與同源的ajax請求沒啥區別,代碼完全一樣。html里面script里面就是普通的ajax請求,而在服務端加了一條
res.header("Access-Control-Allow-Origin", "http://a.jrg.com:8080");
意思就是這個url發送的ajax我是給你數據的。
res.header("Access-Control-Allow-Origin", "*");
不管域名是什么,瀏覽器都放行。

第三種方式降域(iframe)

那是因為你當前的域名是a.jrg.com而你iframe里面的域名是b.jrg.com。
這個時候,你在當前頁面操作iframe里面的東西,是有問題的,會被阻止掉。這是瀏覽器的另一種同源策略,防止你在不同源下操作iframe里面的內容。
針對這種方式,降域。
名下有兩個網站,對應的祖域名是一樣的,而二級域名不一樣,這兩個網站實現iframe嵌套,當有需求的時候可以采用降域的方法。

a1.html里面的內容
...
<iframe src="http://b.jrg.com:8080/b1.html" frameborder="0"></iframe>
<script>
document.domain = 'jrg.com';
</script>
// b.html 里面的內容
<script>
document.domain = 'jrg.com';
</script>
第四種跨域方式postMessage

我不可以操作你的頁面,但是我可以給你這個頁面發送一些消息。
假設iframe里面的域名認可這個消息,那么iframe就可以接受這個消息。
同時iframe也可以向外面發送一些消息,如果你也認可它,那你也可以拿這個消息去處理。那這樣就實現了二者的一個交互。
對于不同域下,我可以向他發送一些數據,如果對方接受了這個數據,那么就可以去用它。如果對方沒有接受它,那么就沒有任何的作用。
舉列說明

// a.html
<div class="ct">
    <h1>使用postMessage實現跨域</h1>
    <div class="main">
        <input type="text" placeholder="http://a.jrg.com:8080/a.html">
    </div>
    <iframe src="http://localhost:8080/b.html" frameborder="0" ></iframe>
</div>
<script>
//URL: http://a.jrg.com:8080/a.html
$('.main input').addEventListener('input', function(){
    console.log(this.value);
    window.frames[0].postMessage(this.value,'*');
})
window.addEventListener('message',function(e) {
        $('.main input').value = e.data
    console.log(e.data);
});
function $(id){
    return document.querySelector(id);
}
</script>
// b.html
<input id="input" type="text"  placeholder="http://b.jrg.com:8080/b.html">
<script>
// URL: http://b.jrg.com:8080/b.html
 
$('#input').addEventListener('input', function(){
    window.parent.postMessage(this.value, '*');
    // 不管post給誰都可以。
})

window.addEventListener('message',function(e) {
        $('#input').value = e.data
    console.log(e.data);
});
function $(id){
    return document.querySelector(id);
}   
</script>
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,002評論 6 542
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,400評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,136評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,714評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,452評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,818評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,812評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,997評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,552評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,292評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,510評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,035評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,721評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,121評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,429評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,235評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,480評論 2 379

推薦閱讀更多精彩內容

  • 瀏覽器安全的基石是"同源政策"。所謂"同源"指的是"三個相同"。 協議相同 域名相同 端口相同 同源政策的目的,是...
    cce117b0a0ce閱讀 294評論 0 1
  • jsonp html中可以通過script標簽引入其他域的js,利用這一特性,結合后端支持,可以實現跨域訪問接口實...
    billa_8f6b閱讀 434評論 0 0
  • 1.JSONP(JSON with Padding)可用于解決主流瀏覽器的跨域數據訪問的問題。由于Web 頁面上調...
    大主教小豪閱讀 306評論 0 0
  • 讀書讓人習慣隨時獨處; 而且,書能隨時相伴左右。 書真是個好東西。
    單生閱讀 227評論 0 4
  • 五二零,荷爾蒙漫天飛,校慶的氛圍更是讓人整個燥起來了。 不得不說孤獨和寂寞比酒精更讓人瘋狂。 負情商少女差點...
    SunnerV閱讀 451評論 0 0