ASP.NET中JSONP的两种实现以及其余跨域解决方案的简单实现 ASP.NET中JSONP的两种实现以及其余跨域解决方案的简单实现

   jQuery中JSONP的两种实现方式:javascript

   都很简单,因此直接上代码!html

   前台代码以下:前端

复制代码
<script type="text/javascript">
    $(function () {
        alert("start...");
        
        // 第一种方式
        $.ajax({
            type: "get",
            url: "http://localhost:9524/Home/ProcessCallback", // 这个就是不一样于当前域的一个URL地址,这里单纯演示,因此同域
            dataType: "jsonp",
            jsonp: "jsonpcallback",  // 指定回调函数,这里名字能够为其余任意你喜欢的,好比callback,不过必须与下一行的GET参数一致
            data: "name=jxq&email=feichexia@yahoo.com.cn&jsonpcallback=?", // jsonpcallback与上面的jsonp值一致
            success: function (json) {
                alert(json.Name);
                alert(json.Email);
            }
        });

        // 第二种方式
        $.getJSON("http://localhost:9524/Home/ProcessCallback?name=xiaoqiang&email=jxqlovejava@gmail.com&jsonpcallback=?",
            function(json) {
                alert(json.Name);
                alert(json.Email);
            }
        );

        alert("end...");
    });
</script>
复制代码

   后台Action代码以下:java

复制代码
public string ProcessCallback(string name, string email)
{
   if (Request.QueryString != null)
   {
       string jsonpCallback = Request.QueryString["jsonpcallback"];
       var user = new User
       {
            Name = name,
            Email = email
       };
       
       return jsonpCallback + "(" + new JavaScriptSerializer().Serialize(user) + ")";
   }

   return "error";
}
复制代码

   运行后就能够看到结果了。我追踪了下后台ProcessCallback代码,以下图:ajax

   能够看到jsonCallback的值为"jQuery17104721....",它是前端传给远程服务器后台Action的。这里jQuery171..表示的是jQuery的版本,能够简单地将这个理解为JSONP类型请求回调函数,jQuery在咱们每次指定Ajax请求方式为JSONP时都会生成这么一个JSONP回调函数。虽然jQuery会自动帮咱们生成一个回调函数,可是咱们也能够经过设置jsonpCallback参数为jsonp请求定制一个咱们本身的回调函数。json

   第一种方式下面这三行代码设定了JSONP请求方式:跨域

dataType: "jsonp",
jsonp: "jsonpcallback",  // 指定回调函数,这里名字能够为其余任意你喜欢的,好比callback,不过必须与下一行的GET参数一致
data: "name=jxq&email=feichexia@yahoo.com.cn&jsonpcallback=?", // jsonpcallback与上面的jsonp值一致

   第二种方式则直接在GET参数后面带上jsonpcallback=?来标识。浏览器

   咱们能够推断这么作之后,jQuery内部机制就帮咱们绕过了浏览器的跨域访问限制,而后就能够像正常请求同域Action同样请求跨域Action了。服务器

   最后返回的是一个函数表达式:app

return jsonCallback + "(" + new JavaScriptSerializer().Serialize(user) + ")";

   这样返回给前端的就是相似这种jQuery17104721....('{Name:"jxq", Email:"feichexia@yahoo.com.cn"}'),它一返回到前端就会执行,获得的是一个JavaScript对象,对象有两个属性:Name和Email,因此咱们能够直接调用json.Name和json.Email。

   上面return时千万别忘了圆括号,缘由很少说,看看下面的例子就明白了:

var response = "{'foo' : 'bar'}";
var json = eval(response);  // Invalid label
var json = eval("(" + response + ")"); // OK

   此外也能够经过动态建立Script、内嵌iframe方式实现跨域。动态建立script的简单代码以下:

复制代码
$(function() {
    var script = document.createElement("script");
    script.type = "text/javascript";
    script.src = "http://otherdomain/script.js";
            
    // 异步加载脚本
    script.onload = script.onreadystatechange = function(){
       if(!script.readyState || script.readyState == 'loaded') {  // 加载完毕
          add(1, 99); // 直接调用跨域js中的函数
       }
    };

    document.getElementsByTagName('head')[0].appendChild(script);
    // add(1, 99); // 这样会出错,由于脚本还没加载完毕
});

// script.js代码以下
function add(a, b) {
  alert("Add: " + a + "+" + b + "=" + (a+b));
}
复制代码

   固然还能够经过jQuery的getScript方法来跨域请求一个js文件或者包含js代码的文本文件(好比test.js.txt),直接贴代码:

$.getScript("http://otherdomain/test.js", function(){
   alert("Script loaded and executed."); // 脚本加载完毕后会直接执行
});

    这种方式加载完成后,就能和使用同域JS同样使用跨域JS中的函数或变量了。

相关文章
相关标签/搜索