ZanProxy —— 本地代码调试线上页面,环境再也不是问题

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 一、ZanProxy 是什么 一言以蔽之,ZanProxy 是一个基于 Node.js 的代理服务器。它专注于帮助前端开发提高开发效率。 二、我们为什么需要一个代理工具 在前端开发中,我们常常会碰到以下几个场景: 对于前端开发者来说,我们需要一个工具能让我们直接用本地的前端代码调试QA环境、预发环境、甚至线上的页面。

一、ZanProxy 是什么

一言以蔽之,ZanProxy 是一个基于 Node.js 的代理服务器。它专注于帮助前端开发提高开发效率

ZanProxy intro二、我们为什么需要一个代理工具

在前端开发中,我们常常会碰到以下几个场景:

  1. 对于前端开发者来说,我们需要一个工具能让我们直接用本地的前端代码调试QA环境、预发环境、甚至线上的页面。

  2. 我们需要在开发的时候需要快速切换环境,修改系统的 host 会有浏览器的 DNS 缓存,常常需要手动清除。所以我们需要一个工具让我们秒切host,不用等待 。

  3. 前后端并行开发的时候,开发中接口的数据通常需要 mock。通过nginx反向代理到mock平台步骤繁琐,配置麻烦,对新手及其不友好。 所以我们需要一个工具能轻松 mock 接口的数据。

在 ZanProxy 之前,我们做过的努力

为解决上面这些问题,我们进行了一些摸索并且做出了一些工具,但是这些工具都这样或那样不尽人意的地方。

我们曾将做了一个项目级别的mock工具叫Doraemon。 这个工具通过修改发送ajax请求的包,会把我们的请求转发到我们的一个 mock 数据平台,从而实现接口 mock 的功能。

后来我们又做了一个工具叫zRedzRed是一个 Chrome 浏览器的插件,会自动监控 chrome 浏览器内的所有请求,根据预先设置的匹配规则,将线上前端 css,js 代码请求转发成相对应的本地请求。

但这些方案都存在明显的问题

首先,Doraemon会入侵我们的项目代码,强依赖于发送ajax请求的包,不利于工具的扩展和升级。而且这个工具只有 mock 功能,上面很多问题都不能得以解决。

zRed由于是一个chrome浏览器插件,不能在其他平台上使用,比如说在移动端上使用,让真机调试成为了一个问题。

最后确定的方案

最终决定的方案是使用一个代理服务器,也就是 ZanProxy, 来帮助我们解决环境问题。和以前的方案相比,ZanProxy 拥有更丰富的功能,可以同时在pc端和移动端使用,为开发者解决环境问题提供更了更多的助力。

三、ZanProxy 能做什么

请求代理与转发

ZanProxy 支持代理 http 和 https 的请求,并会根据用户配置的规则进行请求的转发。用户可以在界面上配置自己的请求转发规则,将符合某种特征的请求转发到需要的地址,可以是本地的一个文件路径或者是一个 URL 。我们常见的用法是将浏览器请求的静态资源如 js,css 等文件转发到本地,实现用本地代码对线上页面的调试

团队规则同步

ZanProxy 支持远程规则,目的是让团队成员间共用同一份转发规则,降低沟通成本。ZanProxy 会在启动的时候同步最新的远程规则,所有的变更都能在使用者之间共享。

无痛 Host 切换

ZanProxy 支持用户自定义 Host 解析,方便用户进行环境的切换,这是通过在转发时,把域名直接替换成指定 ip 实现的,Hosts 的修改没有缓存。ZanProxy 不会修改系统的 Hosts 文件,所以用户在关闭 ZanProxy 后会恢复正常的 DNS 解析,不需要担心会有什么副作用。

自定义响应数据

ZanProxy 支持用户自定义请求的响应数据,意味着用户可以利用 ZanProxy mock 接口数据,不用再等待接口开发完成。

请求监控

ZanProxy 可以让用户监控所有被代理的请求,能看到每一个请求的请求数据和响应数据。用户可以将手机的代理设置成 ZanProxy ,通过 ZanProxy 监控手机的请求,为移动端真机调试带来便利。

自定义插件

随着业务复杂度的增加,单纯的请求转发已经不能满足业务方的需求,面对不断增长的需求我们发现ZanProxy需要有一个机制,让用户扩展 ZanProxy 的代理行为,于是我们为 ZanProxy 增加了支持自定义插件的功能,这样 ZanProxy 就有了很强的扩展性。ZanProxy 支持用户开发自定义插件进行功能的扩展,满足用户在各种场景下的需求,比如给所有的响应增加 Access-Control-Allow-Origin 的头,轻松解决跨域问题。自定义插件编写指南:点击此处

ZanProxy plugin

四、写在最后

虽然 ZanProxy 在有赞内部已经大规模使用了,但肯定存在许多的不足和可以改进的地方,希望大家能多提宝贵的意见。


原文发布时间:06月25日

原文作者:有赞前端

本文来源掘金如需转载请紧急联系作者

相关文章
|
存储 缓存 搜索推荐
想要快速地拥有Sitecore DXP平台!这九个开发大坑一定要避开!
随着互联网技术的深入的发展,人们对于个性化的渴望已经达到了新的阈值,这也让以数字洞察力、个性化体验为名的Sitecore DXP平台成为了品牌们竞相追捧的新宠。而在这样的需要背景下,一众新手企业纷纷投身市场,想要分一杯羹。但是经验不足的新人入场,难免会带来不少麻烦,甚至引发了人们对于Sitecore性能的质疑。
|
安全 Java Devops
在线捉虫:1分钟代码自动检测体验
1分钟快速体验阿里云云效提供的免费在线git代码托管和代码自动检测能力
|
数据可视化 JavaScript 前端开发
尝试7分钟内上线一个网站,这个工具太赞了!
尝试7分钟内上线一个网站,这个工具太赞了!
119 0
|
前端开发 Java API
如何使用线上环境进行本地代码调试
如何使用线上环境进行本地代码调试
563 0
|
IDE 测试技术 编译器
如何管理代码仓库,可以用什么系统开发,编程工具有哪些,程序异常怎么定位分析?
随着工具的日新月异,善于利用这些工具将有利于我们开发效率的提高,本文将简要介绍标题相关知识。
|
SQL Java 数据库连接
线上运行的项目突然变得很卡如何排查?
线上运行的项目突然变得很卡如何排查?
|
测试技术 Shell Linux
Android应用启动流量自动化测试
之前《Tcpdump流量自动化测试上篇》、《Tcpdump流量自动化测试下篇》这两篇文章里讨论了如何通过tcpdump命令行工具来实现Android应用的流量自动化采集和分析,今天再来跟大家分享一下如何针对应用启动场景来做流量测试,有人可能会问了为什么是启动场景?因为现在工信部要求在用户没有授权网络请求前,应用不得擅自进行网络请求,特别是当跟厂商合作提供预装包的时候对此项的检查很严格。 另外跟大家说明一下,我分享的文章都是亲自实践过的,基本照着方案操作不会有大问题,默认情况下我所使用的操作系统都是MacOS。
426 0
Android应用启动流量自动化测试
|
视频直播 Android开发
直播间源码在开发前期必须做的工作及开发步骤
直播间源码的火爆不言而喻,大家对直播的热情也越来越高涨,他不仅给我们的娱乐生活添加了色彩,而且逐渐的改变了我们很多的生活方式。目前市场上做直播间源码开发的有很多,今天与大家一起来分享一下直播间源码在开发前期必须要做的工作及开发步骤都有哪些。
直播间源码在开发前期必须做的工作及开发步骤
|
程序员 测试技术

热门文章

最新文章