1,什么是Fiddler

Fiddler是一个http协议调试代理工具,它能够记录客户端和服务器之间的所有 HTTP请求,可以针对特定的HTTP请求,分析请求数据、设置断点、调试web应用、修改请求的数据,甚至可以修改服务器返回的数据,功能非常强大,是web调试的利器。我这里找不到包就是因为代理的问题。

2,Fiddler工作原理

Fiddler是以代理web服务器的形式工作的,它使用代理地址:127.0.0.1,端口:8888. 当Fiddler启动后将自己变成一个代理服务器,这个代理服务器默认监听127.0.0.1:8888.然后打开IE的时候,IE浏览器会以127.0.0.1:8。 退出的时候它会自动注销代理,这样就不会影响别的程序。不过如果Fiddler非正常退出,这时候因为Fiddler没有自动注销,会造成网页无法访问。那他是怎样的工作原理呢。

首先fiddler截获客户端浏览器发送给服务器的https请求, 此时还未建立握手。

第一步, fiddler向服务器发送请求进行握手, 获取到服务器的CA证书, 用根证书公钥进行解密, 验证服务器数据签名, 获取到服务器CA证书公钥。

第二步, fiddler伪造自己的CA证书, 冒充服务器证书传递给客户端浏览器, 客户端浏览器做跟fiddler一样的事。

第三步, 客户端浏览器生成https通信用的对称密钥, 用fiddler伪造的证书公钥加密后传递给服务器, 被fiddler截获。

第四步, fiddler将截获的密文用自己伪造证书的私钥解开, 获得https通信用的对称密钥。

第五步, fiddler将对称密钥用服务器证书公钥加密传递给服务器, 服务器用私钥解开后建立信任, 握手完成, 用对称密钥加密消息, 开始通信。

第六步, fiddler接收到服务器发送的密文, 用对称密钥解开, 获得服务器发送的明文。再次加密, 发送给客户端浏览器。

第七步, 客户端向服务器发送消息, 用对称密钥加密, 被fidller截获后, 解密获得明文。

由于fiddler一直拥有通信用对称密钥, 所以在整个https通信过程中信息对其透明。

3,fiddler安装后抓不了包的问题

一般能支持HTTP代理的任意程序的数据包都能被Fiddler嗅探到,Fiddler的运行机制其实就是本机上监听8888端口的HTTP代理。 Fiddler启动的时候默认IE的代理设为了127.0.0.1:8888,而其他浏览器是需要手动设置的,所以将浏览器的代理改为127.0.0.1:8888就可以监听数据了。

资料来源:

百度,知乎

最新文章

  1. C#事务
  2. Java连接Oracle database小结
  3. [转]使用Stopwatch类实现高精度计时
  4. ubuntu下各种压缩包的解压命令
  5. mongodb(副本集)
  6. HTTPResponse object — JSON object must be str, not 'bytes'
  7. 创建一个Table View
  8. caca393刷PTP教程
  9. 铁人系列(2)LA2218
  10. LeetCode Unique Paths (简单DP)
  11. ThinkPHP中的视图二
  12. 如果有两个list<Object>只取出两个中不重复的(还可以优化,这里计数器没做好,暂时使用第三变量)
  13. 如何直观的解释back propagation算法?
  14. PHP删除文件夹及其文件
  15. 在 ASP.NET Core 中使用 SignalR
  16. Java学习笔记23(Calendar类)
  17. 使用themeleaf页面技术时,在JavaScript代码中使用for循环报错.....
  18. Laravel 学习笔记
  19. EFCore.MySql当模型遇到int[]怎么办
  20. linux find command information more

热门文章

  1. test命令详解
  2. ASP.NET Web API 2.0 统一响应格式
  3. Day 33 Socket编程.
  4. Java的8种基本数据类型
  5. Dynamic Programming-650. 2 Keys Keyboard
  6. MySQL(慢日志记录)
  7. (5)Oracle基础--约束
  8. 基于Zookeeper实现的分布式互斥锁 - InterProcessMutex
  9. JDK,常见数据结构解读
  10. Windows下安装MySQL详细教程