继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

js跨域的解决多种方案

慕村5556544
关注TA
已关注
手记 2
粉丝 0
获赞 9
跨域的解决方案
1域名组成:

1.协议http 子域名www 主域名abc.com 端口号8080 请求资源source、jquery.js、

解决方案
  1. 使用代理
  2. JSONP
    • ==JSONP只能处理get请求,这是其局限性==
$("#search").click(function(){ 
        $.ajax({ 
            type: "GET",    
            url: "http://127.0.0.1:8000/ajaxdemo/serverjsonp.php?number=" + $("#keyword").val(),
            //将数据格式改为JONP 以及jonp属性为:‘callback’这个为任意名
            dataType: "jsonp",
            jsonp: "callback",
            success: function(data) {
                if (data.success) {
                    $("#searchResult").html(data.msg);
                } else {
                    $("#searchResult").html("出现错误:" + data.msg);
                }  
            },
            error: function(jqXHR){     
               alert("发生错误:" + jqXHR.status);  
            },     
        });
    });

3.XHR2

  • HTML5提供的XMLHttpRequest Level2实现的跨域访问以及其他的一些新功能
  • IE10以下不支持
  • //在服务器端头部添加
    header('Access-Control-Allow-Origin:*');
    header('Access-Control-Allow-Methods:POST,GET');
打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP