使用nginx实现纯前端跨越

  1. 你是否厌倦了老是依赖后台去处理跨域,把握不了主动权
  2. 你是否想模仿某个app倒腾一个demo,却困于接口无法跨域

那么很幸运,接下来我将现实不依赖任何后台,随心所欲的想访问哪个域名就访问哪个!

下载nginx

地址: http://nginx.org/en/download.html
注意: 存放目录中不能含有中文

nginx配置

强大的nginx反向代理工具,有很多东西值得我们去研究,这里我只贴出核心代码,其他的还有待深入。例如我想做一个豆瓣的高仿app,调用 搜索图书接口

  • 本应该调用的地址 //api.douban.com/v2/book/search?q=解忧杂货店&tags=12

  • 本地电脑ip:192.168.1.168
  • 本地React工程访问地址:192.168.1.168:404
  • 实现跨域后React工程访问地址:192.168.1.168
  • 实现跨域后豆瓣接口调用的地址: //192.168.1.168/douban/v2/book/search?q=解忧杂货店&tags=12

nginx.conf server

834823-20170908143648569-386634121.png

完整配置文件

https://github.com/helijun/react-learn/blob/master/nginx/conf/nginx.conf

启动nginx

将上面的配置文件替换你本地的nginx.conf
更改ip地址,server监听端口
cd到nginx存放的根目录

start nginx.exe

到此为止,大功告成,没错就是这么简单。测试效果:
834823-20170908145741476-624001097.png

另外附上nginx常用的几个命令

start nginx.exe //启动
nginx.exe -s reload //重启
nginx.exe -s stop //快速停止
nginx.exe -s quit //完整有序停止

总结

其实前端跨域问题在现在的前后端分离的项目中,应该是说普遍存在的,之前也写过相关的文章总结 jsonp跨域请求优雅的封装ajax,含跨域,但是都基本上是要后台配合的,并且还有很多局限性。那么现在这种方式,就真的很随心所欲的,比如我现在还想代理到百度的api,那么只要在那个server中再添加一个location即可,如:

location /baidu {
        rewrite  ^/baidu/(.*)$ /$1 break;
        proxy_pass   https://api.baidu.com;
}

注意事项

或许你发现了,所有的请求都添加了一个'douban'前缀,那么在真实的项目中,务必将这个前缀设置为一个变量,然后所有的ajax请求url都拼接这个前缀,防止后续如果有变更导致牵一发而动全身。

固定ip

为了防止ip变化导致nginx配置失效,我这里固定ip为 192.168.1.168

打开网络和共享中心->本地连接->属性->双击Internet协议版本4(TCP/IPv4)属性

834823-20170908143849679-1264678745.png

转载于:https://www.cnblogs.com/liliangel/p/7494853.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值