详解抓包原理以及抓包工具whistle的用法

news2025/7/9 6:41:09

什么是抓包?

  • 分析网络问题
  • 业务分析
  • 分析网络信息流通量
  • 网络大数据金融风险控制
  • 探测企图入侵网络的攻击
  • 探测由内部和外部的用户滥用网络资源
  • 探测网络入侵后的影响
  • 监测链接互联网宽频流量
  • 监测网络使用流量(包括内部用户,外部用户和系统)
  • 监测互联网和用户电脑的安全状态
  • 渗透与欺骗


数据在网络上是以很小的帧的单位传输的,帧通过特定的称为网络驱动程序的程序进行成型,然后通过网卡发送到网线上,通过网线到达目的机器,在目的机器的一端执行相反的过程。接收端机器的以太网捕获到这些帧,并告诉操作系统帧已到达,然后对其进行存储。在这个传输和接收的过程,就可以使用抓包工具(Sniffers)进行抓包,作为前端开发者,通常是抓取应用层HTTP/HTTPS的包

HTTP/HTTPS 抓包原理

HTTP/HTTPS是应用层使用的通信协议,常见的应用层体系结构是客户端-服务器体系。
对运行在不同端系统上的客户端程序和服务端程序是如何互相通信的么?

实际上,在操作系统上的术语中,进行通信的实际上是进程而不是程序,一个进程可以被认为是运行在端系统中的一个程序。
在web应用程序中,一个客户浏览器进程与一台服务器进程进行会话交换报文。
浏览器进程需要知道接收进程的主机地址,以及定义在目的主机中的接收进程的标识符,也就是目的端口。多数应用程序由通信进程对组成,每对中的两个进程互相发送报文。

进程通过一个称为套接字的软件接口向网络发送报文和从网络接收报文。进程可以类比一座房子,而它的套接字可以是它的门,套接字是应用层与运输层之间的端口

 知道了两个进程的通信流程,我们要怎么抓包呢?举一个生活中的例子,小明暗恋小雯,于是他写了一封情书,但他有点害羞,找了小雯的好朋友小花帮忙传递情书。这个时候,小花可以负责小雯与小明之间的情书传递,作为中间人,她可以偷偷查看他们的情书内容。思路就是设置一个中间人进程负责抓包话都先与中间人进程通信,再进行转发。

 

 HTTP 抓包原理

在http 标准中,没有对通信端身份验证的标准。对于服务器来说它接收的HTTP请求报文只要格式符合规范,就发送响应报文对于客户端来说也是如此,它无法校验服务器的身份,比如它连接的 http://www.jecyu.com 的主机,但由于中间节点的存在,最终连接的可能是http://wwwjerry.com的主机。因此,对于HTTP抓包,无需做过多的处理,只需要让中间人负责转发客户端和服务端的数据包

HTTPS 抓包原理

HTTP是明文传输,容易受到中间人攻击,不安HTTPS语义仍然是HTTP,只不过是在HTTP协议栈中http 与tcp 之间插入安全层SSL/TSL。安全层采用对称加密的方式加密传输数据和非对称加密的方式来传输对称密钥,解决http 数据没有加密、无法验证身份、数据容易纂改三个核心问题

HTTP+加密+认证+完整性保护=HTTPS

其中验证身份问题是通过验证服务器的证书来实现的,证书是第三方组织(CA证书签发机构) 使用数字签名技术管理的,包括创建证书、存储证书、更新证书、撤销证书

 浏览器连接至一个HTTPS网站,服务器发送的不仅仅只是服务器实体证书,而是一个证书链,但不包含根证书,根证书会被内嵌在Windows,Linux,macOS,Android,ioS这些操作系统里

 其中校验证书分为两步,证书的签发者校验和服务器实体证书校
1、证书链校验:
1.1浏览器从服务器实体证书的上一级证书(比如B证书)获取公钥,用来校验服务器实体证书的签名(签名是通过CA机构的私钥签名的),校验成功则继续,否则证书校验失败。

