解决本地开发时调用远程AIP跨域问题

问题情境:

一般开发在本地,使用的是 Wampserver64,一般为了方便都是一个项目开一个虚拟主机,然后设置host,使用域名重定向,用一个“假域名”来开发调试项目,这样比较方便。

如果调试远程API时,是会有跨域问题的,那么此时可以使用 jsonp,或者设置远程web服务器的Access-Control-Allow-Origin: *,但是这两种解决方案都是需要你有远程web服务器的掌控权才可以。

今天遇到一个问题,别人说他那边web服务器和接口不好改动。让我自己本地设置一个nginx的方向代理。

我本地是Apache,不过也是可以配置代理的,配置方法见参考文章。

于是一番倒腾,终于成功了。

其实原理就是:使用反向代理(对用户不可见,对服务器可见)。

利用反向代理,我们可以将 url/api,代理到 远程域名上去。

这样请求 url/api?a=1 时,实际上请求的是 远程域名?a=1

简单的说,我们通过这个代理配置欺骗了服务器,让它以为我们一直在相同域名下访问资源(请求API)。

代理配置:

文件:httpd-vhosts.conf<VirtualHost *:80>
    ServerName tang-h5.com
    DocumentRoot d:/wamp64/www/tang-h5

    # 设置允许跨域 参考:http://blog.csdn.net/linxiangyao/article/details/6107617
    Header add Access-Control-Allow-Origin *
    Header add Access-Control-Allow-Headers "Content-Type"

    # 解决mod_rewrite时pathinfo url参数中不能带有特殊字符问题 参考:http://www.2cto.com/os/201409/338511.html
    AllowEncodedSlashes On

    <Directory  "d:/wamp64/www/">
        Options +Indexes +Includes +FollowSymLinks +MultiViews
        AllowOverride All
        Require local    </Directory>


    ProxyRequests Off    <Proxy *>
      Order deny,allow
      Allow from all    </Proxy>
    ProxyPass /api http://www.xxx.com</VirtualHost>

参考:

Apache设置反向代理解决js跨域问题 - 51CTO.COM

Apache设置反向代理解决js跨域问题 - 技术分享 - SegmentFault


看恩吧
网站不承担任何有关评论的责任
  • 最新评论
  • 总共条评论
取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