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处理跨域的三大方式

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

jquery 跨域ajax中的异常处理

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

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

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

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

前端同学李雷和后台同学韩梅梅分别在自己电脑上进行开发,后台接口写好的时候,李雷改动完就把前端代码上传到gitlab,然后在测试机上从gitlab上拉下来,然后在测试机上移动最新代码,最后回到本机刷新页...

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

在解决方法中使用到jsonp 首先了解jsonp的原理 jsonp原理 Jsonp其实就是一个跨域解决方案。Js跨域请求数据是不可以的,但是js跨域请求js脚本是可以的。可以把数据封装...

jQuery中利用JSONP解决AJAX跨域问题

jQuery中利用JSONP解决AJAX跨域问题 蓝飞 | 时间:2012-08-10, Fri | 11,316 views 前端开发  写在前面 跨域的解决方案有多种,其中最常见的是使...

jQuery ajax跨域请求的解决方法

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

jQuery.ajax 跨域请求webapi设置headers的解决方案

解决跨域调用服务并设置headers 主要的解决方法需要通过服务器端设置响应头、正确响应options请求,正确设置 JavaScript端需要设置的headers信息 方能实现。 1.第一...

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

今天在项目中需要做远程数据加载并渲染页面,直到开发阶段才意识到ajax跨域请求的问题,隐约记得Jquery有提过一个ajax跨域请求的解决方式,于是即刻翻出Jquery的API出来研究,发现JQuer...

解决webservice用Ajax(jquery)传递客户端请求时ip跨域问题(异步域请求)

经过本人亲测。可以通过servlet实现跨域 在前台index.jsp页面中 实现btn按钮的是无跨域访问。至使jquery的post 请求中的URL必须和服务端的ip完全一致。否...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JQuery中ajax 跨域处理解决
举报原因:
原因补充:

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