1.2浏览器从B证书的上一级证书(比如C证书)获取公,用来校验B证书的签名,
2、校验成功则继续,否则证书校验失败。
1.3浏览器选代校验每张证书的签名,最后会找到自签名的根证书(签发者和使用者是同一个人),由于浏览器已经集成了根证书可以充分信任根证书的公钥,完成最后的签名。服务器实体证书校验:访问的域名信息是否与证书一致、日期证书扩展校验等。
了解完证书校验后,我们来看看具体的https通信流程:首先是tcp的三次握手建立连接接着是非对称加密的握手过程
client 发送随机数random1+支持的加密算法集合server收到信息,返回选择的一个加密算法+证书(包含S_公+random2
client 验证证书有效性,并用randoml+random2生成 pre-master-secure,通过服务端公钥加密发送给 serverserver收到pre-master-secure,根据约定的算法使用S_私钥对pre-master-secure解密这个时候,客户端和服务端都拥有random1、random2、pre-master以及约定的对称密钥生成方法,可以生成相同的master-secure(对称加密的密钥) 进行加解密了。最后,就可以使用master-secure进行真正的数据对称加密传输

中间人想要抓包,需在HTTPS 加密通信之前:

1、截取客户端发送的包含证书的报文,伪装成服务端,把自己的证书发给客户端,然后拿到客户端返回的包含对称加密通信密钥的报文,生成中间人与客户端对称加密的密钥

2、同样伪装成客户端,以服务端自己的非对称公钥加密[客户端返回的包含对称加密通信密钥的报文] 发给服务端,获得服务端生成的对称加密密钥。

3、这样一来,加密通信建立完成,而中间人拿到了通信的数据密钥,可以查看、修改HTTPS的通信报文。

4、这里客户端与中间人通信、中间人与服务端通信,都是正常建立了HTTPS加密连接的

其中很重要的一步是浏览器的根证书校验,CA机构不可能随便给个中间人签发不属于它的域名证书,也就不在客户端的操作系统上了,因此只能把中间人的根证书,导入到客户端的操作系统了,以此完成建立加密通信时对中间人证书的验证

抓包工具whistle


whistle 是什么

其主要特点:

完全跨平台:支持 Mac、Windows 等桌面系统,且支持服务端等命令行系统
功能强大:
支持作为HTTP、HTTPS、SOCKS代理及反向代理

支持抓包及修改HTTP、HTTPS、HTTP2、WebSocket、TCP 请求

支持重放及构造HTTP、HTTPS、HTTP2、WebSocket、TCP请求

支持设置上游代理、PAC脚本、Hosts、延迟(限速)请求响应等

支持查看远页面的console日志及DOM节点
支持用Node开发插件扩展功能,也可以作为独立npm 包引用操作简单
直接通过浏览器查看抓包、修改请求
所有修改操作都可以通过配置方式实现(类似系统Hosts),并支持分组管理

项目可以自带代理规则并一键配置到本地Whistle代理,也可以通过定制插件简化操作

Whistle是基于Node实现的跨平台抓包免费调试工具,

其主要特点:完全跨平台:支持 Mac、Windows 等桌面系统,且支持服务端等命令行系统
功能强大:
支持作为HTTP、HTTPS、SOCKS代理及反向代理

支持抓包及修改HTTP、HTTPS、HTTP2、WebSocket、TCP 请求

支持重放及构造HTTP、HTTPS、HTTP2、WebSocket、TCP请求

支持设置上游代理、PAC脚本、Hosts、延迟(限速)请求响应等

支持查看远页面的console日志及DOM节点
支持用Node开发插件扩展功能,也可以作为独立npm 包引用操作简单
直接通过浏览器查看抓包、修改请求
所有修改操作都可以通过配置方式实现(类似系统Hosts),并支持分组管理

项目可以自带代理规则并一键配置到本地Whistle代理,也可以通过定制插件简化操作

如何快速使用 whistle

1.win+R然后输入cmd进入终端界面,然后执行npm install -g whistle命令安装whistle

2.w2 start启动whistle

whistle 可以做的事情 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/396388.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CI流水线的理解

一、概念 单元测试:针对软件的基本单元(如:类、函数)所做的测试。 集成测试:将软件代码单元集成起来后,以组件、模块和子系统为单位进行的测试,主要测试接口间的交互关系。也称组件测试&#xf…

嵌入式Linux从入门到精通之第十五节:嵌入式系统简介

嵌入式系统的层级结构如下图所示: 开发环境 这里以三星s5pv210为开发环境: 系统资源 s5pv210是三星公司推出的32位RISC微处理器,其CPU采用的是ARM Cortex-A8内核,基于ARMv7架构 丰富的片内资源,为手持设备和其它移动领域应用,提供了低价格、低功耗、高性能的微处理器解…

nodejs学习巩固笔记-nodejs基础,Node.js 高级编程(核心模块、模块加载机制)

目录Nodejs 基础大前端开发过程中的必备技能nodejs 的架构为什么是 NodejsNodejs 异步 IONodejs 事件驱动架构全局对象全局变量之 process核心模块核心模块 - path全局变量之 Buffer创建 bufferBuffer 实例方法Buffer 静态方法Buffer-split 实现核心模块之FS模块文件操作 APImd…

Chromium HTML Video 媒体播放代码梳理

经过一番探索(参见Android 10 WebView 踩坑实录),终于搞定 Chromium WebView 的代码下载和编译问题,加下来就要向 H265 8K 高清播放发起冲锋。不过在打开 Chromium 源码后,眼前一黑。这还是熟悉的 Chromium 代码吗&…

KEIL5中头文件路劲包含问题

方式1:1.Keil中添加头文件相对路劲的方法在c/c配置中添加路劲,最终是将添加的绝对路径转化为相对路径;注意:相对路径的当前位置指.uvproj文件所在位置在C/C配置中的include paths”中添加工程所用的所有头文件的路径;2…

45岁VP:1000页PPT 10节实战课程,江湖再见!

与时舒卷,与光同尘 知识星球3年已满,受兄弟的盛请于是有了这2年10节课程 10节课程1000页自写的PPT20年的经验,N个企业不同行业的切身实际案例,王者课程,分享后江湖再见,华丽转身。 第1课 百万年薪CIO成长&…

线程、进程、协程的总结详细

线程、进程、协程的总结详细1 、进程1.1 进程是什么呢?1.2 生命周期1.3 进程同步机制1.4 进程通信机制1.4.1 管道1.4.2 消息队列1.4.3 共享内存1.4.4 信号量和PV操作1.4.5 信号1.4.6 socket1.4.7 总结 Linux 内核提供的进程通信机制2、线程2.1 线程是什么呢&#xf…

王道计算机组成原理课代表 - 考研计算机 第四章 指令系统 究极精华总结笔记

本篇博客是考研期间学习王道课程 传送门 的笔记,以及一整年里对 计算机组成 知识点的理解的总结。希望对新一届的计算机考研人提供帮助!!! 关于对 “指令系统” 章节知识点总结的十分全面,涵括了《计算机组成原理》课程…

【GeoDjango框架解析】conda环境下安装psycopy2版本问题

GeoDjango框架解析 【GeoDjango框架解析】配置geodjango开发环境 【GeoDjango报错处理】conda环境下安装psycopy2版本问题 文章目录GeoDjango框架解析前言一、报错:OSError: /usr/lib/libgdal.so: undefined symbol: TIFFReadRGBATileExt, version LIBTIFF_4.0二、…

代码随想录-52-257. 二叉树的所有路径

目录前言题目1.递归和回溯2. 本题思路分析:3. 算法实现4. pop函数的算法复杂度5. 算法坑点前言 在本科毕设结束后,我开始刷卡哥的“代码随想录”,每天一节。自己的总结笔记均会放在“算法刷题-代码随想录”该专栏下。 代码随想录此题链接 题…

【数字孪生百科】每周认识一个数字孪生要素 ——柱形图(Histogram, Column Diagram)

简介柱形图(Histogram, Column Diagram),又称柱状统计图、条状图、长条图或者条形图,是一种以宽度相同的长方形的长度为变量的统计图表。一般来说,柱形图只有一个变量,比较适用于较小数据集的分析。柱形图同…

HHO:闯进耳机赛道的外行人,却给整个行业带来了光

数字化时代的耳机,应该是什么样的?如果是一位在行业浸润多年的专业人士,对这个问题给出的答案应该是:更加细腻真实的音质、更好的降噪效果、更舒适的佩戴体验……作为原阿里巴巴集团副总裁、钉钉创始人CEO,踏上创业之路…

【RuoYi-Vue-Plus】学习笔记 49 - Easy Excel(三)自定义转换器 ExcelDictConvert 源码分析

文章目录前言参考目录框架集成1、Maven2、框架集成模块 ruoyi-common-excel2.1、自定义转换器 ExcelDictConvert2.2、自定义转换器注解 ExcelDictFormat2.3、Excel 工具类 ExcelUtil3、测试方法3.1、用户导入3.2、用户导出3.3、测试调用流程说明执行流程分析1、用户导出流程分析…

Dynamics 365如何动态设置表单上字段标签label的tooltips提示语。

客户要求定制一下光标放在字段标签上的tooltips提示语言。如果是静态的,可以去后台实体字段编辑页面直接修改字段的描述信息即可。 但是这里要求改成动态的显示形式:“ABC”当前用户当前时间的yyyyMMddHHmm格式的字符串。 表单onload中调用的JS函数Rese…

第十四届蓝桥杯第三期模拟赛B组C/C++原题与详解

文章目录 一、填空题 1、1 找最小全字母十六进制数 1、1、1 题目描述 1、1、2 题解关键思路与解答 1、2 给列命名 1、2、1 题目描述 1、2、2 题解关键思路与解答 1、3 日期相等 1、3、1 题目描述 1、3、2 题解关键思路与解答 1、4 乘积方案数 1、4、1 题目描述 1、4、2 题解关…

centos7 oracle19c安装 ORA-01012: not logged on

总共分三步 1.下载安装包:里面有一份详细的安装教程 链接:https://pan.baidu.com/s/1Of2a72pNLZ-DDIWKrTQfLw?pwd8NAx 提取码:8NAx 2.安装后,执行初始化:时间较长 /etc/init.d/oracledb_ORCLCDB-19c configure 3.配置环境变量,不配置环境变量,sq…

Java介绍,什么是Java?

同学们好! 第一次接触软件行业吗?没有关系,看完这篇介绍让你了解到底什么是Java?并对它强大的功能所吸引。希望你能耐心的看完,更了解软件行业,了解Java开发。 1、是不是不知道什么是Java? 官…

港科夜闻|沈向洋教授获委任为香港科大校董会主席

关注并星标每周阅读港科夜闻建立新视野 开启新思维1、沈向洋教授获委任为香港科大校董会主席。该委任由2023年3月6日起生效,为期3年。沈教授将接替现任校董会主席廖长城先生。而廖先生亦于今天获委任为大学最高咨询机构「顾问委员会」的新一任主席,接替成…

pandas数据分析(二)

文章目录DataFrame数据处理与分析读取Excel文件中的数据筛选符合特定条件的数据查看数据特征和统计信息按不同标准对数据排序使用分组与聚合对员工业绩进行汇总DataFrame数据处理与分析 部分数据如下 这个数据百度可以搜到,就是下面这个 读取Excel文件中的数据 …

JVM实战OutOfMemoryError异常

目录 Java堆溢出 常见原因: 虚拟机栈和本地方法栈溢出 实验1:虚拟机栈和本地方法栈测试(作为第1点测试程序) 实验2:(作为第1点测试程序) 运行时常量池和方法区溢出 运行时常量池内存溢出 …