跨域

同源策略

1 . 含義
1995年,同源策略由netscape公司引入瀏覽器,目前,所有瀏覽器都實行這個策略。同源的含義是指三個相同:

  • 協議相同
  • 域名相同
  • 端口相同
  1. 目的
    同源策略的目的是為了保護用戶信息的安全,防止惡意網站竊取數據。
    設想這樣一種情況:a網站是一家銀行,用戶登錄以后,又去瀏覽其他的網站,如果其他的網站可以讀取a網站的cookie,會發生什么?
    很顯然,如果cookie包含隱私(比如存款金額),這些信息就會泄露、更可怕的是,cookie往往用來保存用戶的登錄狀態,如果用戶沒有退出登錄,其他網站就可以冒充用戶,為所欲為。因為瀏覽器同時還規定,提交表單不受同源策略的限制。
  2. 限制范圍
    三種行為受到限制:
  • cookie/localstorage/indexdb無法讀取
  • dom無法獲得
  • ajax請求不能發送

跨域及實現形式

含義
跨域就是突破同源策略的限制,使一個域名的網頁可以請求另一個域名的資源。
實現方式

  • jsonp:步驟:
  1. 定義數據處理函數_fun
  2. 創建script標簽,src的地址執行后端接口,最后加個參數callback=_fun
  3. 服務端在收到請求后,解析參數計算返回數據,輸出fun(data)字符串
  4. fun(data)會放到script標簽作為js執行,此時會調用fun函數,將data作為參數。
    代碼:
    html:
<div class='container'>
    <ul class='news'>
        <li></li>
       <li></li>
       <li></li>
    </ul>
    <button class='change'>第一組</button>
</div>

前端

$('.change').addEventListener('click',function(){
    var script=document,createElement('script');
    script.src='http://localhost:8080/getnews?callback=appendHtml';
    document.head.appendChild(script);
    document.head.removeChild(script);
})
function appendHtml(news){
    var html='';
    for(var i=0;i<news.length;i++){
      html+='<li>'+news[i]+'<li>';
}
    console.log(html);
    $('.news').innerHtml=html
}

后臺:

var cb=req,query,callback;
if(cb){
    res.send(cb='('+JSON.stringify(data+'))')
}else{
    res.send(data);
}
<div class='container'>
    <ul class='news'>
        <li></li>
       <li></li>
       <li></li>
    </ul>
    <button class='change'>第一組</button>
</div>

前臺:

$('.change').addEventListener('click',function(){
    var xhr=new XMLHttpRequest();
    xhr.open('get','http://jrg,com:8080',true);
    xhr.send();
    xhr.onreadystatechange=function(){
      if(xhr.readyState===4&&xhr,status===200){
        appendHtml( JSON.parse(xhr.responseText))
}
}
})
function appendHtml(news){
    var html='';
    for(var i=0;i<news.length;i++){
      html+='<li>'+news[i]+'</li>'
}
    console.log(html);
    $('.news').innerHtml=html;
}

后臺:

app.get('/getNews',function(req,res){
    var news=[.....]
var data=[];
for (var i=0;i<3;i++){
    var index=parseInt(Math.random()+news.length);
    data.push(news[index]);
    news.splice(index,1);
}
res.header('Acess-Control-Allow-Origin','http://a.jrg.com:8080');
res,send(data);
})
  • 降域
    僅限于主域名相同子域名不同的兩個頁面的交互,可以通過設置document.damain屬性來使來年各個頁面個的域名相同,從而避開同源策略,實現跨域。。
  • postMessage
    兩個窗口能夠通信的前提是一個窗口以iframe的形式存在于另一個窗口,或者一個窗口是通過另一個窗口通過window.open()或者超鏈接的形式打開的。
    理解就是a向b發送消息,如果b接收就監聽message事件,然后b向a發送消息,如果接收a就監聽message事件
    示例代碼:
    a.html中:
<input type='text' placeholder='http:a.jirengu.com:8080/a.html'>
<iframe src='http://localhost:8080/b.html' frameborder='0'></iframe>
<script>
    $(.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)
})
<script>

b.html中:

<input id='input' type='text' placeholder='http://b.jirengu.com:8080/b.html'>
<script>
    $('#input').addEventListener('input',function(){
      window.parent.postMessage(this.value,'*')
})
window.addEventListener('message',function(e){
    $('#input‘).value=e.data
    console.log(e.data)
})
<script>

JSONP的原理

通過<script>標簽向服務器發送請求,將前端方法作為參數傳遞到服務器,服務器接收到請求后將JSON數據作為該方法的參數,返回javascript文本前端方法就可以拿到數據。
由于使用的是script標簽的src屬性,所以只支持get方法

cors

cors定義一種跨域訪問機制,可以讓ajax實現跨域訪問。cors允許一個域上的網絡應用向另一個域提交跨域ajax請求實現此功能非常簡單,只需向服務器發送一個響應頭即可。
`header('Access-Control-Allow-Origin:http://www.test2.com')

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

推薦閱讀更多精彩內容

  • 前言:對于跨域請求,很早之前就有去了解過,但因為一直關注的都是服務器后端開發,故也就僅僅停留在概念的理解上而沒有機...
    ken_ljq閱讀 89,843評論 6 128
  • 跨域問題的場景和解決方案多種多樣,只要是做前端開發,總會遇到。而且面試時也是必問的問題。所以自己學習總結記錄一下。...
    花開_陳鳳娟閱讀 740評論 0 0
  • 什么是同源策略 瀏覽器出于安全方面的考慮,只允許與本域下的接口交互。不同源的客戶端腳本在沒有明確授權的情況下,不能...
    ezrealor閱讀 503評論 0 1
  • 一、瀏覽器的同源策略 1.什么是同源? 所謂“同源”指的是”三個相同“。相同的域名、端口和協議,這三個相同的話就視...
    徐國軍_plus閱讀 860評論 1 3
  • 操作文件和目錄的函數一部分放在os模塊中,一部分放在os.path模塊中,這一點要注意一下。查看、創建和刪除目錄可...
    SateZheng閱讀 318評論 0 0