html代码:

 <html xmlns="http://www.w3.org/1999/xhtml">

 

<head runat="server">
    <title></title>
    <script src="jquery-1.3.2-vsdoc2.js" type="text/javascript"></script>
    <script type="text/javascript">
        function getdata() {
            $.ajax({
            url: "http://192.168.2.32/jquery/ajax_do.aspx?callback=?",
            dataType: "jsonp",
            jsonp:"callback",
                success: function(data) {
                alert(data);
                  $("#sp_data").html(data.msg);
                }
            });
        }
    </script>
</head>
<body>
    <div>
     <a onclick="getdata()" href="#" style="color:Blue">跨域</a>
    </div>
</body>
</html>
 

 

后台代码(ajax_do.aspx.cs):

 

        string callback=Request.QueryString["callback"];
        Response.Write(callback+"({msg:'error action!'})");

 

 

Jsonp原理:

首先在客户端注册一个callback, 然后把callback的名字传给服务器。

此时,服务器先生成 json 数据。 

然后以 javascript 语法的方式,生成一个function , function 名字就是传递上来的参数 jsonp.

最后将 json 数据直接以入参的方式,放置到 function 中,这样就生成了一段 js 语法的文档,返回给客户端。

客户端浏览器,解析script标签,并执行返回的 javascript 文档,此时数据作为参数,传入到了客户端预先定义好的 callback 函数里.(动态执行回调函数)

 

 

 

相关文章:

  • 2021-11-30
  • 2022-02-25
  • 2021-12-15
  • 2021-10-24
  • 2021-12-26
  • 2022-01-20
猜你喜欢
  • 2021-06-21
  • 2022-12-23
  • 2021-05-17
  • 2022-01-16
  • 2021-10-10
相关资源
相似解决方案