JSONP實(shí)現(xiàn)原理-簡析

使用script標(biāo)簽是如何實(shí)現(xiàn)跨域請求的,它是一個(gè)新技術(shù)削祈,還是一個(gè)技巧?
下面我們來看看削饵,其中簡單的原理:

我們寫一個(gè)很平常的example.js岩瘦,文件內(nèi)容展示如下:

getJson({
    results: [
        {
            name: 'xxx',
            code: 1
        }
    ]
});

接下來,再寫一個(gè)簡單的index.html文件:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>jsonp</title>
    <script>
      function getJson(data) {
        console.log(data);
      }
    </script>
    <script src="http://127.0.0.1:3000/example.js"></script>
   </head>
   <body></body>
</html>

上面的index.html代碼窿撬,當(dāng)成功的請求到example.js后启昧,相當(dāng)于這樣:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>jsonp</title>
    <script>
      function getJson(data) {
        console.log(data);
      }
    </script>
    <script>
      //  這里是:src="http://127.0.0.1:3000/example.js"請求成功后,返回的代碼(數(shù)據(jù))
      getJson({
        results: [
          {
            name: 'xxx',
            code: 1
          }
        ]
      });
    </script>
   </head>
   <body></body>
</html>

相信寫到這里劈伴,是能看得明白的密末,下面正式開始說JSONP的實(shí)現(xiàn),我用的是nodejs后臺:

前端代碼index.html跛璧,給"http://http://127.0.0.1:3000/example.js"請求地址加一個(gè)get請求參數(shù)?callback=getJson严里,代碼示例如下:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>jsonp</title>
    <script>
      function getJson(data) {
        console.log(data);
      }
    </script>
    <script src="http://127.0.0.1:3000/example.js?callback=getJson"></script>
   </head>
   <body></body>
</html>

后端server.js代碼如下:

const express = require('express');
const server = express();

server.use('/example.js', (req, res) => {
  // req.query.callback是getJson
  let methodName = req.query.callback; 
  let data = {
     results: [
       {
         name: 'xxx',
         code: 1
       }
     ]
   };
  let dataStr = JSON.stringify(data),
      // 相當(dāng)于sendStr = `getJson(${dataStr})`
      sendStr = `${methodName}(${dataStr})`;
  res.send(sendStr);
});

server.listen(3000);
console.log('server running at 127.0.0.1:3000');

當(dāng)<script src="http://127.0.0.1:3000/example.js?callback=getJson"></script>請求成功后,index.html代碼解析如下:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>jsonp</title>
    <script>
      function getJson(data) {
        console.log(data);
      }
    </script>
    <script>
      // 這里是:src="http://127.0.0.1:3000/example.js?callback=getJson"請求成功后追城,返回的代碼(數(shù)據(jù))
      getJson('{"results":[{"name":"xxx","code":1}]}')
    </script>
   </head>
   <body></body>
</html>

最后聲明刹碾,為了方便大家理解,我把請求寫成了一個(gè)example.js座柱,其實(shí)接口只要一個(gè)字符串就可以了,例如"http://127.0.0.1:3000/example?callback=getJson"迷帜,其中.js文件格式,完全是為了幫助大家理解色洞。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末戏锹,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子火诸,更是在濱河造成了極大的恐慌锦针,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件置蜀,死亡現(xiàn)場離奇詭異奈搜,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)盯荤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進(jìn)店門媚污,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人廷雅,你說我怎么就攤上這事耗美【┧瑁” “怎么了?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵商架,是天一觀的道長堰怨。 經(jīng)常有香客問我,道長蛇摸,這世上最難降的妖魔是什么备图? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮赶袄,結(jié)果婚禮上揽涮,老公的妹妹穿的比我還像新娘。我一直安慰自己饿肺,他們只是感情好蒋困,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著敬辣,像睡著了一般雪标。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上溉跃,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天村刨,我揣著相機(jī)與錄音,去河邊找鬼撰茎。 笑死嵌牺,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的龄糊。 我是一名探鬼主播逆粹,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼绎签!你這毒婦竟也來了枯饿?” 一聲冷哼從身側(cè)響起酝锅,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤诡必,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后搔扁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體爸舒,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年稿蹲,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了扭勉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,137評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡苛聘,死狀恐怖涂炎,靈堂內(nèi)的尸體忽然破棺而出忠聚,到底是詐尸還是另有隱情,我是刑警寧澤唱捣,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布两蟀,位于F島的核電站,受9級特大地震影響震缭,放射性物質(zhì)發(fā)生泄漏赂毯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一拣宰、第九天 我趴在偏房一處隱蔽的房頂上張望党涕。 院中可真熱鬧,春花似錦巡社、人聲如沸膛堤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽骑祟。三九已至,卻和暖如春气笙,著一層夾襖步出監(jiān)牢的瞬間次企,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工潜圃, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缸棵,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓谭期,卻偏偏與公主長得像堵第,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子隧出,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評論 2 355