1. 介绍

whistle(读音[ˈwɪsəl],拼音[wēisǒu])基于Node实现的跨平台web调试代理工具,类似的工具有Windows平台上的Fiddler,主要用于查看、修改HTTP、HTTPS、Websocket的请求、响应,也可以作为HTTP代理服务器使用,不同于Fiddler通过断点修改请求响应的方式,whistle采用的是类似配置系统hosts的方式,一切操作都可以通过配置实现,支持域名、路径、正则表达式、通配符、通配路径等多种匹配方式,且可以通过Node模块扩展功能

2. 安装

官方文档-安装步骤

  • 2.1 npm安装
npm install -g whistle
  • 2.2 基本命令
// 启动whistle:
w2 start 重启whsitle:
w2 restart 停止whistle:
w2 stop 调试模式启动whistle(主要用于查看whistle的异常及插件开发):
$ w2 run

3. 使用

当所有安装都已经完成之后,就可以进行使用了

  • 3.1 启动whistle
// 终端运行命令
w2 start



可以通过本地地址访问whistle的界面

  • 3.2 配置Proxy SwitchyOmega

  • 3.2.1 可以直接在对应网站,直接切换你配置的代理



  • 3.2.2 使用auto_switch 模式

    在对应域名下,Proxy SwitchyOmega会根据对应的域名,来调用你定义的代理服务器

但是这里有个问题就是,如果后端访问接口跟你配置的域名不一致,那么会走不到这个代理来

比如 前端访问为 www.example.com 后端服务器为www.example1.com 那么 你就需要再配置一个 www.example1.com 调用self_proxy 代理 如果,后端有很多接口,那就直接使用第一种最好,直接选择self_proxy代理,只是这种选择会影响到浏览器其他网页的访问

注意域名通配符配置 需要这么配置 假设你的网址为 https://adc.example.com.cn

或者使用网址通配符配置 对于这一个存在一些限制 Chromium 完整网址限制 · FelisCatus/SwitchyOmega Wiki · GitHub

如果你不知道该怎么写这个通配符可以这么做,代理软件会帮助你生成一个通配符



  • 3.3 如果你想抓取https请求则需要在电脑安装证书

注意:安装证书也就相当于你把别人的指纹录入到了你家的密码锁,因此安装三方证书一定要确认这个三方证书是可信的而不是任意一个网站上下载的证书(这个判断需要个人根据经验自行判断)

对于https,传输的数据,没有证书进行加解密,外界是无法破解传输内容的,因此计算有第三方拦截了请求,他也不知道具体的内容是什么(这里设计到安全与鉴权相关知识,此处仅仅简单举例)

但是你安装与信任了外部证书,就相当于这个新安装的证书也可以解密你传输的数据

杂谈: 对于一些公司会要求安装公司的软件,以达到了解员工日常活动的目的,就是这个原理,如果员工仅仅是连接公司网络,不安装公司软件,那么公司是无法获知员工的访问内容的,而仅仅只能知道员工访问了那些网站,具体内容是不知道的

  • 3.4 配置whistle

在 Proxy SwitchyOmega配置后 并访问对应网页假设 网页为 www.abc.com 则请求就会走到 www.example.com



这个时候 whistle的这个配置生效 就会把所有访问www.example.com 的请求 都转发到 whistle的端口(当然你也可以指定你自己的代理服务器,不一定是你的本地,也可以是你本地的其他服务或者线上的其他服务,甚至whistle的功能你也可以自己通过node写一个)

4. 抓取内容

5. 修改内容(功能重点)

对于上面的 代理 也就是如果访问 a.com 显示b.com的内容,都是可以通过修改本机的host文件来实现的(这就涉及到浏览器访问网页按下回车后,干了哪些事)

简单说浏览器的域名解析(所有的域名 最终都是要解析为ip,域名是为了方便记忆,以及访问而产生的)

  • 就是浏览器先找自己的缓存看有没有
  • 自己没有 看本地host文件有没有域名与ip对应关系
  • host也没有 访问dns服务器 (dns服务器会一层一层网上找,类似于 从县到市再到省再到国家这种)
  • 能查到则访问对应ip,查不到则浏览器会显示无法访问

