Wireshark基本介绍和学习TCP三次握手


Posted in Javascript onAugust 15, 2016

这篇文章介绍另一个好用的抓包工具wireshark, 用来获取网络数据封包,包括http,TCP,UDP,等网络协议包。

记得大学的时候就学习过TCP的三次握手协议,那时候只是知道,虽然在书上看过很多TCP和UDP的资料,但是从来没有真正见过这些数据包, 老是感觉在云上飘一样,学得不踏实。有了wireshark就能截获这些网络数据包,可以清晰的看到数据包中的每一个字段。更能加深我们对网络协议的理解。

对我而言, wireshark 是学习网络协议最好的工具。

阅读目录

  1. wireshark介绍
  2. wireshark不能做的
  3. wireshark VS Fiddler
  4. 同类的其他工具
  5. 什么人会用到wireshark
  6. wireshark 开始抓包
  7. wireshark 窗口介绍
  8. wireshark 显示过滤
  9. 保存过滤
  10. 过滤表达式
  11. 封包列表(Packet List Pane)
  12. 封包详细信息 (Packet Details Pane)
  13. wireshark与对应的OSI七层模型
  14. TCP包的具体内容
  15. 实例分析TCP三次握手过程

wireshark介绍

wireshark的官方下载网站: http://www.wireshark.org/

wireshark是非常流行的网络封包分析软件,功能十分强大。可以截取各种网络封包,显示网络封包的详细信息。

wireshark是开源软件,可以放心使用。 可以运行在Windows和Mac OS上。

使用wireshark的人必须了解网络协议,否则就看不懂wireshark了。

Wireshark不能做的

为了安全考虑,wireshark只能查看封包,而不能修改封包的内容,或者发送封包。

Wireshark VS Fiddler

Fiddler是在windows上运行的程序,专门用来捕获HTTP,HTTPS的。

wireshark能获取HTTP,也能获取HTTPS,但是不能解密HTTPS,所以wireshark看不懂HTTPS中的内容

总结,如果是处理HTTP,HTTPS 还是用Fiddler,  其他协议比如TCP,UDP 就用wireshark

同类的其他工具

微软的network monitor

sniffer

什么人会用到wireshark

1. 网络管理员会使用wireshark来检查网络问题

2. 软件测试工程师使用wireshark抓包,来分析自己测试的软件

3. 从事socket编程的工程师会用wireshark来调试

4. 听说,华为,中兴的大部分工程师都会用到wireshark。

总之跟网络相关的东西,都可能会用到wireshark.

wireshark 开始抓包

开始界面

Wireshark基本介绍和学习TCP三次握手

wireshark是捕获机器上的某一块网卡的网络包,当你的机器上有多块网卡的时候,你需要选择一个网卡。

点击Caputre->Interfaces.. 出现下面对话框,选择正确的网卡。然后点击"Start"按钮, 开始抓包

Wireshark基本介绍和学习TCP三次握手

Wireshark 窗口介绍

Wireshark基本介绍和学习TCP三次握手

WireShark 主要分为这几个界面

1. Display Filter(显示过滤器),  用于过滤

2. Packet List Pane(封包列表), 显示捕获到的封包, 有源地址和目标地址,端口号。 颜色不同,代表

3. Packet Details Pane(封包详细信息), 显示封包中的字段

4. Dissector Pane(16进制数据)

5. Miscellanous(地址栏,杂项)

Wireshark 显示过滤

Wireshark基本介绍和学习TCP三次握手

使用过滤是非常重要的, 初学者使用wireshark时,将会得到大量的冗余信息,在几千甚至几万条记录中,以至于很难找到自己需要的部分。搞得晕头转向。

过滤器会帮助我们在大量的数据中迅速找到我们需要的信息。

过滤器有两种,

一种是显示过滤器,就是主界面上那个,用来在捕获的记录中找到所需要的记录

一种是捕获过滤器,用来过滤捕获的封包,以免捕获太多的记录。 在Capture -> Capture Filters 中设置

保存过滤

在Filter栏上,填好Filter的表达式后,点击Save按钮, 取个名字。比如"Filter 102",

