跨域和JSONP

AJAX经常用来异步请求数据,并且局部更新页面。但是AJAX有一个很大的问题,它只能请求相同域名下的内容。如果是请求不同域名下的内容和数据,不管是什么内容,都不会成功。这就需要JSONP来进行跨域请求数据。

一、 前提

在JS和HTML中,其实跨域是很常见的。img标签、script标签都可以直接跨域来获取其它网站的内容。这就表示,我们通过使用script来跨域请求是完全可行的。而且因为JSON的存在,提供了一种非常适合数据交换的语法格式,而JSON恰好又被原生JS支持。

二、 理解JSONP的三个demo
1. 使用script跨域

本地有一个index.html的文件,内容如下:

<body>
  <script src="http://127.0.0.1:8080/test.js"></script>
</body>

本地域名为:127.0.0.1:8081,script标签是在跨域请求
test.js的内容:

alert('我是远程文件')

当在http协议打开index.html文件时,弹出“我是远程文件”,表示跨域成功。

2. 稍微变通一下

远程的test.js改为:

handler({"name":"limingru"})

本地index.html改成:

<body>
  <script>
    function handler(data){
      document.write(data.name)
    }
  </script>
  <script src="http://127.0.0.1:8080/test.js"></script>  //这里就相当于在script标签里写了handler({"name":"limingru"}),调用了上面准备好的函数。
</body>

这样,在页面里就写入了limingru了。

3.理解JSONP

写到这里,大致就能理解JSONP的基本逻辑了,JSONP就是通过客户端通过script脚本来跨域调用其它服务器上动态生成的JS格式的文件,而用于交互的数据的格式则是JSON。调用成功以后,客户端就跨域获得了服务器的数据,这样就可以通过JS来展示这些数据了。

到这里还有一个问题。就是拿数据和给数据的双方要共同约定一种格式,JSONP是通过函数参数传递的方式来给数据的,那给数据的一方如何知道拿数据的一方的函数呢?用查询参数来约定,比如callback,它们的值就是共同的函数名称和其它需要的信息。

来看第三个demo:
本地index.html内容为:

<body>
  <div></div>
  <div></div>
  <div></div>
  <script>
    function handler(data){
      var divs = document.querySelectorAll('div')
      divs[0].textContent = data.name
      divs[1].textContent = data.gender
      divs[2].textContent = data.age
    }

    var url = 'http://127.0.0.1:8080/test.js?callback=handler'
    var script = document.createElement('script')
    script.setAttribute('src',url)
    document.querySelector('body').appendChild(script)
  </script>
</body>

index.html文件动态生成script标签,并且加上url,在url还给了一个查询参数callback=handler,它告诉服务器返回一个handler来传递服务器的JSON数据。
服务器会根据查询参数生成相应的test.js文件:

handler({
  "name":"limingru",
  "gender": "male",
  "age": 18
})

并且将相应的数据传过去。这样,在本地页面就能展示跨域获得的数据了。

三、用jQuery通过JSONP跨域获取数据

$.ajax({
  type: "get",
  async: false,
  url: "http://xxx.aspx",
  dataType: "jsonp",
  jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback)
  jsonpCallback:"flightHandler",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名,也可以写"?",jQuery会自动为你处理数据
  success: function(json){
    alert('您查询到航班信息:票价: ' + json.price + ' 元,余票: ' + json.tickets + ' 张。')
  },
  error: function(){
    alert('失败');
  }
})

jQuery将JSONP封装到了AJAX里,但实际上它们完全不一样。要记住这一点。

参考文章:说说JSON和JSONP,也许你会豁然开朗,含jQuery用例

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容

  • JavaScript是一种在Web开发中经常使用的前端动态脚本技术。在JavaScript中,有一个很重要的...
    西瓜w阅读 1,755评论 0 1
  • 本节内容:实现跨域常用的两种方式 —— JSONP 和 CORS 零:跨域报错展示 在非同源情况下,调用 Ajax...
    NathanYangcn阅读 3,242评论 2 12
  • 0. 前言 说到AJAX就会不可避免的面临两个问题。 AJAX以何种格式来交换数据? 第二个是跨域的需求如何解决?...
    公子七阅读 23,592评论 7 67
  • 1.什么是同源策略 1.要了解同源策略,我们必须先知道源即orgin 以百度页面为例,谷歌浏览器打开控制台:输入l...
    GarenWang阅读 1,445评论 2 8
  • 当总经理老赵的手搂住我的腰时是什么感觉?那是一种恶心又无力又难过的感觉,那种出境持续了大概一分钟。那一分钟,大概是...
    哥斯拉天下无敌阅读 685评论 4 3