JSONP和跨域

1尘颓、什么是同源策略?

  • 瀏覽器出于安全方面的考慮,只允許與本域下的接口交互主胧。不同源的客戶端腳本在沒有明確授權(quán)的情況下叭首,不能讀寫對(duì)方的資源。
  • 不同源的例子:

需要注意的是: 對(duì)于當(dāng)前頁面來說頁面存放的 JS 文件的域不重要焙格,重要的是加載該 JS 頁面所在什么域

2、什么是跨域夷都?跨域有幾種實(shí)現(xiàn)形式眷唉?

  • 跨域是不同源之間的數(shù)據(jù)交互
  • 四種方式:
  • JSONP
  • CORS:跨域資源共享(Cross-Origin Resource Sharing)
  • 降域
  • postMessage()

3、JSONP 的原理是什么

域名網(wǎng)頁1通過url發(fā)送一個(gè)callback 帶有形參的函數(shù)名到域名網(wǎng)頁2下,另外域名網(wǎng)頁2把數(shù)據(jù)和獲取的函數(shù)名包裝成一個(gè)函數(shù)的調(diào)用冬阳,把整個(gè)函數(shù)調(diào)用的形式 callback("獲取的數(shù)據(jù)")一并發(fā)送回域名網(wǎng)頁1蛤虐,域名網(wǎng)頁1通過響應(yīng)的 callback("獲取的數(shù)據(jù)") 執(zhí)行這個(gè)帶有形參的函數(shù),獲取的數(shù)據(jù)就是跨域?qū)崿F(xiàn)的摩泪,叫JSONP

// 網(wǎng)頁1:http://localhost:8080/index.html
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JSONP</title>
</head>
<body>
  <ul class="lists"></ul>
  <button class="btn">換一組</button>
  <script type="text/javascript" src='jquery/jquery-3.2.1.min.js'></script>
  <script type="text/javascript">
    //var lists = $('.lists')
    //var btn = $('.btn')
    var $lists = $('.lists')
    var $btn = $('.btn')
    $btn.on('click',function(){
      var $script = $('<script>' + '</scr\ipt>')
      $script.attr('src','http://book.kuma.com:8080/getNew?callback=appendHtml')
      $('head').append($script)
      //$('head').remove($script) 這個(gè)有問題
      $('head script').remove()
    })
    /*
    btn.addEventListener('click',function(){
      var script = document.createElement('script')
      script.src = 'http://book.kuma.com:8080/getNew?callback=appendHtml'
      document.head.appendChild(script)
      document.head.removeChild(script)
    })
    */
    function appendHtml(data){
      var htmls = ''
      for (var i = 0; i < data.length; i++) {
        var li = '<li>' + data[i] + '</li>'
        htmls += li
      }
      //lists.innerHTML = htmls
      $lists.html(htmls)
      //$lists.append(htmls)
    }
/*
    function $(cls){
      return document.querySelector(cls)
    }
    */
  </script>
</body>
</html>
// 網(wǎng)頁2:http://book.kuma.com:8080/getNew?callback=appendHtml
app.get('/getNew',function(req,res){
  var cb = req.query.callback
  var news = [
    '團(tuán)中央給單身找伴侶 幫得了你嗎',
    '這個(gè)貪官行賄3億 為何只判了4年',
    '夫婦親熱遭偷拍 被平臺(tái)現(xiàn)場(chǎng)直播',
    '熊黛林現(xiàn)身"撈金" 拒談過往情事',
    '汪東城曬孫悟空造型照 畫面穿越',
    '鄒市明生日會(huì) 與冉瑩穎恩愛互動(dòng)',
    '馬蘇獲獎(jiǎng)后臺(tái)畫風(fēng)突變 搞怪自拍',
    '美泄密士兵服刑7年:獄中想變性',
    '英大選黨派競(jìng)選 宣言"脫歐"為主',
    '特朗普發(fā)推文反駁指控:政治迫害',
    '韓"薩德"紛爭(zhēng)再起 撤走可能性小'
  ]
  var arr = []
  for (var i = 0; i < 3; i++) {
    var data = parseInt(Math.random()*news.length)
    arr.push(news[data])
    //把取出的這條新聞在原json數(shù)組中刪除笆焰,防止再次取到
    news.splice(data,1)
  }
  res.send(cb + '(' + JSON.stringify(arr) + ')')
})

