JSONP的使用

1、原生JSONP写法

 /*
  * url: jsonp地址
  * callback: 返回接收的函数名(String)
  */
 function mockJsonp(url,callback){
 	 var JSONP=document.createElement("script");
	 JSONP.type="text/javascript";
	 JSONP.src=`${url}?callback=${callback}`;
	 document.getElementsByTagName("head")[0].appendChild(JSONP);
 }
 function jsonCallBack(result){
 	console.log('jsonp原生写法');
 	console.log(result);
 }
 mockJsonp("https://api.asilu.com/geoip/",jsonCallBack.name)

2、JQuery的jsonp写法

//ajax请求
$.ajax({
	url: "https://api.asilu.com/geoip/",
	dataType: "jsonp", //指定服务器返回的数据类型
	jsonpCallback: "handleData" //指定回调函数
}).done(function(resp_data) {
	console.log("请求完成!");
})

function handleData(result) {
    console.log('jsonp的jquery写法');
 	console.log(result);
}

3、对原生jsonp的封装

function jsonp(obj) {
	//定义一个处理Jsonp返回数据的回调函数
	var callbackName = 'callback' + Math.random().toString(16).slice(2);
	window[callbackName] = function(result) {
		delete window[callbackName];
		obj.success(result);
	}
	
	//组合请求URL
	var callbackStr = "callback="+ callbackName;
	var src = obj.url.includes("?") ? (obj.url + "&" + callbackStr) : (obj.url + "?" + callbackStr);
	for(key in obj.data){
		src += ("&" + key + "=" + obj.data[key]);
	}
	
	//将创建的新节点添加到BOM树上
	var script = document.createElement("script");
	script.src = src;
	document.getElementsByTagName("body")[0].appendChild(script);
}

//调用Jsonp函数发送jsonp请求
jsonp({
	url:"https://api.asilu.com/geoip/",
	data:{
		name:"小明",
	},
	success:function(obj) {
		console.log(obj)
	}
});
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中使用JSONP主要是通过使用跨域请求来获取JSON数据。JSONP(JSON with Padding)是一种跨域请求技术,它实际上是通过在页面中动态创建一个`<script>`标签来加载远程的JSON数据,并通过回调函数来处理返回的数据。 下面是一个简单的Java JSONP的示例代码: ```java import javax.ws.rs.GET; import javax.ws.rs.Path; import javax.ws.rs.Produces; import javax.ws.rs.QueryParam; import javax.ws.rs.core.MediaType; @Path("/jsonp") public class JSONPService { @GET @Path("/data") @Produces(MediaType.APPLICATION_JSON) public String getJSONPData(@QueryParam("callback") String callback) { // 构造要返回的JSON数据 String jsonData = "{\"name\":\"John\", \"age\":30}"; // 将返回的数据包装成JSONP格式 String jsonpData = callback + "(" + jsonData + ")"; return jsonpData; } } ``` 上面的代码使用了JAX-RS(Java API for RESTful Web Services)来创建一个简单的RESTful服务。通过访问`/jsonp/data?callback=callbackFunction`,可以获取到如下格式的JSONP数据: ``` callbackFunction({"name":"John", "age":30}) ``` 在前端页面中,可以使用类似下面的代码来处理返回的JSONP数据: ```javascript function callbackFunction(data) { // 处理返回的JSON数据 console.log(data.name); console.log(data.age); } var script = document.createElement('script'); script.src = 'http://example.com/jsonp/data?callback=callbackFunction'; document.body.appendChild(script); ``` 以上代码中,通过动态创建`<script>`标签,设置`src`属性为请求JSONP数据的URL,并指定回调函数名字为`callbackFunction`。当服务器返回数据时,会调用该回调函数来处理返回的数据。 需要注意的是,JSONP存在一些安全性问题,因为它允许在页面中执行任意的JavaScript代码。因此,在使用JSONP时需要谨慎处理返回的数据,以防止潜在的安全漏洞。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值