在日常的工作中,我经常使用charles 来分析http请求,它非常的强大,可以去官网下载 https://www.charlesproxy.com/
需要注意charles是一款收费软件,但是你可以免费使用,只不过需要忍受启动加载慢的过程。
data:image/s3,"s3://crabby-images/27721/277211b38f6df04a56b80f4874ac269e7a9387ed" alt="使用Charles 抓包"
设置为系统代理
1.安装完毕后启动,然后选择Proxy-macOS Proxy
data:image/s3,"s3://crabby-images/1b731/1b731546992cdf3b13e04e4e77bbbcd06a74b1b7" alt="使用Charles 抓包"
PC抓包
就可以把系统的http请求代理到charles了,如果你需要分析https的数据包,点击help- SSL proxying- INSTALL charles root certificate 安装
data:image/s3,"s3://crabby-images/26766/26766f3103251f7ad3a6fd2c9a47965703f133a7" alt="使用Charles 抓包"
data:image/s3,"s3://crabby-images/cbea3/cbea3274e88a9f472fc95da20d7c38fc2a2a01d8" alt="使用Charles 抓包"
默认情况下选项卡是在Structur上,他会安装网站的域名进行分组
data:image/s3,"s3://crabby-images/4519b/4519b758b0c3aa9adf8c18b85007a77577b88c0e" alt="使用Charles 抓包"
你可以切换到Sequence上查看所有的未分组请求的状态、请求方法、主机地址,请求URL路径等等
data:image/s3,"s3://crabby-images/48b83/48b8392b8d988acc18274e474a9bcc56b1a5c0fd" alt="使用Charles 抓包"
如果你只希望抓取某个域名的数据包,可以选择Porxy-Recording Setting,然后切换到Include
data:image/s3,"s3://crabby-images/35ec5/35ec5d6b8132399b88fea45e0370c9322e96951b" alt="使用Charles 抓包"
然后输入协议 hosts 端口即可
data:image/s3,"s3://crabby-images/6fbba/6fbba6317c4b43f27a47f51204c5944c7c54f185" alt="使用Charles 抓包"
当你点击某一个请求包的时候,下面会显示你的请求信息和响应信息以及http的body体内容,可以通过过滤器过滤你的域名方法等等。
data:image/s3,"s3://crabby-images/09800/09800233171e8182870bf6ab000b9574cf4b9ff8" alt="使用Charles 抓包"
移动端抓包
选择Proxy- Proxy Settings,填写端口,假设本机地址是10.0.1.15,那么就去移动端设置代理
data:image/s3,"s3://crabby-images/e8345/e8345b0381589ac2457c272d8b359d960e0f2b50" alt="使用Charles 抓包"
然后移动端,以iphone为例,点击设置 无线网 找到你链接的wifi,注意wifi必须与pc同网段,然后选择http代理 手动,填写服务器和端口
data:image/s3,"s3://crabby-images/f9866/f98667a40f1e1030fa7f24509fb02c25b3d05e92" alt="使用Charles 抓包"
此时pc端会弹出一个对话框
data:image/s3,"s3://crabby-images/f92c6/f92c67e6d3986e28d39bbe4ebf990477e5649eb5" alt="使用Charles 抓包"
然后就可以看到了移动端的请求了
data:image/s3,"s3://crabby-images/88a6c/88a6c185d5259552488a282f36104d8b1e8cd0e4" alt="使用Charles 抓包"
查看请求文件的实体内容
data:image/s3,"s3://crabby-images/e103a/e103abfb308bf348b0892191bb16fd75cbc8ffba" alt="使用Charles 抓包"
注意:如果没有发现数据包,很可能是设置了Recording Setting 只运行某个域名的包通过了,通常链接后注意看下方状态是否有类似GET POST请求URL 一闪而过,如果有说明是请求了但是不匹配你的url所以忽略了。另外,移动端抓取SSL的包,需要安装证书,具体方法是点击help- SSL proxying- INSTALL charles root on a Mobile certificate Device or Remote Browser 安装
data:image/s3,"s3://crabby-images/a4d67/a4d677cb44dc01a8a3f5796d93d77c4c7dae2b39" alt="使用Charles 抓包"
然后会弹出个对话框
data:image/s3,"s3://crabby-images/5ad85/5ad859f297c35dfbe79d0cafa71f5d6d8aabc47d" alt="使用Charles 抓包"
你在移动端打开浏览器输入chls.pro/ssl 去下载文件安装,然后输入密码确认后完成安装。
data:image/s3,"s3://crabby-images/320e6/320e6473e8b0bb5ec9f2b0c0742b5187eb031c1e" alt="使用Charles 抓包"
安装完后进入系统-通用-关于本机 证书信任设置,针对根证书启动完全信任 开启charles Porxy CA
data:image/s3,"s3://crabby-images/40029/400297a6ef0572b37735a834a7a6d505aca4c93f" alt="使用Charles 抓包"