JSONP——跨域请求(python)

一般来说,浏览器请求数据是遵循的同源请求策略,即前后端请求需要在同一个ip和端口才能允许获取数据,为了解决这个问题,利用前端的SCRIPT标签属性来解决。
方式一:

<srcript>
$(".send_ajax").click(function(){
	//封装一个kuayu_request方法,可以用来复用跨域函数
	kuayu_request("https://www.baidu.com/send_ajax")
});

// 跨域函数
function kuayu_request(url){
	var $script = $('<script>');//创建script标签,是一个jquery对象
	$script.attr("src", url); //添加src属性
	$("body").append($script); //添加到文档中
	$("body script:last").remove(); //然后在移除该标签

}
</script>

方式二:基于jQuery的JSONP实现

<script>
$('.send_ajax').click(function(){
	$.ajax({
		url:"https://www.baidu.com/send_ajax" ,//示例地址,无实际用处
		dataType:"jsonp", //跨域请求<script>
		jsonp:'callbacks',                //相当于路径中回调函数路径参数键值对的键
		jsonpCallback:"func"              //相当于路径中回调函数路径参数键值对的值,回调函数名
		success:function(data){
			//获取数据后执行代码
			console.log(data)
};
	});
});
</script>

示例:
  jsonp: 'callbacks’就是定义一个存放回调函数的键,jsonpCallback是前端定义好的回调函数方法名,server端接受callback键对应值后就可以在其中填充数据打包返回。但是,jsonpCallback参数可以不定义,jquery会自动定义一个随机名发过去,那前端就得用回调函数来处理对应数据了。利用jQuery可以很方便的实现JSONP来进行跨域访问。

//项目1中html中前端js跨域部分代码

<script>
    $(".ajax_btn").click(function () {
       $.ajax({
           url:"http://127.0.0.1:8002/send_ajax/",
           dataType:"jsonp",
           jsonp:'callbacks',
           success:function (data) {
               alert(data);
               console.log(data)
           }
       })
    });
</script>

//项目2服务端中的视图函数,即跨域请求的路径

def send_ajax(request):
    import json
    func_name=request.GET.get("callbacks")    #获得回调函数的名字
    dic={"k1":"v1"}
    print("ok")
    return HttpResponse("%s('%s')" %(func_name,json.dumps(dic)))

应用:跨域请求应用

如某合作单位提供如下获取数据接口:http://www.jxntv.cn/data/jmd-jxtv2.html?callback=list&_=1454376870403,请通过跨域请求获取数据。由数据连接可以知对方已经定义了回调函数的函数名,即为list,所以我们可以通过上述"基于jquery的JSONP的实现"的方式获取数据,结果如下:

<script>
    $(".ajax_btn").click(function () {

        $.ajax({
        // 改地址已经定义好了回调函数的名称,所以只能用这个回调函数的名称,不能前端自己定义
            url:"http://www.jxntv.cn/data/jmd-jxtv2.html?callback=list&_=1454376870403",  //目标地址
            dataType:"jsonp", // 跨域请求
            jsonp:"callback", //回调函数的键值对的键
            jsonpCallback:"list"// 回调函数中键值对的值,也就是回调函数名称
        })

    });

    function list(result) {
          console.log(result);
              }

</script>

然后自行可以根据数据结果类型进行处理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值