Wireshark、Fiddler、Charles抓包工具详细使用指南

抓包工具

1.1 常用抓包工具

常用的抓包工具有:Wireshark、Fiddler、Charles。此外,Sniffmaster作为一款全平台抓包工具,支持HTTPS、TCP和UDP协议,可在iOS/Android/Mac/Windows设备上实现无需代理、越狱或root的抓包操作。

Wireshark、Fiddler、Charles的优缺点:

①Wireshark是一种在网络层上工作的抓包工具,不仅自带大量的协议分析器,而且可以通过编写Wireshark插件来识别自定义的协议。虽然Wireshark功能强大,但是却并不能解决所有的抓包问题,其原因在于:Wireshark工作在网络层;如果计算机配置了IPSec传输层加密,则在网络层的流量都已经被加密,什么也看不到。当今大量网络接口使用HTTPS加密,Wireshark不能抓取到HTTPS流量的明文内容。

②Fiddler和Charles工作在应用层上,作为其他程序的HTTP代理服务器。它可以直接抓取并分析HTTP流量,也可以作为"中间人"抓取并分析HTTPS流量。

1.2 参考资料

https://www.cnblogs.com/kristin/p/8445141.html

https://blog.csdn.net/sb___itfk/article/details/45250771

2.1 wireshark使用

2.1.1 抓取数据包

  1. 选择抓包网口,选择抓包网口有两种方式

l 第一种,启动wireshark后,直接双击以太网,就会开始抓包。

l 第二种,启动wireshark后,点击捕获--->>选项。在弹出框中选择网卡以及配置过滤条件。

  1. 停止抓包,点击停止后,可以将捕获的数据包保存。

2.1.2 常用过滤、分析

捕获的数据包比较多,可以通过一些语法进行筛选。

  1. 根据ip地址进行筛选,语法如下ip.addr==192.168.0.121。
  1. 根据http.request过滤所有http请求
  1. 根据关键字查询

2.1.3 查看捕获的数据

2.2 Fiddler使用

2.2.1 抓取数据包

2.2.2 搜索会话

按住ctrl+F,输入关键字,点击find session,进行搜索

2.2.3 查看会话

选择一个会话,根据结果的请求/响应的不同数据类型,显示会话。

2.2.4 设置代理

  1. Tools-> Fiddler Options

选中"Allow remote computers to connect". 是允许别的机器把HTTP/HTTPS请求发送到Fiddler上来

记住这个端口号是:8888,通过ipconfig查看本机的ip,如本机ip为192.168.2.11

  1. 在手机上进行代理设置
  1. 下载Fiddler的安全证书

使用android手机的浏览器打开:http://192.168.2.11:8888, 点"FiddlerRoot certificate",然后安装证书。

安装完成后,就可以在fiddler上看到手机的HTTP请求

2.2.5 抓取HTTPS数据包

l Fiddler抓取HTTPS数据包过程原理:

l fiddler接到客户端的https请求,fiddler将请求转发给服务器

l 服务器生成公钥证书,返回给fiddler;fiddler拦截下真的公钥证书,并生成伪造的公钥证书给客户端;

l 客户端使用伪造的公钥证书加密共享密钥发送给fiddler,fiddler使用伪造的私钥解密获取共享密钥

l fiddler将解密后的共享密钥,使用真正的公钥加密发送给服务器端,服务器使用共享密钥与fiddler通信

l fiddler使用共享密钥与客户端通信

  1. 设置抓取HTTPS,PC机安装根证书:

Tools->options->HTTPS->capture https connects->decrypt https traffic->ignore server certificate errors(unsafe)->actions->trust root certificate->确定->OK

  1. 安装根证书后,可以点击Actions->open windows certificate manager查看安装到系统的根证书

对于需要无需代理的HTTPS抓包,Sniffmaster提供了暴力抓包模式,直接解密HTTPS流量,支持指定APP过滤和双向验证爆破。

相关推荐
阿宇爱吃鱼2 小时前
uniapp input输入框,限制金额输入格式
前端·javascript·uni-app
aaa最北边2 小时前
进程间通信-1.管道通信
android·java·服务器
Dreamy smile2 小时前
JavaScript 实现 HTTPS SSE 连接
开发语言·javascript·https
一只程序熊2 小时前
uniapp x 新手入门指南
uni-app
苏苏哇哈哈2 小时前
微信小程序实现仿腾讯视频小程序首页圆角扩散轮播组件
微信小程序·小程序·轮播图
灰灰勇闯IT3 小时前
【Flutter for OpenHarmony--Dart 入门日记】第3篇:基础数据类型全解析——String、数字与布尔值
android·java·开发语言
2501_944521593 小时前
Flutter for OpenHarmony 微动漫App实战:底部导航实现
android·开发语言·前端·javascript·redis·flutter·ecmascript
code袁3 小时前
基于微信小程序的宿舍维修小程序的设计与实现
微信小程序·小程序·毕业设计·springboot·notepad++·宿舍维修小程序
说私域3 小时前
AI智能客服S2B2C商城小程序在客户服务场景中的应用与价值——以顾客反馈处理为例
人工智能·小程序·流量运营·私域运营