一站式页面调试、抓包工具。远程调试任何手机浏览器页面,任何手机移动端 webview (如:微信, HybirdApp 等) HTTP/HTTPS
项目地址: https://github.com/wuchangming/spy-debugger
效果图:
1 、页面调试+抓包
2 、操作简单
3 、支持 HTTPS。
4 、spy-debugger
内部集成了weinre
、node-mitmproxy
、AnyProxy
。
5 、自动忽略原生 App 发起的 https 请求,只拦截 webview 发起的 https 请求。对使用了 SSL pinning 技术的原生 App 不造成任何影响。
6 、可以配合其它代理工具一起使用(默认使用 AnyProxy) [(设置外部代理)](#设置外部代理默认使用 anyproxy)
第一步:手机和 PC 保持在同一网络下(比如同时连到一个 Wi-Fi 下)
第二步:命令行输入spy-debugger
,按命令行提示用浏览器打开相应地址。
第三步:设置手机的 HTTP 代理,代理 IP 地址设置为 PC 的 IP 地址,端口为spy-debugger
的启动端口(默认端口: 9888)。
第四步:手机安装证书。注:手机必须先设置完代理后再通过(非微信)手机浏览器访问http://spydebugger.com/cert
(地址二维码)
安装证书(手机首次调试需要安装证书,已安装了证书的手机无需重复安装)。
第五步:用手机浏览器访问你要调试的页面即可。
(默认端口: 9888)
spy-debugger -p 8888
spy-debugger -e http://127.0.0.1:8888
spy-debugger 内置 AnyProxy 提供抓包功能,但是也可通过设置外部代理和其它抓包代理工具一起使用,如: Charles 、 Fiddler 。
该功能使页面内容修改更加直观方便。 (默认: false)
spy-debugger -w true
内部实现原理:在需要调试的页面内注入代码:document.body.contentEditable=true
。暂不支持使用了 iscroll 框架的页面。
(默认: false)
spy-debugger -i true
(默认: true)
spy-debugger -b false
有些浏览器发出的 connect 请求没有正确的携带 userAgent ,这个判断有时候会出错,如UC 浏览器。这个时候需要设置为 false 。大多数情况建议启用默认配置: true ,由于目前大量 App 应用自身(非 WebView )发出的请求会使用到 SSL pinning 技术,自定义的证书将不能通过 app 的证书校验。
(默认: false)
spy-debugger -c true
spy-debugger
原理是集成了weinre
,简化了weinre
需要给每个调试的页面添加 js 代码。spy-debugger
原理是拦截所有 html 页面请求注入weinre
所需要的 js 代码。让页面调试更加方便。
1
jsser 2016-11-25 15:15:08 +08:00
赞~
|
2
397738481 2016-11-25 15:15:52 +08:00
6666666666666
|
3
wuchangming89 OP |
4
Roycom 2016-11-25 15:59:15 +08:00
mark 一下
|
5
SourceMan 2016-11-25 16:10:43 +08:00
mac 下的安装指令把 sudo 去掉吧, npm 可以不需要 sudo 的,这样避免的权限错乱
如果有用户需要 sudo ,让他们自己看错误提示再加 |
6
wuchangming89 OP @SourceMan ,安装到全局是需要的吧?
|
7
SourceMan 2016-11-25 16:17:36 +08:00
额,不知道大家的习惯,一般大家都 sudo chown -R who:admin /usr/local 了吧?
意思是文档中还是去掉(基本也没看见 -g 的组件文档写上 sudo )的,有需要的人他们自己再加 |
8
nailuoGG 2016-11-25 16:18:07 +08:00
试用后,使用起来方便了很多
|
9
wuchangming89 OP @nailuoGG 谢谢支持。
|