设为首页 收藏本站
查看: 772|回复: 0

[经验分享] 使用nginx实现纯前端跨越

[复制链接]

尚未签到

发表于 2017-12-22 16:17:31 | 显示全部楼层 |阅读模式

  • 你是否厌倦了老是依赖后台去处理跨域,把握不了主动权
  • 你是否想模仿某个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
DSC0000.png


完整配置文件
  https://github.com/helijun/react-learn/blob/master/nginx/conf/nginx.conf

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

start nginx.exe  

  到此为止,大功告成,没错就是这么简单。测试效果:
  
DSC0001.png
  另外附上nginx常用的几个命令
  

start nginx.exe //启动
  
nginx.exe -s>  
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)属性
DSC0002.png

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-426897-1-1.html 上篇帖子: 打造最强NGINX HTTPS 下篇帖子: Nginx+Tomcat的服务器端环境配置详解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表