写点什么

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

  • 2020-03-08
  • 本文字数:1657 字

    阅读完需:约 5 分钟

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

一、ZanProxy 是什么

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


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

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


  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 的头,轻松解决跨域问题。自定义插件编写指南:https://youzan.github.io/zan-proxy/book/plugin/code.html


四、写在最后

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

相关链接

主页:https://youzan.github.io/zan-proxy/


Github: https://github.com/youzan/zan-proxy


使用文档:https://youzan.github.io/zan-proxy/book/


2020-03-08 19:241192

评论

发布
暂无评论
发现更多内容

Java RMI

沃德

Java 程序员 7月月更

执掌英国工程技术学会13载,范纳杰正式退休

E科讯

正则什么的,你让我写,我会难受,你让我用,真香!

掘金安东尼

前端 正则 7月月更

git clone出错--必看贴

坚果

git Mac git 学习 7月月更

我,AI博士生,在线众筹研究主题

OneFlow

研究

有一说一,要搞明白优惠券架构是如何演化的,只需10张图!

程序员小毕

Java 编程 程序员 架构 面试

ES6 类聊 JavaScript 设计模式之结构型模式

devpoint

JavaScript 设计模式 桥接模式 适配器模式 7月月更

行业分析| 物流对讲

anyRTC开发者

人工智能 音视频 物流 调度 快对讲

mysql进阶(十四) 批量更新与批量更新多条记录的不同值实现方法

No Silver Bullet

MySQL 数据库 7月月更 批量更新

STM32+ENC28J60+UIP协议栈实现WEB服务器示例

DS小龙哥

7月月更

个性潮流与性能兼备,华硕a豆14 Pro搭载全新12代酷睿标压处理器

科技热闻

高度关注!2022 开放原子开源峰会最新议程一览

kk-OSC

开源 开放原子全球开源峰会

java零基础入门-java8新特性(中篇)

喵手

Java 7月月更

45W性能释放+2.8K OLED全面屏 华硕灵耀X 14 2022精英气质高效利器

科技热闻

这价格够香!灵耀14 2022影青釉秒杀:12代酷睿+2.8K OLED屏

科技热闻

P9力荐!阿里巴巴最新出品776页JDK源码+并发核心原理解析小册

程序员小毕

Java 程序员 面试 程序人生 jdk源码

博物馆数字化——数字藏品app开发

开源直播系统源码

区块链数字藏品 数字藏品软件开发

一年时间过去了,LiveData真的被Flow代替了吗? LiveData会被废弃吗?

编程的平行世界

android android jetpack

LeetCode-94. 二叉树的中序遍历(java)

bug菌

Leet Code 7月月更

Qt|控制QScrollBar显示位置

中国好公民st

qt 7月月更

阿里云技术专家杨泽强:弹性计算云上可观测能力构建

阿里云弹性计算

DevOps 可观测性 CI/CD metrics

wallys/industrial Wireless AP/industrial Wireless AP

wallys-wifi6

IPQ4019/IPQ4029

SAP ABAP 解析 excel 文件的函数 TEXT_CONVERT_XLS_TO_SAP 单步执行分析

汪子熙

Cloud SAP abap Netweaver 7月月更

Qt | Qt的项目文件.pro文件详解

YOLO.

qt 7月月更

Wallys/industrial Wireless AP/IPQ6018,IPQ4019,IPQ4029,802.11ax,802.11ac,outdoor ap

wallys-wifi6

常用 CSS 代码片段集合,建议收藏

南城FE

CSS 前端 CSS语法 7月月更

即刻报名|如何降低云上数据分析成本?

Kyligence

数据分析 智能多维数据库

wallys/industrial Wireless AP/IPQ4019 IPQ4029 ,802.11ac /VSSupport IPQ6018 IPQ4019 IPQ4029 802.11ax 802.11ac

wallys-wifi6

云原生 SIG 直播:关于 cni 与 hybridnet 核心技术分享 | 第 35 期

OpenAnolis小助手

开源 云原生 直播 sig 龙蜥大讲堂

源启数字化:既有模式,还是开源创新?|砺夏行动

OneFlow

活动

【LeetCode】使数组可以被整除的最少删除次数Java题解

Albert

LeetCode 7月月更

ZanProxy —— 本地代码调试线上页面,环境再也不是问题_文化 & 方法_maiweiqi_InfoQ精选文章