Wireshark基本介绍和学习TCP三次握手

Filter栏上就多了个"Filter 102" 的按钮。

Wireshark基本介绍和学习TCP三次握手

过滤表达式的规则

表达式规则

 1. 协议过滤

比如TCP,只显示TCP协议。

2. IP 过滤

比如 ip.src ==192.168.1.102 显示源地址为192.168.1.102,

ip.dst==192.168.1.102, 目标地址为192.168.1.102

3. 端口过滤

tcp.port ==80,  端口为80的

tcp.srcport == 80,  只显示TCP协议的愿端口为80的。

4. Http模式过滤

http.request.method=="GET",   只显示HTTP GET方法的。

5. 逻辑运算符为 AND/ OR

常用的过滤表达式

过滤表达式 用途
http 只查看HTTP协议的记录
ip.src ==192.168.1.102 or ip.dst==192.168.1.102  源地址或者目标地址是192.168.1.102
   
   

封包列表(Packet List Pane)

封包列表的面板中显示,编号,时间戳,源地址,目标地址,协议,长度,以及封包信息。 你可以看到不同的协议用了不同的颜色显示。

你也可以修改这些显示颜色的规则,  View ->Coloring Rules.

Wireshark基本介绍和学习TCP三次握手

封包详细信息 (Packet Details Pane)

这个面板是我们最重要的,用来查看协议中的每一个字段。

各行信息分别为

Frame:   物理层的数据帧概况

Ethernet II: 数据链路层以太网帧头部信息

Internet Protocol Version 4: 互联网层IP包头部信息

Transmission Control Protocol:  传输层T的数据段头部信息,此处是TCP

Hypertext Transfer Protocol:  应用层的信息,此处是HTTP协议

wireshark与对应的OSI七层模型

Wireshark基本介绍和学习TCP三次握手

TCP包的具体内容

 从下图可以看到wireshark捕获到的TCP包中的每个字段。

 Wireshark基本介绍和学习TCP三次握手

实例分析TCP三次握手过程

看到这, 基本上对wireshak有了初步了解, 现在我们看一个TCP三次握手的实例

 三次握手过程为

Wireshark基本介绍和学习TCP三次握手

这图我都看过很多遍了, 这次我们用wireshark实际分析下三次握手的过程。

打开wireshark, 打开浏览器输入 http://www.cnblogs.com/tankxiao

在wireshark中输入http过滤, 然后选中GET /tankxiao HTTP/1.1的那条记录,右键然后点击"Follow TCP Stream",

这样做的目的是为了得到与浏览器打开网站相关的数据包,将得到如下图

Wireshark基本介绍和学习TCP三次握手

图中可以看到wireshark截获到了三次握手的三个数据包。第四个包才是HTTP的, 这说明HTTP的确是使用TCP建立连接的。

第一次握手数据包

客户端发送一个TCP,标志位为SYN,序列号为0, 代表客户端请求建立连接。 如下图

Wireshark基本介绍和学习TCP三次握手

第二次握手的数据包

服务器发回确认包, 标志位为 SYN,ACK. 将确认序号(Acknowledgement Number)设置为客户的I S N加1以.即0+1=1, 如下图

Wireshark基本介绍和学习TCP三次握手

第三次握手的数据包

客户端再次发送确认包(ACK) SYN标志位为0,ACK标志位为1.并且把服务器发来ACK的序号字段+1,放在确定字段中发送给对方.并且在数据段放写ISN的+1, 如下图:

Wireshark基本介绍和学习TCP三次握手

 就这样通过了TCP三次握手,建立了连接。

以上就是Wireshark基本介绍和学习TCP三次握手,后续继续整理相关知识,谢谢大家对本站的支持!

Javascript 相关文章推荐
HTML TO JavaScript 转换
Jun 26 Javascript
为jquery.ui.dialog 增加“自动记住关闭时的位置”的功能
Nov 24 Javascript
js将控件隐藏及display属性的使用介绍
Dec 30 Javascript
浅析jQuery移动开发中内联按钮和分组按钮的编写
Dec 04 Javascript
Bootstrap 最常用的JS插件系列总结(图片轮播、标签切换等)
Jul 14 Javascript
Centos6.8下Node.js安装教程
May 12 Javascript
基于VuePress 轻量级静态网站生成器的实现方法
Apr 17 Javascript
jQuery创建及操作xml格式数据示例
May 26 jQuery
Webpack 4.x搭建react开发环境的方法步骤
Aug 15 Javascript
vue-cli 引入jQuery,Bootstrap,popper的方法
Sep 03 jQuery
JavaScript实现的开关灯泡点击切换特效示例
Jul 08 Javascript
通过js实现压缩图片上传功能
Feb 25 Javascript
JavaScript中removeChild 方法开发示例代码
Aug 15 #Javascript
jQuery解决input元素的blur事件和其他非表单元素的click事件冲突问题
Aug 15 #Javascript
Web安全测试之XSS实例讲解
Aug 15 #Javascript
js中获取jsp表单中radio类型的值简单实例
Aug 15 #Javascript
卸载安装Node.js与npm过程详解
Aug 15 #Javascript
jQuery Easyui Tabs扩展根据自定义属性打开页签
Aug 15 #Javascript
浅谈js中字符和数组一些基本算法题
Aug 15 #Javascript
You might like
基于PHP一些十分严重的缺陷详解
2013/06/03 PHP
在Laravel5.6中使用Swoole的协程数据库查询
2018/06/15 PHP
laravel接管Dingo-api和默认的错误处理方式
2019/10/25 PHP
用JS实现一个TreeMenu效果分享
2011/08/28 Javascript
js实现一个省市区三级联动选择框代码分享
2013/03/06 Javascript
JavaScript实现打地鼠小游戏
2020/04/23 Javascript
JavaScript输出所选择起始与结束日期的方法
2017/07/12 Javascript
jQuery中过滤器的基本用法示例
2017/10/11 jQuery
Vue cli 引入第三方JS和CSS的常用方法分享
2018/01/20 Javascript
Vue表单demo v-model双向绑定问题
2018/06/29 Javascript
vue使用v-for实现hover点击效果
2018/09/29 Javascript
JS实现点击按钮随机生成可拖动的不同颜色块示例
2019/01/30 Javascript
微信小程序template模板与component组件的区别和使用详解
2019/05/22 Javascript
微信小程序开发数据缓存基础知识辨析及运用实例详解
2020/11/06 Javascript
[01:03:37]Secret vs VGJ.S Supermajor小组赛C组 BO3 第二场 6.3
2018/06/04 DOTA
python使用递归解决全排列数字示例
2014/02/11 Python
Python装饰器decorator用法实例
2014/11/10 Python
Python中模拟enum枚举类型的5种方法分享
2014/11/22 Python
Python实现的自定义多线程多进程类示例
2018/03/23 Python
详解用TensorFlow实现逻辑回归算法
2018/05/02 Python
python实现画一颗树和一片森林
2018/06/25 Python
利用Python求阴影部分的面积实例代码
2018/12/05 Python
Python实现K折交叉验证法的方法步骤
2019/07/11 Python
浅析Python 引号、注释、字符串
2019/07/25 Python
Python3常见函数range()用法详解
2019/12/30 Python
Python datetime 如何处理时区信息
2020/09/02 Python
python 可视化库PyG2Plot的使用
2021/01/21 Python
使用HTML5中的contentEditable来将多行文本自动增高
2016/03/01 HTML / CSS
Java语言程序设计测试题选择题部分
2014/04/03 面试题
领导调研接待方案
2014/02/27 职场文书
小学校长竞聘演讲稿
2014/05/16 职场文书
解除劳动合同证明书
2014/09/26 职场文书
教师党的群众路线教育实践活动学习心得体会
2014/10/30 职场文书
vue项目中的支付功能实现(微信支付和支付宝支付)
2022/02/18 Vue.js
CDPR谈《巫师》新作用虚幻5原因 称不会为Epic独占
2022/04/06 其他游戏
人工智能深度学习OpenAI baselines的使用方法
2022/05/20 Python