jQuery实现跨域请请求小案例

jQuery从1.2开始就支持XMLHttp跨域请求了,具体怎么操作?


jQuery中跨域访问的核心原理:JS文件注入,因为因为script标签的src属性是可以跨域的,利用script标签的src属性直接返回非本域名下的数据,具体采用的方式称为:jsonp。
代码:
    test.html,例如位于 www.qq.com
     <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html http://www.w3.org/1999/xhtml">http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title>jQuery-跨域请求</title>
    <script type="text/javascript" src="/js/jquery.js"></script>
    </head>
     <script type="text/javascript">
    jQuery(document).ready(function(){
        $.ajax({
            type : "GET",
            url : "http://www.b.com/server.php&action=getmsg&callback=?",
           dataType : "jsonp",
           jsonp: 'callback',
            success : function(json){
                $('#msg_box').html(json.msg);
                return true;
            }
        });
    });
    </script>
     <body>
    <div id="msg_box"></div>
    </body>
    </html>

    server.php,例如位于www.baidu.com
    <?php
    $action = $_GET['action'];
    $callback = $_GET[callback ];
    
    if ($action)
    {
        echo "{$callback}({"msg":"this is a jquery jsonp test message!"})";
        exit();
    }
    else
    {
        echo "{$callback}({"msg":"error action!"})";
        exit();
    }
    ?>

posted on 2014-06-16 16:21  朱永志  阅读(263)  评论(0编辑  收藏  举报

导航