码迷,mamicode.com
首页 > 其他好文 > 详细

前端开发调试之代理配置

时间:2018-03-15 22:08:08      阅读:279      评论:0      收藏:0      [点我收藏+]

标签:代理配置   nginx代理   灵活   输入框   name   无法   安全   style   之间   

前端开发往往需要在本地调试环境和线上环境之间灵活切换,以将要调试的一个页面为例,页面引用了如下的静态资源,要想在本地开发调试下面引入的js代码,最直接的方法是在把引入的资源路径改成本地调试路径,并起一个本地服务器访问页面,使用这种方法最大的缺点就是上线前需要恢复原来的引入路径,再或者我们没有权限修改页面代码,上述方法也无法使用。因此代理的方式才是首选。

<script type="text/javascript" src="//q.qunarzz.com/flight_tejia/prd/scripts/app.js"></script>

Mac上常用两种代理工具:Nginx和Charles,下面介绍这两种工具的配置方法。

配置Nginx代理

第一步:配置host使请求打到本地

127.0.0.1 q.qunarzz.com

为了方便配置host,推荐使用SwitchHosts软件


技术分享图片?

第二步:配置nginx
nginx基本命令

sudo nginx #第一次启动nginx
sudo nginx -s reload #重新启动nginx
sudo nginx -s stop ?#关闭nginx

以支持https请求为例,浏览器或者模拟器访问页面https://q.qunarzz.com:443/xxxxx,域名解析host生效—>127.0.0.1:443/xxxx,使用nginx的proxy_pass代理到本地端口如3000因此会将请求打到本地服务,对于的nginx配置如下,对于https需要安装证书文件,可以参考如何为nginx配置https(免费证书)

server{
 ?  listen ?80;
 ?  listen ?443 ssl;
 ? ?#监听的域名
 ?  server_name qunarzz.com q.qunarzz.com my.qunar.com mobileqzz.beta.qunar.com;
 ?  expires -1;
?
 ?  ssl_certificate ? ?  /usr/local/etc/nginx/cert/xxx.crt;
 ?  ssl_certificate_key  /usr/local/etc/nginx/cert/xxxx.key;
?
 ?  ssl_session_cache ?  shared:SSL:1m;
 ?  ssl_session_timeout  5m;
?
 ?  ssl_ciphers  HIGH:!aNULL:!MD5;
 ?  ssl_prefer_server_ciphers  on;
?
 ?  location ~ /(flight_tejia)/ {
 ? ? ?  proxy_pass http://127.0.0.1:8000;
 ? ? ?  proxy_set_header ? Host $host;
 ? ? ?  proxy_set_header ? X-Real-IP ? ? ? ?$remote_addr;
 ? ? ?  proxy_set_header ? X-Forwarded-For ?$proxy_add_x_forwarded_for;
 ?  }
}

配置Charles代理

个人喜欢使用Charles代理,图形化的界面便于发现代理错误和集中管理常用代理,上面的代理也可以使用Charles配置,而且不需要单独配置host。
第一步:开启Charles的SSL proxy
开启Charles,点击顶部菜单栏的Proxy--SSL Proxying Settings,打开设置页面。点击add按钮,可以对制定的Host和Port进行SSL Proxy,如果想对所有的Host进行SSL代理,在Host输入框里填*,在Port框里填443,这样可以代理所有域名或ip。最后点击Enable SSL Proxying,生效设置。


技术分享图片?

第二步:终端连代理,安装Charles的证书
保证终端和电脑在同一个局域网内,比如手机和电脑都连同一个热点,或者电脑开共享热点,手机连这个热点。模拟器就不需要了。在手机的WLAN设置里,选择热点-修改网络或者高级设置-代理-手动,输入电脑的局域网IP,端口号是8888。这个8888是Charles的默认端口号。连接成功后,在手机浏览器里输入http://charlesproxy.com/getssl,点回车。会自动下载弹窗提示安装charles的ssl证书,安装即可。


技术分享图片

补充说明在手机或者模拟器上要设置信任证书,设置->通用->关于手机-> 证书信任设置
第三步:通过Map Remote实现https转http
手机连上Charles的代理,发送网络请求。第一次连Charles发请求时,Charles会弹窗提示是否允许该终端发网络请求,一定要点是!。可以看到即使是https,也可以明文展示。以q.qunarzz.com为例,找到q.qunarzz.com的请求项,右击,点击Map Remote, 将https://q.qunarzz.com 映射到 http://q.qunar.com,重新发请求即可。

最后还有一点需要注意,由于浏览器的安全策略,如果使用浏览器打开,可能会有如下错误,只需要继续前往,然后刷新页面就好了。
技术分享图片

前端开发调试之代理配置

标签:代理配置   nginx代理   灵活   输入框   name   无法   安全   style   之间   

原文地址:https://www.cnblogs.com/star91/p/qian-duan-kai-fa-diao-shi-zhi-dai-li-pei-zhi.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!