使用Charles进行HTTPS抓包
背景:
在进行App测试或定位线上问题时,经常会遇到抓取HTTPS数据包的需求。一般在windows上会使用fiddler,Mac上使用Charles。对于https请求,抓到的数据因为经过了加密,只能看到乱码。
本文介绍如何使用Charles来抓取https网络报文。操作步骤已在MAC + iphone5s上亲测。
操作原理
关键的操作思想:
1. 构造一个中间人代理,它有能力完成TLS/SSL握手
2. 弄到一个根证书,并用它生成签名认证的代理服务器证书
Charles就是一个理想的中间人,它支持SSL握手,可以自动根据根证书生成一个签名的服务器证书,并且它的官网为我们提供了一个根证书。
我们要做的就是在客户端安装好这个根证书,然后让我们的操作系统信任它。对App来说,需要设法在IOS或Android上装上这个官网提供的根证书。
完成上述步骤后,App再指定Charles为它的代理服务器,这时,App请求的服务器证书就是Charles自动生成的代理服务器证书。如果Charles的根证书已被信任,这个自动生成的代理服务器证书是有效的,使用它App和Charles的TLS握手可以顺利完成。
以下是详细的操作步骤:
分步指南
第一步:配置HTTP代理,这步与抓取HTTP请求是一样的:
![](http://upload-images.jianshu.io/upload_images/4722219-e03ec3ed7adc50b5.png?imageMogr2/auto-orient/strip|imageView2/2/w/666/format/webp)
选择在8888端口上监听,然后确定。够选了SOCKS proxy,还能截获到浏览器的http访问请求。
![](http://upload-images.jianshu.io/upload_images/4722219-63ff7695c115323e.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp)
第二步:配置SSL代理:
首先在charles的 Proxy选项选择SSL Proxy Settings
![](http://upload-images.jianshu.io/upload_images/4722219-7bc9f0010119b7dd.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp)
然后在弹出的对话框中点击add,添加需要监视的域名。域名支持 *号通配符,如:抓取所有的https请求,可以填写 *:443
如果想要抓取qq.com的域名,可以填写 *.qq.com
第三步 为手机设置代理
在手机无线中配置手动代理,输入安装Charles的电脑的网络地址,端口填8888。
第四步 安装根证书
在手机上安装Charles的根证书:
以IOS为例,在Safri上打开Charles的根证书下载网址: chls.pro/ssl 。
顺利的话会出现这样的画面,继续点安装,一路点确定。然后去设置里的描述文件管理如果看到有绿色的勾勾就说明安装成功了。
接下来,在设置->通用->关于本机->证书信任设置 (这一步很重要) 刚刚安装的证书的开关打开信任就可以抓取加密包了。
![](http://upload-images.jianshu.io/upload_images/4722219-9fb5b9623d4699f7.png?imageMogr2/auto-orient/strip|imageView2/2/w/656/format/webp)
如果不能下载,检查手机是否正确设置了代理,Charles是否已经打开并配置正确。
电脑端的根证书安装
以MAC为例,直接在Charles的Help菜单中安装;安装完成后去系统的钥匙串访问中信任它。
完成后:试试看抓一下QQ空间的数据,将..qq.com 和*.qq.com 添加到SSL Proxy的Setting中后,配置好手机代理,打开手机QQ空间App
可以看到抓取到的报文如下:
![](http://upload-images.jianshu.io/upload_images/4722219-a9e33ad9f6c602e9.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp)
几点说明:
- 本文的操作指南是在MAC+iphone5s+Charles上实践的。文中开头已经讲述了HTTPS使用中间人代理抓包的简单原理和核心操作思想,其他环境下可以类比。
- 有些人认为https可以完美防止中间人攻击,无法抓到https的明文包...... 其实是不对的,TLS的设计只能说是从技术上最大限度地保护网络报文的安全,它无法防止用户自己作死。
- 网络安全和用户的安全意识是强相关的,技术的防范能力总是有限的。在实际生活中养成良好的上网习惯,千万不能随意信任不明来源的证书,轻视浏览器、操作系统或其他App给我们发出的安全警告。
作者:一只怪味鱼
链接:https://www.jianshu.com/p/7a88617ce80b
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关文章
- IP也可以申请SSL证书开启https?其实已经有许多靠谱又便宜的国产品牌支持
- https和http有哪些区别「建议收藏」
- 抓 https 加密数据,偷偷摸摸爽得很!
- RestTemplate自定义异常白名单,连接https
- LNMP部署typecho,开启SSL、强制开启https
- 【计算机网络】HTTP 与 HTTPS ( HTTPS 简介 | HTTP 通信过程 )
- 【错误记录】git clone 报错 ( fatal: unable to access ‘https...‘:gnutls_handshake() failed: Error in the pu )
- dotnet core 不自动从 https 到 http 的 302 重定向
- JAVA利用HttpClient进行HTTPS接口调用详解编程语言
- 美国政府所有网站开始使用HTTPS加密
- 哈萨克斯坦对所有 HTTPS 流量发动中间人攻击
- 使用Redis实现安全的HTTPS跳转(redis跳转https)
- 如何使用php判断服务器是否是HTTPS连接