爱程序网

ajax跨域请求简单介绍

来源: 阅读:

ajax跨域请求简单介绍:
本章介绍一下ajax跨域请求问题,内容主要是引用网络上的一篇文章,希望能够需要的朋友带来一定的帮助。
一.是jsonp格式文件:

如果获取的数据文件存放在远程服务器上(域名不同,也就是跨域获取数据),则需要使用jsonp类型。使用这种类型的话,会创建一个查询字符串参数 callback=? ,这个参数会加在请求的URL后面。服务器端应当在JSON数据前加上回调函数名,以便完成一个有效的JSONP请求。意思就是远程服务端需要对返回的数据做下处理,根据客户端提交的callback的参数,返回一个callback(json)的数据,而客户端将会用script的方式处理返回数据,来对json数据做处理。JQuery.getJSON也同样支持jsonp的数据方式调用。 
二.客户端JQuery.ajax的调用代码示例:

 

$.ajax({ 
type : "get", 
async:false, 
url : "http://www.softwhy.com/ajax.do", 
dataType : "jsonp", 
jsonp: "callbackparam",//服务端用于接收callback调用的function名的参数 
jsonpCallback:"success_jsonpCallback",//callback的function名称 
success : function(json){ 
  alert(json); 
  alert(json[0].name); 
}, 
error:function(){ 
  alert('fail'); 
} 
});

 

三.服务端返回数据的示例代码:

public void ProcessRequest (HttpContext context) { 
context.Response.ContentType = "text/plain"; 
String callbackFunName = context.Request["callbackparam"]; 
context.Response.Write(callbackFunName + "([ { name:\"John\"}])"); 
}

原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=8131

更多内容可以参阅:http://www.softwhy.com/jquery/

 

关于爱程序网 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助