4、CORS是什么

CORS(Cross-Origin Resource Sharing见坑,跨域資源共享)嚷掠,定義了在必須訪問跨域資源時(shí),使用自定義的HTTP頭部讓瀏覽器與服務(wù)器進(jìn)行溝通荞驴,從而決定請(qǐng)求或響應(yīng)是應(yīng)該成功還是失敗不皆。在發(fā)送請(qǐng)求時(shí),需要額外附一個(gè) Origin 頭部熊楼,其中包含請(qǐng)求頁面的原信息(協(xié)議霹娄、域名、端口)鲫骗,服務(wù)器根據(jù)這個(gè)頭部信息決定是否給予響應(yīng)犬耻。如果服務(wù)器認(rèn)為這個(gè)請(qǐng)求可以接受,就在 Access-Control-Allow-Origin 頭部中回發(fā)相同的源信息(如果是公共資源执泰,可以回發(fā) *)枕磁,如果沒有這個(gè)頭部,或者有這個(gè)頭部但源信息不匹配术吝,瀏覽器就會(huì)駁回請(qǐng)求计济。

5、 根據(jù)視頻里的講解演示三種以上跨域的解決方式

github

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末排苍,一起剝皮案震驚了整個(gè)濱河市沦寂,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌淘衙,老刑警劉巖传藏,帶你破解...
    沈念sama閱讀 216,744評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異幔翰,居然都是意外死亡漩氨,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門遗增,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人款青,你說我怎么就攤上這事做修。” “怎么了?”我有些...
    開封第一講書人閱讀 163,105評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵饰及,是天一觀的道長(zhǎng)蔗坯。 經(jīng)常有香客問我,道長(zhǎng)燎含,這世上最難降的妖魔是什么宾濒? 我笑而不...
    開封第一講書人閱讀 58,242評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮屏箍,結(jié)果婚禮上绘梦,老公的妹妹穿的比我還像新娘。我一直安慰自己赴魁,他們只是感情好卸奉,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,269評(píng)論 6 389
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著颖御,像睡著了一般榄棵。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上潘拱,一...
    開封第一講書人閱讀 51,215評(píng)論 1 299
  • 那天疹鳄,我揣著相機(jī)與錄音,去河邊找鬼芦岂。 笑死瘪弓,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的盔腔。 我是一名探鬼主播杠茬,決...
    沈念sama閱讀 40,096評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼弛随!你這毒婦竟也來了瓢喉?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,939評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤舀透,失蹤者是張志新(化名)和其女友劉穎栓票,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體愕够,經(jīng)...
    沈念sama閱讀 45,354評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡走贪,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,573評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了惑芭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片坠狡。...
    茶點(diǎn)故事閱讀 39,745評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖遂跟,靈堂內(nèi)的尸體忽然破棺而出逃沿,到底是詐尸還是另有隱情婴渡,我是刑警寧澤,帶...
    沈念sama閱讀 35,448評(píng)論 5 344
  • 正文 年R本政府宣布凯亮,位于F島的核電站边臼,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏假消。R本人自食惡果不足惜柠并,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,048評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望富拗。 院中可真熱鬧臼予,春花似錦、人聲如沸媒峡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽谅阿。三九已至半哟,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間签餐,已是汗流浹背寓涨。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留氯檐,地道東北人戒良。 一個(gè)月前我還...
    沈念sama閱讀 47,776評(píng)論 2 369
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像冠摄,于是被迫代替她去往敵國(guó)和親糯崎。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,652評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容