什么是json?和jsonp有什么区别?

JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度,

那么,JSON到底是什么?

JSON就是一串字符串 只不过元素会使用特定的符号标注。

{} 双括号表示对象

[] 中括号表示数组

“” 双引号内是属性或值

冒号表示后者是前者的值(这个值可以是字符串、数字、也可以是另一个数组或对象)

所以 {“name”: “Michael”} 可以理解为是一个包含name为Michael的对象

而[{“name”: “Michael”},{“name”: “Jerry”}]就表示包含两个对象的数组

当然了,你也可以使用{“name”:[“Michael”,”Jerry”]}来简化上面一部,这是一个拥有一个name数组的对象

ps:现在还有很多人存在一些误区,为什么{name:’json’}在检验时通过不了,

那是因为JSON官网最新规范规定

如果是字符串,那不管是键或值最好都用双引号引起来,所以上面的代码就是{“name”:”json”}

不要反驳,官网就是这么定义的。


什么是jsonp

首先先知道

jsonp的核心原理就是目标页面回调本地页面的方法,并带入参数
我们常用的动态页面有jsp,php,aspx

为什么需要JSONP?

由于浏览器安全限制,数据是不可以直接跨域(包括不同的根域名、二级域名、或不同的端口)请求的,除非目标域名授权你可以访问。比如设置crossdomain.xml 或在http头部里授权

但是crossdomain.xml会允许设置的网站访问所有的数据,而头部设置又非常麻烦。

所以可以在你授权的数据返回里设置jsonp来让该接口允许所有的调用者获取数据。
JSONP的原理

jsonp是使用方法回调的原理.

在网页里,你如果引入其他网页的js,那这个页面的js是可以调用你网页的代码的

直接请求js 和 请求的动态页面(jsp,php,aspx)里输出的javascript代码 效果一样

function showjson(json){
    alert(json.url);
}

当前页面定义的showjson方法(这里定义是本地页面的回调方法)内容
laycode - v1.1
如果引用的js或动态页面里有 showjson({“url”:”http://www.bejson.com“});这行代码的话,那就会弹出 http://www.bejson.com

jsonp的第一种方式,将目标作为js形式加载过来,尽管其实对方是一个php
下面我们在这个页面里来请求http://www.ibilibili.com/static/js/forbejson/userinfo.php页面的数据,这个php页面数据会有回调函数showjson,来调用我们这个bejson页面里的 showjson方法 并将一个json传入

< ?php 
    //这里是php页面里,回调showjson方法,这里的方法必须和上面定义的本地页面中的回调方法一致
    echo 'showjson({"url":"http://www.bejson.com"})';
?>

包含回调函数的php代码
laycode - v1.1

$("#getuserp").click(function(){
    $.getScript("http://www.ibilibili.com/static/js/forbejson/userinfop.php");
});

按钮绑定的事件
laycode - v1.1

那如果我们抓包后就会看到(如上图),点击按钮后发起了一个http请求,

请求了http://www.ibilibili.com/static/js/forbejson/userinfop.php页面,

页面里输出了 showjson({“url”:”http://www.bejson.com“}) ,

因为是以javascript文件形式加载过来 ,所以他会对本地页面showjson发起回调(看绿色箭头),并传入json参数(看红色箭头),所以就会弹出了json中的url

直接用jquery的ajax来请求jsonp

 $.ajax({
     url:'http://www.ibilibili.com/static/js/forbejson/userinfop.php',
     dataType:"jsonp",
     jsonp:"showjson", //这里的参数必须和目标页面里的回调函数一样
     success:function(data){
        alert(data.url);
     }
});         
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值