3d现场开奖直播在线:JSONP 教程

七乐彩预测 www.xedsq.com.cn JSONP是一种使用模式,人们常常把JSONP和JSON混淆,他们虽然有关系,但是描述的不是一个事物,JSONP是JSON with Padding的简称。本篇会说明JSONP是一个什么?怎么是去使用。

通俗讲,JSONP 为解决跨域而诞生。是为了基于浏览器Web请求不通源之间的请求。

为了下面更好的讲解JSONP,先解释一下跨域。

具体讲,是解决不同源,被浏览器监管Javascript的安全限制。

  • //www.xedsq.com.cn调用//www.xedsq.com.cn/json/是不会跨域的。
  • //www.xedsq.com.cn 调用//www.itboy.net/json/是跨域的,因为不同域名。
  • //www.xedsq.com.cn调用https://icp.sojson.com/search1_baidu.com.html 是跨域的。因为是不同二级域名。
  • //www.xedsq.com.cn:8080调用//www.xedsq.com.cn:8081 是跨域的。因为是不同端口。
  • //www.xedsq.com.cn调用//www.xedsq.com.cn 是跨域的。因为是不同请求协议,http和https。
  • 188.188.188.20调用199.199.199.99 是跨域的。因为不同IP。
  • localhost调用127.0.0.1 也是跨域的。其实他也是不同域名。

JSONP for Java (一)

前端代码,Javascript:

<script>
    //jsonp回调方法,一定要写在jsonp请求前面
    function callback(txt){
        alert(txt);
    }
</script>
<script src ="/demo/testJsonp.shtml" type="text/javascript" ></script>

后端代码,Java:

/**
 * jsonp 测试
 * @return
 */
@RequestMapping(value="testJsonp",method=RequestMethod.GET)
@ResponseBody
public String testJsonp(){
	return "callback('test jsonp');";
}

前端会alert弹出的内容“test jsonp”。

JSONP for Java ,自定义callback函数(二)

前端代码,Javascript:

<script>
    //jsonp回调方法,一定要写在jsonp请求前面
    function testjson(txt){
        alert(txt);
    }
</script>
<script src ="/demo/testJsonp.shtml?callback=testjson" type="text/javascript" ></script>

后端代码,Java:

/**
 * jsonp 测试
 * @return
 */
@RequestMapping(value="testJsonp",method=RequestMethod.GET)
@ResponseBody
public String testJsonp(String callback){
	return callback +"('test jsonp');";
}

JSONP for Java ,jQuery Ajax请求

前端代码,Javascript:

<script>
var testjsonp = function(data){
    $.each(data.data,function () {
        alert("时间:" + this.time +",内容:" + this.info);
    });
}
var demoJSONP = function () {
    $.getScript("//www.xedsq.com.cn/open/api/kuaidi/get.shtml?orderNo=887180351164743887&callback=testjsonp");
}
</script>

这个接口您不要去尝试使用,因为它的数据来自百度而已。

JSONP for PHP ,jQuery

PHP代码:

<?php
    $data = ".......";
    $callback = $_GET['callback'];
    echo $callback.'('.json_encode($data).')';
    exit;
?>

前端代码,Javascript:

<script>
$.ajax({
    type : "post",
    url : "ajax.php",
    dataType : "jsonp",
    jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(默认为:callback)
    jsonpCallback:"success_jsonpCallback",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名
    success : function(json){
        alert('success');
    },
    error:function(){
        alert('fail');
    }
});
</script>
支付扫码

所有赞助/开支都讲公开明细,用于网站维护:赞助名单查看

正在加载... ...

  • 沪明确市级机关培训费标准 院士讲课费半天不超3000元 2019-04-23
  • 脸每天都洗 但你真的洗对了吗? 2019-04-22
  • 乌鲁木齐一老人西湖边落水 5位小伙出手相救 2019-04-21
  • 葫芦岛市:司法改革解决百姓纠纷 2019-04-20
  • 科技赋能助力医保革新,平安开启商保服务新模式 2019-04-19
  • 23年前的今天,武汉长江二桥建成通车 江城从此告别三镇交通一线牵 2019-04-18
  • 加舒尔布鲁木Ⅰ和Ⅱ峰文章中国国家地理网 2019-04-17
  • 为社会奉献爱心 用青春书写梦想 2019-04-17
  • 商务部新闻发言人就6月15日美方公布对华贸易措施发表谈话 2019-04-16
  • 视频:罗志祥打造新男团正式出道 内含两名17“快男” 2019-04-16
  • [安徽新闻联播]安徽与中央企业签下1800多亿元合作大单 2019-04-15
  • 新疆额敏县:“社区影院”助推文化惠民 2019-04-14
  • 习近平关于生态环境保护的十个精妙论述 2019-04-14
  • 陕西援藏医生索杰成功为一名外籍患者实施急诊手术 2019-04-13
  • 呼死你团伙被摧毁 封停83万余个账号抓获210余人 2019-04-12
  • 267| 305| 810| 280| 255| 482| 310| 596| 315| 408|