jquery ajax 跨域调用

设计接口的时候,大部分接口返回的都是json格式,本来以为就够了,因为客户端都是安卓或ios或者java端,html的比较少,跨域调用的时候报告异常,其实服务器端也执行了,但是返回来的时候有问题,研究了一晚上,解决了,就用jsonp的方式来解决,问题是需要服务器端进行支持,还好比较容易,这样就使得纯html的webapp有了可能。

比较完整的调用方式


var _url = "${eyunCommonServerUrl}/user/sendSMSCaptchaCode.do"; //别人家的服务器


$.ajax({

          type : "get",

          url : _url,

          data : {

            phoneNumber : mobile,

            templateID : 0,

            sendType : 0

          },


          dataType:"jsonp",

          //jsonp:"callback", //可以指定回调函数的参数名

          //jsonpCallback:"flightHandler", //可以指定回调函数的函数名

          success : function(json) {

//jquery会默认给你实现一个,然后回调到这里来,参数json可能是json,也可能是纯字符串,因为服务器端返回的都是json对象,这里就肯定是json了

            alert("json.result: " + json.result + " json.errormsg: "+json.errormsg);

          },

          error : function() {

            //请求出错处理

            alert("error");

          }

        });


第二种方式:

简单一点,用getJOSN方法,不过要注意的是,跨域调用的时候要在url后面传?callback=?。不跨域的时候不用写,也是ajax调用的另一种简写方法。

jQuery.getJSON(_url+"?callback=?" ,{phoneNumber : mobile,templateID : 0,sendType : 0} ,function(data)  

            {  

            alert("data: " + data.result + ", errormsg: " + data.errormsg);  

            });   


其他的注意事项:

跨域只能使用JSONP来实现,或者通过服务器端获取


另外,Access-Control-Allow-Origin 方法可以参考

http://blog.csdn.net/net_lover/article/details/5172509
http://blog.csdn.net/net_lover/article/details/5172522
http://blog.csdn.net/net_lover/article/details/5172532 


其他重要的文章摘要


Data Types(数据类型)


$.ajax()调用不同类型的响应,被传递到成功处理函数之前,会经过不同种类的预处理。 预处理的类型取决于由更加接近默认的Content-Type响应,但可以明确使用dataType选项进行设置。如果提供了dataType选项, 响应的Content-Type头信息将被忽略。


有效的数据类型是text, html, xml, json,jsonp,和 script.


如果指定的是text 或 html, 则不会预处理。 这些数据被简单地传递给成功处理函数, 并通过该jqXHR对象的responseText属性获得的。


如果指定的是xml, 响应结果作为XMLDocument,在传递给成功处理函数之前使用jQuery.parseXML进行解析。 XML文档是可以通过该jqXHR对象的responseXML属性获得的。


如果指定的是json,响应结果作为一个对象,在传递给成功处理函数之前使用jQuery.parseJSON进行解析。 解析后的JSON对象可以通过该jqXHR对象的responseJSON属性获得的。


如果指定的是script ,$.ajax() 执行这段 JavaScript,这段 JavaScript 从服务器接收到,在传递给成功处理函数之前是一个字符串。


如果指定的是jsonp ,$.ajax()会自动在请求的URL后面增加一个查询字符串参数 callback=?(默认) 。传递给$.ajax() 设置中的jsonp 和 jsonpCallback属性可以被用来指定, 分别为 查询字符串参数的名称和JSONP回调函数的名称。服务器应返回有效的JavaScript,传递JSON响应到回调函数(愚人码头注:例如,flightHandler({"code": "CA1998","price": 1780,"tickets": 5});等)。 在包含JSON对象的相应结果传递给成功处理函数之前,$.ajax() 将执行返回的JavaScript, 调用JSONP回调函数。


更多JSONP信息可以参阅详细介绍了其使用的原帖.


Sending Data to the Server(发送数据到服务器)


默认情况下,Ajax请求使用GET方法。如果要使用POST方法,可以设定type参数值。这个选项也会影响 data 选项中的内容如何发送到服务器。POST数据将被发送到服务器使用UTF-8字符集,根据W3C XMLHttpRequest的标准。


data选项既可以包含一个查询字符串,比如 key1=value1&key2=value2,也可以是一个映射,比如 {key1: 'value1', key2: 'value2'} 。如果使用了后者的形式,则数据再发送前会用jQuery.param() 将其转换成查询字符串。这个处理过程也可以通过设置processData选项为false来回避。如果我们希望发送一个XML对象给服务器时,这种处理可能并不合适。并且在这种情况下,我们也应当改变contentType 选项的值,用其他合适的MIME类型来取代默认的 application/x-www-form-urlencoded 。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在使用 jQueryAJAX 请求时,可以采用以下方法来解决问题: 1. JSONP(JSON with Padding)请求:使用 JSONP 可以通过在请求 URL 中添加一个回调函数名来实现请求。服务器返回一个函数调用,并将数据作为参数传递给该函数。在 jQuery 中,可以设置 `dataType: 'jsonp'` 来发送 JSONP 请求。 2. CORS(Cross-Origin Resource Sharing)请求:使用 CORS 可以在服务器端设置允许请求的响应头,从而实现请求。在 jQuery 中,可以设置 `crossDomain: true` 和 `xhrFields: {withCredentials: true}` 来发送 CORS 请求。 3. 代理请求:在服务器端设置一个代理,将客户端的请求转发到目标服务器上,并将目标服务器返回的响应返回给客户端。在 jQuery 中,可以使用 `$.ajax()` 方法的 `url` 属性指定代理服务器的 URL。 需要注意的是,以上方法都有各自的限制和适用场景,具体使用时需要根据实际情况选择合适的方法来解决问题。 ### 回答2: 问题指的是浏览器出于安全考虑,禁止进行访问,即在A名下的网页无法访问B名下的资源。而jQuery Ajax是一种强大的工具,通过它我们可以方便地进行服务器端和客户端之间的异步数据交互。但是,由于Ajax请求也受到限制,导致我们在使用Ajax进行数据请求时需要进行一定的处理。 问题的解决办法有很多种,可以通过后端设置Header头信息,也可以通过前端设置JSONP或CORS等方式进行解决。接下来,我们针对Ajax问题,主要介绍以下两种解决方案: 1、JSONP 方式 JSONP是一种数据请求的协议,其原理是在前端代码中添加一个脚本标签,通过向服务器端动态加载一个JS脚本,使得服务器返回的数据被包裹在一个回调函数中,并在前端代码中调用该回调函数。 示例代码: ``` $.jsonp({ url: 'http://www.example.com/api/testjsonp', // jsonp地址 type: 'GET', dataType: 'jsonp', jsonp: 'callback', //callback参数名 success: function(obj) { // 成功回调函数 // 处理返回的json数据... }, error: function() { // 失败回调函数 console.log('fail'); } }); ``` 在实现JSONP请求时,需要注意以下几点: (1)需要后端接口支持JSONP回调函数,即在后端接口中返回的数据需要被包裹在一个函数中,并通过callback参数名来传递前端定义的回调函数名称。 (2)需要定义一个callback参数名,该参数名需要在后端接口和前端代码中保持一致。 (3)需要在前端代码中定义一个回调函数,该回调函数会在后端接口返回数据时被调用,在该函数内部进行数据处理操作。 2、通过CORS方式 CORS即资源共享,是一种使用了浏览器内置的安全机制,允许符合条件的网站进行访问。CORS的实现需要在服务端支持,并且在请求头中添加特定的信息来启动。 示例代码: ``` $.ajax({ url: "http://www.example.com/api/testcors", // cors地址 type: "GET", dataType: "json", xhrFields: { withCredentials: true }, // 允许带 cookie 请求,不加会丢失 crossDomain: true, // 允许请求 success: function(data) { // 成功回调函数 // 处理返回数据... }, error: function() { // 失败回调函数 console.log("fail"); } }); ``` 在使用CORS时,需要注意以下几点: (1)需要在服务端开启CORS,允许其他名的访问。 (2)在前端AJAX请求时需要设置crossDomain为true,同时设置xhrFields中的withCredentials为true。 (3)需要在服务端响应中添加特定的header信息,如Access-Control-Allow-Origin等,来告知浏览器该请求被允许。 通过上述两种方式,我们可以轻松地解决Ajax问题,并实现服务端和客户端之间的数据交互。 ### 回答3: 是指在当前页面的名、协议、端口与请求的 URL 不同,根据浏览器的同源策略,会阻止请求。jQuery ajax 解决方法主要有以下几种: 1. JSONP JSONP 是一种利用 `<script>` 标签进行的方式。首先客户端定义一个回调函数,然后将该函数名作为参数放在请求 URL 中,服务端接收到请求后动态生成 JSON 数据并将其作为函数参数传递给回调函数,以实现访问。 常见代码示例: ``` $.ajax({ url: 'http://example.com/data?callback=mycallback', dataType: 'jsonp', jsonpCallback: 'mycallback', success: function(data){ // 处理数据 } }); ``` 2. CORS CORS(Cross-Origin Resource Sharing)是一种机制,允许服务器在响应头中设置一个 Access-Control-Allow-Origin 字段,指定允许访问的名。 常见代码示例: ``` $.ajax({ url: 'http://example.com/data', type: 'GET', xhrFields: { withCredentials: true }, crossDomain: true, success: function(data){ // 处理数据 } }); ``` 需要注意的是,使用 CORS 时浏览器需要支持 CORS 并开启,服务端需要设置 Access-Control-Allow-Origin,同时需要注意处理预请求(OPTIONS 请求)。 3. 代理 使用代理是一种比较常见的解决问题的方法,即在同一名下设置一个代理服务器,将客户端请求转发至目标服务器,然后将目标服务器的响应返回给客户端。通过代理服务器可以绕过浏览器的同源策略,实现访问。 常见代码示例: ``` // 代理服务器代码 const http = require('http'); const request = require('request'); const url = require('url'); const server = http.createServer(function(req, res){ const target = url.parse(req.url).query; req.pipe(request(target)).pipe(res); }); server.listen(8000); // 客户端代码 $.ajax({ url: '/proxy?url=http://example.com/data', type: 'GET', success: function(data){ // 处理数据 } }); ``` 需要注意的是,使用代理时需要考虑代理服务器的负载以及安全问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值