• jquery用jsonp方式跨域获取json数据原理(解决jquery跨服务器权限受限问题)


    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 函数里.(动态执行回调函数)

  • 相关阅读:
    PBOC规范研究之九---静态数据认证(转)
    PBOC规范研究之五、安全相关的PKI基础知识(转)
    PBOC规范研究之三、TypeB协议(转)
    PBOC规范研究之二、PBOC规范中,对于通讯速率的约定(转)
    PBOC规范研究之一、ISO14443协议和PBOC关于CID的约定(转)
    qml js
    qml 信号与信号 信号与方法链接使用 带参数会报错
    调试bug的几种方法
    CDN方式使用iview
    iView--3
  • 原文地址:https://www.cnblogs.com/Byrd/p/1968162.html
Copyright © 2020-2023  润新知