跨域的几种实现方式

  1. jsonp

     $.ajax({  
     type: "get",  
     url: "/home/ReturnJson",  
     dataType: "jsonp",  
     jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback, http://xxxx.com?callback=foo)  
     success: function (data) {  
             alert(data.name);  
         },  
     error: function () {  
             alert('fail');  
         }  
     });  
  2. 服务器设置响应头, 允许跨域(一般不建议这样做)

    res.header("Access-Control-Allow-Origin", "*");

  3. 服务器转发

    服务器与服务器之间没有跨域问题. 可以让本机服务器作为代理,来请求第三方服务器, 然后将第三方服务器数据返回回来,但是不会携带cookie

  4. 反向代理

    配置步骤:

    1> 找到 httpd.conf 文件
    2> 找到里面的 Proxy_modules 模块与 Proxy_http_module 模块, 将其注释去掉
    3> 找到要配置的虚拟主机
    4> 在里面添加两段代码
        ProxyRequests Off
        ProxyPass /api http://api.botue.com
    5> 重启 服务器
    <VirtualHost *:80>
       DocumentRoot"D:/developer/wamp/www/studyit"
       ServerName studyit.com
       ProxyRequests Off
       ProxyPass /api http://api.botue.com
    </VirtualHost>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值