JQuery中ajax 跨域处理解决

原创 2016年08月30日 15:46:54

//JQuery的Ajax  跨域请求的解决方案
   今天在项目中需要做远程数据加载并渲染页面,直到开发阶段才意识到ajax跨域请求的问题,隐约记得Jquery有提过一个ajax跨域请求的解决方式, 于是即刻翻出Jquery的API出来研究,发现JQuery对于Ajax的跨域请求有两类解决方案,不过都是只支持get方式。分别是JQuery的 jquery.ajax jsonp格式和jquery.getScript方式。


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


$.ajax({
    type:"get";
    async:"false";
    dataType:"json";
    url:"http://www.xxx.com/ajax.do";
    jsonCallback:"success_jsonCallback";
    jsonp:"callbackparam";   // 什么是jsonp格式呢
    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(callbackparam+"([{name:"\json\"}])");
   }


//服务器断也可以这么写


String callbackFunName=Request["callbackparam"];
Response.Write(callbackFunName+"([{name:"\John\"}])");
Response.End();

版权声明:本文为博主原创文章,未经博主允许不得转载。

jquery中ajax处理跨域的三大方式

一、处理跨域的方式: 1.代理 2.XHR2 HTML5中提供的XMLHTTPREQUEST Level2(及XHR2)已经实现了跨域访问。但ie10以下不支持 只需要在服务端填上响应头: ...
  • qq_35844359
  • qq_35844359
  • 2017年03月14日 16:09
  • 1174

jQuery ajax跨域请求的解决方法

由于JS同源策略的影响,因此js只能访问同域名下的文档。因此要实现跨域,一般有以下几个方法: 一、处理跨域的方式: 1.代理 2.XHR2 HTML5中提供的XMLHTTPREQUEST Le...
  • wuyou1336
  • wuyou1336
  • 2017年02月07日 23:52
  • 2659

JQuery中ajax处理跨域的三大方式

由于JS同源策略的影响,因此js只能访问同域名下的文档。因此要实现跨域,一般有以下几个方法: 一、处理跨域的方式: 1.代理 2.XHR2 HTML5中提供的XMLHTTPREQUEST Level2...
  • u014175572
  • u014175572
  • 2016年06月03日 15:38
  • 2414

jquery 跨域ajax中的异常处理

一直未曾注意,jquery在跨域ajax的时候,是不进行异常处理的. 如: $.ajax({url:'http://www.testn.com', success:function(){}, er...
  • qingralf
  • qingralf
  • 2012年12月12日 09:38
  • 1731

jquery中ajax处理跨域的三大方式

这篇文章主要介绍了jquery中ajax处理跨域的三大方式,感兴趣的小伙伴们可以参考一下 由于JS同源策略的影响,因此js只能访问同域名下的文档。因此要实现跨域,一般有以下几个方法: ...
  • kuangruike
  • kuangruike
  • 2016年11月22日 18:12
  • 178

Jquery中Ajax处理跨域的方式

一、处理跨域的方式:1.代理 2.XHR2 HTML5中提供的XMLHTTPREQUEST Level2(及XHR2)已经实现了跨域访问。但ie10以下不支持 只需要在服务端填上响应头:head...
  • qq_30206797
  • qq_30206797
  • 2017年11月15日 19:34
  • 43

跨域解决方案 & 使用angularJS和jQuery进行Ajax请求的差异

转载自时间被海绵吃了:跨域解决方案 前端同学李雷和后台同学韩梅梅分别在自己电脑上进行开发,后台接口写好的时候,李雷改动完就把前端代码上传到gitlab,然后在测试机上从gitlab上拉下来,然后...
  • senmage
  • senmage
  • 2017年08月08日 18:02
  • 171

jQuery的Ajax跨域请求的解决方案

什么是jsonp格式呢?API原文:如果获取的数据文件存放在远程服务器上(域名不同,也就是跨域获取数据),则需要使用jsonp类型。使用这种类型的话,会创建一个查询字符串参数 callback=? ,...
  • ijasonchen91
  • ijasonchen91
  • 2016年01月01日 16:59
  • 348

基于jQuery的AJAX跨域问题完美解决方案[转]

(请求的跨域服务器不支持常规”?”查询请求时的解决方案)   昨天第一次做VIP需求时,发现一个超奇怪的问题,我有以下URL地址:   http://dynamic.vip.xxxxxx.co...
  • luxideyao
  • luxideyao
  • 2013年12月05日 11:21
  • 556

Jquery使用AJAX请求跨域解决方法

在解决方法中使用到jsonp 首先了解jsonp的原理 jsonp原理 Jsonp其实就是一个跨域解决方案。Js跨域请求数据是不可以的,但是js跨域请求js脚本是可以的。可以把数据封装...
  • qq_33939283
  • qq_33939283
  • 2017年06月18日 20:23
  • 179
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JQuery中ajax 跨域处理解决
举报原因:
原因补充:

(最多只允许输入30个字)