5.1 修改请求返回 header 可以用来跨域(在服务器暂时无法配置解决跨域,可以本地先通过修改请求返回header来越过,当然也可以关闭浏览器的跨域限制,这里又涉及到了为什么跨域以及跨域的解决方法 之前文章:浏览器跨域与处理方案 - 简书 (jianshu.com)

此处仅举例 修改请求返回header 其余功能参考官方文档

5.1.1先在values 定义对应修改header的json文件

{
"Access-Control-Allow-Origin": "http://abc.com",
"Access-Control-Allow-Credentials":true
}

5.1.2 在Rules中 定义规则 对resHeader 的覆写修改使用 response.json 文件中的内容

https://example.com resHeaders://`{response.json}`

resHeaders · 官网文档

whistle代理使用的更多相关文章

  1. 2019年Web前端最新导航(常见前端框架、前端大牛)

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 前言 本文列出了很多与前端有关的常见网站.博客.工具等,整体来看比较权威.有些东西已经 ...

  2. 移动端调试Web页面

    移动端调试Web页面 虽然可以在PC下,通过开发者工具,模拟移动端,但是这样只能模拟页面样式,对于代码的执行情况是无法模拟的,所以在此结合实际调试经验,针对安卓与IOS设备,进行总结. IOS 安卓 ...

  3. 跨平台web调试代理工具---whistle

    whistle是基于Node实现的跨平台web调试代理工具,支持windows.mac.linux等所有安装了Node的操作系统,可以部署在本地机器.虚拟机或远程服务器,并通过本地网页查看或修改HTT ...

  4. 前端代理----whistle

    场景一:如何将本地的请求代理到服务器上(如果接口没有校验登陆的情况) 最简单的方法:在项目文件中找到webpack开发环境的配置文件,配置devServer对象 devServer: { conten ...

  5. web调试代理工具Whistle

    由于最近在学习微信小程序开发,项目中用到了https代理请求,所以用到了基于Node实现的跨平台web调试代理工具Whistle,在此做一记录. 完成https代理请求总共需要5个步骤. 一.安装No ...

  6. 实用抓包工具:whistle

    无论是前端开发还是客户端,实际开发过程中,抓包都经常被用到.工欲善其事必先利其器,一款好用的抓包工具也是必须的. 说到抓包,Windows系统上不少人都用过Fiddler,Mac或Linux上用Cha ...

  7. 使用 whistle 替代本地 nginx/webpack 服务

    加入鹅厂之后,我发现团队都在用一款叫做 Whistle 的工具,起初我以为这只是一款类似 Fiddler/Charles 的普通货色.然鹅,发现下面这两种用法之后,我把自己的膝盖摘下来献给了制作这款工 ...

  8. whistle

    whistle介绍 whistle是基于Node的跨平台web调试代理工具, 主要查看, 修改HTTP, HTTPS, Websocket的请求,响应, 也可以作为HTTP代理服务器使用 (文档)[h ...

  9. 移动端调试神器 whistle

    移动端h5页面嵌入的方式多种多样,普通的chrome真机调试功能有时就不能满足要求了. whistle通过设置wifi服务器代理的方式,可以抓包调试所有移动端请求的页面. whistle的github ...

  10. whistle工具全程入门

    接触过前后端开发的同学应该都了解网络请求代理工具fiddler(mac下面常用的是Charles),可以用来拦截分析请求.包装请求.本地调试和移动端代理开发调试等.多多少少,fiddler和Charl ...

随机推荐

  1. 本地锁 & 分布式锁

    引子: 解决缓存击穿问题 synchronized (this){代码块} public synchronized Map<String,List<Catelog2Vo>> g ...

  2. input textarea 禁止输入 非数字,特别是中文字符,光标位置保持不变 - vue2

    input textarea 禁止输入 非数字,特别是中文字符,光标位置保持不变 思路:禁止输入 主要是用 keydown事件限制 不让输入即可,主要是输入中文的时候,之前没弄过. 禁止中文输入思路 ...

  3. docker 资料整理

    docker 资料整理 基础概念 docker deamon 守护系统:简单理解就是docker的软件系统,管控这容器的开关. docker容器:从镜像启动到内存中形成动态运行,从编程角度,如果镜像是 ...

  4. springMVC+JDBC:分页示例

    文章来源:http://liuzidong.iteye.com/blog/1067492 一 环境:XP3+Oracle10g+MyEclipse6+(Tomcat)+JDK1.5 二 工程相关图片: ...

  5. 瑞云科技荣获全国电子信息行业专精特新“最具创新价值 TOP20”!

    "专精特新",从概念提出到写入政府工作报告走过了十年.这十年来我国促进中小企业发展力度之大.出台政策之密集.含金量之高前所未有,足见走专精特新发展之路深入人心."专精特新 ...

  6. 记录--ECharts — 饼图相关功能点(内环、外环、环形间隔、环形文字、轮播动画)

    这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 记录一下在公司遇到的一些功能,以及相关实现 以上的内容我花了一周时间去实现的,自己也觉得时间很长,但主要因为很少使用ECharts,导致使 ...

  7. hdfs disk balancer 磁盘均衡器

    目录 1.背景 2.hdfs balancer和 hdfs disk balancer有何不同? 3.操作 3.1 生成计划 3.2 执行计划 3.3 查询计划 3.4 取消计划 4.和disk ba ...

  8. Loto实践干货(3) 测量CAN总线通讯数据

    Loto实践干货(3) 测量CAN总线通讯数据 最近在做运动控制卡的项目,调试样机的过程中,需要验证CAN总线通讯功能的正确性.以前只限于理论上认识CAN总线,使用的CANbus的通讯卡也是有上位机例 ...

  9. html 本地预览图片 图片上绘制矩形框

    效果如图 完整html代码如下 <!DOCTYPE html> <html> <head> <meta charset="UTF-8" / ...

  10. PostgreSQL与Java JDBC数据类型对照 源码

    文件:postgresql-42.2.12.jar 类名:org.postgresql.jdbc.TypeInfoCache // basic pg types info: // 0 - type n ...