2024年2月20日发(作者:)
第 3 章 用户界面
. 须知
现在您已经安装好了Wireshark,几乎可以马上捕捉您的一个包。紧接着的这一节我们将会介绍:
Wireshark的用户界面如何使用
如何捕捉包
如何查看包
如何过滤包
……以及其他的一些工作。
. 启动Wireshark
你可以使用Shell命令行或者资源管理器启动Wireshark.
提示
开始Wireshark时您可以指定适当的参数。参见第 节 “从命令行启动Wireshark”
注意
在后面的章节中,将会出现大量的截图,因为Wireshark运行在多个平台 ,并且支持多个GUI Toolkit2x),您的屏幕上显示的界面可能与截图不尽吻合。但在功能上不会有实质性区别。尽管有这些区别,也不会导致理解上的困难。
. 主窗口
先来看看图 “主窗口界面”,大多数打开捕捉包以后的界面都是这样子(如何捕捉/打开包文件随后提到)。
图 . 主窗口界面
和大多数图形界面程序一样,Wireshark主窗口由如下部分组成:
1. 菜单(见第 节 “主菜单”)用于开始操作。
2. 主工具栏(见第 节 “"Main"工具栏”)提供快速访问菜单中经常用到的项目的功能。
3. Fiter toolbar/过滤工具栏(见第 节 “"Filter"工具栏”)提供处理当前显示过滤得方法。(见:”浏览时进行过滤”)
4. Packet List面板(见第 节 “"Pcaket List"面板”)显示打开文件的每个包的摘要。点击面板中的单独条目,包的其他情况将会显示在另外两个面板中。
5. Packet detail面板(见第 节 “"Packet Details"面板”)显示您在Packet list面板中选择的包德更多详情。
6. Packet bytes面板(见第 节 “"Packet Byte"面板”)显示您在Packet list面板选择的包的数据,以及在Packet details面板高亮显示的字段。
7. 状态栏(见第 节 “状态栏”)显示当前程序状态以及捕捉数据的更多详情。
注意
主界面的三个面版以及各组成部分可以自定义组织方式。见第 节 “首选项”
3.3.1. 主窗口概述
Packet list和Detail 面版控制可以通过快捷键进行。表 “导航快捷键”显示了相关的快捷键列表。表 “"GO"菜单项”有关于快捷键的更多介绍
表 . 导航快捷键
快捷键 描述
Tab,Shift+Tab 在两个项目间移动,例如从一个包列表移动到下一个
Down
Up
移动到下一个包或者下一个详情
移动到上一个包或者上一个详情
Ctrl-Down,F8 移动到下一个包,即使焦点不在Packet list面版
Ctrl-UP,F7
Left
Right
Backspace
移动到前一个报,即使焦点不在Packet list面版
在Pactect Detail面版,关闭被选择的详情树状分支。如果以关闭,则返回到父分支。
在Packet Detail面版,打开被选择的树状分支.
Packet Detail面版,返回到被选择的节点的父节点
Return,Enter Packet Detail面版,固定被选择树项目。
另外,在主窗口键入任何字符都会填充到filter里面。
. 主菜单
Wireshark主菜单位于Wireshark窗口的最上方。图 “主菜单”提供了菜单的基本界面。
图 . 主菜单
主菜单包括以下几个项目:
File
包括打开、合并捕捉文件,save/保存,Print/打印,Export/导出捕捉文件的全部或部分。以及退出Wireshark项.见第 节 “"File"菜单”
Edit
包括如下项目:查找包,时间参考,标记一个多个包,设置预设参数。(剪切,拷贝,粘贴不能立即执行。)见第 节 “"Edit"菜单”
View
控制捕捉数据的显示方式,包括颜色,字体缩放,将包显示在分离的窗口,展开或收缩详情面版的地树状节点,……见第 节 “"View"菜单”
GO
包含到指定包的功能。见第 节 “"Go"菜单”
Capture
允许您开始或停止捕捉、编辑过滤器。见第 节 “"Capture"菜单”
Analyze
包含处理显示过滤,允许或禁止分析协议,配置用户指定解码和追踪TCP流等功能。见第 节 “"Analyze"菜单”
Statistics
包括的菜单项用户显示多个统计窗口,包括关于捕捉包的摘要,协议层次统计等等。见第 节 “"Statistics"菜单”
Help
包含一些辅助用户的参考内容。如访问一些基本的帮助文件,支持的协议列表,用户手册。在线访问一些网站,“关于”等等。见第 节 “"Help"菜单”
本章链接介绍菜单的一般情况,更详细的介绍会出现在后续章节。
提示
你可以直接点击访问菜单项,也可以使用热键,热键显示在菜单文字描述部分。例如:您可以使用CTR+K打开捕捉对话框。
. "File"菜单
WireSharkFile菜单包含的项目如表表 “File菜单介绍”所示
图 . File菜单
表 . File菜单介绍
菜单项 快捷键 描述
显示打开文件对话框,让您載入捕捉文件用以浏览。见第 节
Ctr+O
“打开捕捉文件对话框”
Open Recent 弹出一个子菜单显示最近打开过的文件供选择。
显示合并捕捉文件的对话框。让您选择一个文件和当前打开的文件Merg
合并。见第 节 “合并捕捉文件”
关闭当前捕捉文件,如果您未保存,系统将提示您是否保存(如果Close Ctrl+W
您预设了禁止提示保存,将不会提示)
保存当前捕捉文件,如果您没有设置默认的保存文件名,Wireshark出现提示您保存文件的对话框。详情第 节 “"save Capture
File As/保存文件为"对话框”
Save Crl+S
注意
如果您已经保存文件,该选项会是灰色不可选的。
注意
您不能保存动态捕捉的文件。您必须结束捕捉以后才能进行保存
让您将当前文件保存为另外一个文件面,将会出现一个另存为的对Save As Shift+Ctrl+S 话框(参见第 节 “"save Capture File As/保存文件为"对话框”)
允许您显示文件集合的列表。将会弹出一个对话框显示已打开文件File Set>List Files
的列表,参见第 节 “文件集合”
如果当前載入文件是文件集合的一部分,将会跳转到下一个文件。File Set>Next File
如果不是,将会跳转到最后一个文件。这个文件选项将会是灰色。
如果当前文件是文件集合 的一部分,将会调到它所在位置的前一File set>Previous Files
个文件。如果不是则跳到文件集合的第一个文件,同时变成灰色。
这个菜单允许您将捕捉文件中所有的或者部分的包导出为plain
Export> as “Plain Text” File… ASCII text格式。它将会弹出一个Wireshark导出对话框,见第 节 “"Export as Plain Text File"对话框”
将捕捉文件的全部或部分导出为PostScrit文件。将会出现导出文Export >as "PostScript" Files 件对话框。参见第 节 “"Export as PostScript File" 对话框”
Export > as "CVS" (Comma
Separated Values Packet
导出文件全部或部分摘要为.cvs格式(可用在电子表格中)。将会弹出导出对话框,见第 节 “"Export as CSV (Comma Separated
Values) File" 对话框”。
导出文件的全部或部分为PSML格式(包摘要标记语言)XML文件。Export > as “PSML” File…
将会弹出导出文件对话框。见第 节 “"Export as PSML File"
菜单项 快捷键
对话框”
描述
导出文件的全部或部分为PDML(包摘要标记语言)格式的XML文件。Export as "PDML" 将会弹出一个导出文件对话框,见第 节 “"Export as PDML
File" 对话框”
导出当前在Packet byte面版选择的字节为二进制文件。将会弹出Export > Selected Packet Bytes… 一个导出对话框。见第 节 “"Export selected packet bytes"
对话框”
打印捕捉包的全部或部分,将会弹出打印对话框。见第 节 “打Print Ctr+P
印包”
Quit
Ctrl+Q 退出Wireshark,如果未保存文件,Wireshark会提示是否保存。
. "Edit"菜单
Wireshark的"Edit"菜单包含的项目见表 “Edit菜单项”
图 . "Edit"菜单
表 . Edit菜单项
菜单项
Copy>As Filter
快捷键 描述
Shift+Ctrl+C 使用详情面版选择的数据作为显示过滤。显示过滤将会拷贝到剪贴板。
菜单项
Find Next
Find Previous
Mark Packet(toggle)
Find Next Mark
Find Previous Mark
Mark ALL Packets
Unmark All Packet
Set Time
快捷键
Ctr+F
Ctrl+N
Ctr+B
Ctrl+M
描述
打开一个对话框用来通过限制来查找包,见
在使用Find packet以后,使用该菜单会查找匹配规则的下一个包
查找匹配规则的前一个包。
标记当前选择的包。见第 节 “标记包”
Shift+Ctrl+N 查找下一个被标记的包
Ctrl+Shift+B 查找前一个被标记的包
标记所有包
取消所有标记
Ctrl+T
Reference(toggle)
Find Next Reference
Find Previous
以当前包时间作为参考,见第 节 “包参考时间”
找到下一个时间参考包
找到前一个时间参考包
打开首选项对话框,个性化设置Wireshark的各项参数,设置后的参数将会Shift+Ctrl+P
在每次打开时发挥作用。详见第 节 “首选项”
. "View"菜单
表 “"View"菜单项”显示了Wireshar View菜单的选项
图 . "View"菜单
表 . "View"菜单项
快捷菜单项
键
Main Toolbar
Filter Toolbar
Statusbar
显示隐藏Main toolbar(主工具栏),见第 节 “"Main"工具栏”
显示或隐藏Filter Toolbar(过滤工具栏)见第 节 “"Filter"工具栏”
显示或隐藏状态栏,见第 节 “状态栏”
显示或隐藏Packet List pane(包列表面板),见第 节 “"Pcaket List"Packet List
面板”
显示或隐藏Packet details pane(包详情面板).见第 节 “"Packet
Packet Details
Details"面板”
显示或隐藏 packet Bytes pane(包字节面板),见第 节 “"Packet Byte"Packet Bytes
面板”
选择这里告诉Wireshark将时间戳设置为绝对日期-时间格式(年月日,时分秒),见第 节 “时间显示格式及参考时间”
描述
Time Display Fromat>Date and
Time of Day: 1970-01-01 01:02:
注意
这里的字段"Time of Day","Date and Time of Day","Seconds Since
Beginning of Capture","Seconds Since Previous Captured
Packet"和"Seconds Since Previous Displayed Packet"几个选项是互斥的,换句话说,一次同时有一个被选中。
快捷菜单项
键
Time Display Format>Time of
Day: 01:02:
Time Display Format > Seconds
Since Beginning of Capture:
Time Display Format > Seconds
将时间戳设置为秒格式,从上次捕捉开始计时,见第 节 “时间显示格式Since Previous Captured
Packet:
Time Display Format > Seconds
将时间戳设置为秒格式,从上次显示的包开始计时,见第 节 “时间显示Since Previous Displayed
Packet:
Time Display Format > ------
根据指定的精度选择数据包中时间戳的显示方式,见第 节 “时间显示格Time Display Format >
Automatic (File Format
Precision)
注意
"Automatic","Seconds"和"...seconds"是互斥的
描述
将时间设置为绝对时间-日期格式(时分秒格式),见第 节 “时间显示格式及参考时间”
将时间戳设置为秒格式,从捕捉开始计时,见第 节 “时间显示格式及参考时间”
及参考时间”
格式及参考时间”
式及参考时间”
Time Display Format > Seconds:
0
Time Display
Format > ...seconds: 0....
Name Resolution > Resolve Name
Name Resolution > Enable for
MAC Layer
Name Resolution > Enable for
Network Layer
Name Resolution > Enable for
Transport Layer
设置精度为1秒,见第 节 “时间显示格式及参考时间”
设置精度为1秒,秒,秒,百万分之一秒等等。 见第 节 “时间显示格式及参考时间”
仅对当前选定包进行解析第 节 “名称解析”
是否解析Mac地址
是否解析网络层地址(ip地址),见第 节 “名称解析”
是否解析传输层地址第 节 “名称解析”
是否以彩色显示包
Colorize Packet List
注意
以彩色方式显示包会降低捕捉再如包文件的速度
控制在实时捕捉时是否自动滚屏,如果选择了该项,在有新数据进入时, 面Auto Scrooll in Live Capture 板会项上滚动。您始终能看到最后的数据。反之,您无法看到满屏以后的数据,除非您手动滚屏
Zoom In Ctrl++ 增大字体
快捷菜单项
键
Zoom Out
Normal Size
Ctrl+- 缩小字体
Ctrl+= 恢复正常大小
恢复所有列宽
Resiz All Columnus
注意
除非数据包非常大,一般会立刻更改
描述
Expend Subtrees
Expand All
Collapse All
展开子分支
看开所有分支,该选项会展开您选择的包的所有分支。
收缩所有包的所有分支
打开一个对话框,让您可以通过过滤表达来用不同的颜色显示包。这项功能
对定位特定类型的包非常有用。见第 节 “包色彩显示设置”
Show Packet in New Window
Reload
在新窗口显示当前包,(新窗口仅包含View,Byte View两个面板)
Ctrl+R 重新再如当前捕捉文件
. "Go"菜单
Wireshark "GO"菜单的内容见表 “"GO"菜单项”
图 . "GO"菜单
表 . "GO"菜单项
菜单项
Back
ForWard
快捷键 描述
Alt+Left 跳到最近浏览的包,类似于浏览器中的页面历史纪录
Alt+Right 跳到下一个最近浏览的包,跟浏览器类似
打开一个对话框,输入指定的包序号,然后跳转到对应的包,见第 节 “到Go to Packet Ctrl+G
指定的包”
Go to Corresponding
Packet
Previous Packet
Next Packet
First Packet
Last Packet
Ctrl+UP 移动到包列表中的前一个包,即使包列表面板不是当前焦点,也是可用的
Ctrl+Down 移动到包列表中的后一个包,同上
移动到列表中的第一个包
移动到列表中的最后一个包
跳转到当前包的应答包,如果不存在,该选项为灰色
. "Capture"菜单
"Capture"菜单的各项说明见表 “"Capture"菜单项”
图 . "Capture"菜单
表 . "Capture"菜单项
快捷菜单项
键
Start
Stop
Restart
Capture
“定义,保存过滤器”
在弹出对话框选择您要进行捕捉的网络接口,见第 节 “捕捉接口对话框”
说明
Ctrl+K 打开设置捕捉选项的对话框,(见第 节 “捕捉选项对话框”)并可以在此开始捕捉
立即开始捕捉,设置都是参照最后一次设置。
Ctrl+E 停止正在进行的捕捉,见第 节 “停止捕捉”
正在进行捕捉时,停止捕捉,并按同样的设置重新开始捕捉.仅在您认为有必要时
打开对话框,编辑捕捉过滤设置,可以命名过滤器,保存为其他捕捉时使用见第 节
. "Analyze"菜单
"Analyze"菜单的各项见表 “"analyze"菜单项”
图 . "Analyze"菜单
表 . "analyze"菜单项
菜单项
Display
快捷键 说明
打开过滤器对话框编辑过滤设置,可以命名过滤设置,保存为其他地方使用,见
第 节 “定义,保存过滤器”
菜单项
Apply as
快捷键 说明
更改当前过滤显示并立即应用。根据选择的项,当前显示字段会被替换成选择在
Filter>...
Prepare a
Filter>... 成Detail面板选择的协议字段
为多种不同的防火墙创建命令行ACL规则(访问控制列表),支持Cisco IOS, Linux
Firewall ACL
Rules
Netfilter (iptables), OpenBSD pf and Windows Firewall (via netsh). Rules for
MAC addresses, IPv4 addresses, TCP and UDP ports, 以及 IPv4+混合端口
以上假定规则用于外部接口
Enable
Shift+Ctrl+R 是否允许协议分析,见第 节 “"Enable Protocols"对话框”
[a]
Detail面板的协议字段
更改当前显示过滤设置,当不会立即应用。同样根据当前选择项,过滤字符会被替换看样子他们有个关于这部分的章节
. "Statistics"菜单
Wireshark "statistics"菜单项见表 “”
图 . "Statistics"菜单
表 .
快捷菜单项
键
Summary 显示捕捉数据摘要,见第 节 “摘要窗口”
显示协议统计分层信息,见第 节 “"Protocol Hierarchy"窗口”
显示会话列表(两个终端之间的通信),见
显示端点列表(通信发起,结束地址),见第 节 “"Endpoints"窗口”
显示用户指定图表,(如包数量-时间表)见第 节 “"IO Graphs"窗口”
通过一个组合窗口,显示会话列表,见第 节 “协议指定“Conversation List/会话Conversation List
列表”窗口”
Endpoint List
Service Response
Time
ANSI
GSM
...
ISUP Message
Types
MTP3
RTP
GSM
SIP
HTTP
ISUP Messages
ONC-RPC Programs
TCP Stream Graph
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
HTTP请求/相应统计,见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
见第 节 “协议指定统计窗口”
显示一个请求及其相应之间的间隔时间,见第 节 “服务相应时间”
通过一个组合窗口显示终端列表,见第 节 “特定协议的"Endpoint List"窗口”
描述
Protocol Hierarchy
Conversations/
EndPoints
IO Graphs
. "Help"菜单
帮助菜单的内容见表 “”
图 . 帮助菜单
表 .
菜单项
Contents
快捷键
F1 打开一个基本的帮助系统
描述
Supported Protocols
Manaul Pages>...
打开一个对话框显示支持的协议或工具
打开浏览器,显示安装在本地的手册
按照选择显示在线资源
弹出信息窗口显示Wireshark的一些相关信息,如插件,目录等。
Wireshark Online>
About Wireshark
注意
有些版本可能不支持调用WEB浏览器。如果是这样,可能会隐藏此菜单。
注意
如果调用浏览器错误,检查Wireshark首选项关于浏览器设置。
. "Main"工具栏
主工具栏提供了快速访问常见项目的功能,它是不可以自定义的,但如果您觉得屏幕屏幕过于狭小,需要更多空间来显示数据。您可以使用浏览菜单隐藏它。
在主工具栏里面的项目只有在可以使用的时候才能被选择,如果不是可用则显示为灰色,不可选(例如:在未载入文件时,保存文件按钮就不可用.)
图 .
表 . 主工具栏选项
工具栏图标
接口
选项。。。
Start
STOP
Restar
Capture/Options
Capture/Start
Capture/Stop
Caputer/Rstart
打开接口列表对话框,见第 节 “开始捕捉”
打开捕捉选项对话框,见第 节 “捕捉接口对话框”
使用最后一次的捕捉设置立即开始捕捉
停止当前的捕捉,见第 节 “开始捕捉”
停止当前捕捉,并立即重新开始
启动打开文件对话框,用于载入文件,详见第 节 “打File/Open
开捕捉文件对话框”
保存当前文件为任意其他的文件,它将会弹出一个对话框,(见第 节 “"save Capture File As/保存文件为"对话框”
File/
注意
如果当前文件是临时未保存文件,图标将会显示为
工具栏项 对应菜单项 描述
Close
Reload
File/Close
View/Reload
关闭当前文件。如果未保存,将会提示是否保存
重新载入当前文件
打印捕捉文件的全部或部分,将会弹出一个打印对话框(见File/Print
第 节 “打印包”)
打开一个对话框,查找包。见第 节 “查找包”
返回历史记录中的上一个
跳转到历史记录中的下一个包
弹出一个设置跳转到指定的包的对话框
Edit/
Go Back
Go Forward
Go/Go Back
Go/Go Forward
Go Go/Go
Go To First
Go/First Packet
Packet
跳转到第一包
Go To Last Packet Go/Last Packet
Colorize View/Coloreze
跳转到最后一个包
切换是否以彩色方式显示包列表
Auto Scroll in View/Auto Scrool in Live
开启/关闭实时捕捉时自动滚动包列表
Live Capture
工具栏图标
Zoom in
zoom out
Normal Size
View/Zoom In
View/Zoom Out
View/Normal Size
增大字体
缩小字体
设置缩放大小为100%
重置列宽,使内容适合列宽(使包列表内的文字可以完全显
Resize Columns View/Resize Columns
Capture
Filters..
Display
Analyze/
Filters..
Coloring
View/
显示设置”
打开首选项对话框,详见第 节 “首选项”
打开帮助对话框
义,保存过滤器”
定义以色彩方式显示数据包的规则详见第 节 “包色彩示)
工具栏项 对应菜单项 描述
打开对话框,用于创建、编辑过滤器。详见第 节 “定Capture/
义,保存过滤器”
打开对话框,用于创建、编辑过滤器。详见第 节 “定
Edit/Preferences
Help
Help/Contents
. "Filter"工具栏
过滤工具栏用于编辑或显示过滤器,更多详情见第 节 “浏览时过滤包”
图 . 过滤工具栏
表 .
工具工具栏栏图项
标
过滤 打开构建过滤器对话框,见第 节 “查找包”[a]
在此区域输入或修改显示的过滤字符,见第 节 “建立显示过滤表达式”,在输入过程中会进行语法检查。如果您输入的格式不正确,或者未输入完成,则背景显示为红色。直到您输入合法的表达式,背景会变为绿色。你可以点击下拉列表选择您先前键入的过滤字符。列表会一直保留,即使
过滤输您重新启动程序。
入框
注意
做完修改之后,记得点击右边的Apply(应用)按钮,或者回车,以使过滤生效。
注意
说明
工具工具栏栏图项
标
输入框的内容同时也是当前过滤器的内容(当前过滤器的内容会反映在输入框)
说明
标签为表达式的按钮打开一个对话框用以从协议字段列表中编辑过滤器,详见第 节 ““Filter
式... Expression/过滤表达式”对话框”
清除 重置当前过滤器,清除输入框
应用当前输入框的表达式为过滤器进行过滤
应用
表达注意
在大文件里应用显示过滤可能要很长时间
[a]
我看到的Filter按钮貌似没有图标,可能只出现在版中
. "Pcaket List"面板
Packet list/包列表面板显示所有当前捕捉的包
图 . "Packet list/包列表"面板
列表中的每行显示捕捉文件的一个包。如果您选择其中一行,该包得更多情况会显示在"Packet Detail/包详情","Packet Byte/包字节"面板
在分析(解剖)包时,Wireshark会将协议信息放到各个列。因为高层协议通常会覆盖底层协议,您通常在包列表面板看到的都是每个包的最高层协议描述。
例如:让我们看看一个包括TCP包,IP包,和一个以太网包。在以太网(链路层)包中解析的数据(比如以太网地址),在IP分析中会覆盖为它自己的内容(比如IP地址),在TCP分析中会覆盖IP信息。
包列表面板有很多列可供选择。需要显示哪些列可以在首选项中进行设置,见第 节 “首选项”
默认的列如下
No. 包的编号,编号不会发生改变,即使进行了过滤也同样如此
Time 包的时间戳。包时间戳的格式可以自行设置,见第 节 “时间显示格式及参考时间”
Source 显示包的源地址。
Destination 显示包的目标地址。
Protocal 显示包的协议类型的简写
Info 包内容的附加信息
右击包,可以显示对包进行相关操作的上下文菜单。见第 节 “浏览时过滤包”
. "Packet Details"面板
"Packet Details/包详情"面板显示当前包(在包列表面板被选中的包)的详情列表。
图 . "Packet Details/包详情"面板
该面板显示包列表面板选中包的协议及协议字段,协议及字段以树状方式组织。你可以展开或折叠它们。
右击它们会获得相关的上下文菜单。见第 节 “建立显示过滤表达式”
某些协议字段会以特殊方式显示
Generated fields/衍生字段 Wireshark会将自己生成附加协议字段加上括号。衍生字段是通过该包的相关的其他包结合生成的。例如:Wireshark 在对TCP流应答序列进行分析时。将会在TCP协议中添加[SEQ/ACK
analysis]字段
Links/链接 如果Wireshark检测到当前包与其它包的关系,将会产生一个到其它包的链接。链接字段显示为蓝色字体,并加有下划线。双击它会跳转到对应的包。
. "Packet Byte"面板
Packet Byte/包字节 面板以16进制转储方式显示当前选择包的数据
图 . Packet Byte/包字节面板
通常在16进制转储形式中,左侧显示包数据偏移量,中间栏以16进制表示,右侧显示为对应的ASCII字符
根据包数据的不同,有时候包字节面板可能会有多个页面,例如:有时候Wireshark会将多个分片重组为一个,见第 节 “合并包”.这时会在面板底部出现一个附加按钮供你选择查看
图 . 带选项的"Paket Bytes/包字节"面板
注意
附加页面的内容可能来自多个包。
右击选项按钮会显示一个上下文菜单显示所有可用的页的清单。如果您的面板尺寸过小,这项功能或许有所帮助
. 状态栏
状态栏用于显示信息
通常状态栏的左侧会显示相关上下文信息,右侧会显示当前包数目
图 . 初始状态栏
该状态栏显示的是没有文件载入时的状态,如:刚启动Wireshark时
图 . 载入文件后的状态栏
左侧显示当前捕捉文件信息,包括名称,大小,捕捉持续时间等。
右侧显示当前包在文件中的数量,会显示如下值
P:捕捉包的数目
D:被显示的包的数目
M: 被标记的包的数目.
图 . 已选择协议字段的状态栏
如果你已经在"Packet Detail/包详情"面板选择了一个协议字段,将会显示上图
提示
括号内的值(如上图的可以作为显示过滤使用。它表示选择的协议字段。
第 4 章 实时捕捉数据包
. 介绍
实时捕捉数据包时Wireshar的特色之一
Wiershark捕捉引擎具备以下特点
支持多种网络接口的捕捉(以太网,令牌环网,)
支持多种机制触发停止捕捉,例如:捕捉文件的大小,捕捉持续时间,捕捉到包的数量...
捕捉时同时显示包解码详情
设置过滤,减少捕捉到包的容量。见第 节 “捕捉时过滤”
长时间捕捉时,可以设置生成多个文件。对于特别长时间的捕捉,可以设置捕捉文件大小罚值,设置仅保留最后的N个文件等手段。见第 节 “捕捉文件格式、模式设置”
Wireshark捕捉引擎在以下几个方面尚有不足
从多个网络接口同时实时捕捉,(但是您可以开始多个应用程序实体,捕捉后进行文件合并)
根据捕捉到的数据停止捕捉(或其他操作)
. 准备工作
第一次设置Wireshark捕捉包可能会遇到一些小麻烦
提示
关于如何进行捕捉设置的较为全面的向导可以在:
这里有一些常见需要注意的地方
你必须拥有root/Administrator特权以开始捕捉[12]
必须选择正确的网络接口捕捉数据
如果您想捕捉某处的通信,你必须作出决定:在什么地方可以捕捉到
……以及许多
如果你碰到设置问题,建议看看前面的那个向导,或许会有所帮助
. 开始捕捉
可以使用下任一方式开始捕捉包
使用打开捕捉接口对话框,浏览可用的本地网络接口,见图 “"Capture Interfaces"捕捉接口对话框”,
选择您需要进行捕捉的接口启动捕捉
你也可以使用"捕捉选项"按钮启动对话框开始捕捉,见图 “"Capture Option/捕捉选项"对话框”
开始捕捉"按钮或者是菜单项立即开始本次捕捉。 如果您前次捕捉时的设置和现在的要求一样,您可以点击"
如果你已经知道捕捉接口的名称,可以使用如下命令从命令行开始捕捉:
wireshark -i eth0 -k
上述命令会从eht0接口开始捕捉,有关命令行的介绍参见第 节 “从命令行启动Wireshark”
. 捕捉接口对话框
如果您从捕捉菜单选择"",将会弹出如图 “"Capture Interfaces"捕捉接口对话框”所示的对话框
警告
打开"Capture Interfaces"/捕捉对话框时 同时正在显示捕捉的数据,这将会大量消耗您的系统资源。尽快选择您需要的接口以结束该对话框。避免影响系统性能
注意
这个对话框只显示本地已知的网络接口,Wireshark可能无法检测到所有的本地接口,Wireshark不能检测远程可用的网络接口,Wireshark只能使用列出可用的网络接口
图 . "Capture Interfaces"捕捉接口对话框
描述
从操作系统获取的接口信息
IP
Wireshark能解析的第一个IP地址,如果接口未获得IP地址(如,不存在可用的DHCP服务器),将会显示"Unkow",如果有超过一个IP的,只显示第一个(无法确定哪一个会显示).
Packets
打开该窗口后,从此接口捕捉到的包的数目。如果一直没有接收到包,则会显示为灰度
Packets/s
最近一秒捕捉到包的数目。如果最近一秒没有捕捉到包,将会是灰度显示
Stop
停止当前运行的捕捉
Capture
从选择的接口立即开始捕捉,使用最后一次捕捉的设置。
Options
打开该接口的捕捉选项对话框,见 第 节 “捕捉选项对话框”
Details(仅Win32系统)
打开对话框显示接口的详细信息
Close
关闭对话框
. 捕捉选项对话框
如果您从捕捉菜单选择""按钮(或者从主工具栏选择对应的项目),Wireshark弹出"Capture Option/捕捉选项"对话框。如图 “"Capture Option/捕捉选项"对话框”所示
图 . "Capture Option/捕捉选项"对话框
提示
如果你不了解各项设置的意义,建议保持默认。
你可以用对话框中的如下字段进行设置
4.5.1. 捕捉桢
Interface
该字段指定你想用于进行捕捉的借口。一次只能使用一个接口。这是一个下拉列表,简单点击右侧的按钮,选择你想要使用的接口。默认第一是支持捕捉的non-loopback(非环回)接口,如果没有这样的接口,第一个将是环回接口。在某些系统中,回借口不支持捕捉包(windows平台下的环回接口就不支持。)
在命令行使用-i
IP address
表示选择接口的IP地址。如果系统未指定IP地址,将会显示为"unknown"
Link-layer header type
除非你有些特殊应用,尽量保持此选项默认。想了解更多详情,见 第 节 “链路层包头类型”
Buffer size: n megabyte(s)
输入用于捕捉的缓层大小。该选项是设置写入数据到磁盘前保留在核心缓存中捕捉数据的大小,如果你发现丢包。尝试增大该值。
注意
该选项仅适用于Windows平台
Capture packets in promiscuous mode
指定Wireshark捕捉包时,设置接口为杂收模式(有些人翻译为混杂模式)。如果你未指定该选项,Wireshark 将只能捕捉进出你电脑的数据包(不能捕捉整个局域网段的包)[13]
注意
如果其他应用程序将网卡设置为杂收模式,即使不选中该选项,也会工作于杂收模式下。
注意
即使在杂收模式下,你也未必能够接收到整个网段所有的网络包。详细解释见
each packet to n bytes
指定捕捉过程中,每个包的最大字节数。在某些地方被称为。"snaplen".[14]如果禁止该选项,默认值为65535,这适用于大多数协议,下面是一些大多数情况下都适用的规则(这里又出现了拇指规则,第一章,系统需求时提到过。这里权且翻译作普适而非绝对的规则))
如果你不确定,尽量保持默认值
如果你不需要包中的所有数据。例如:如果您仅需要链路层、IP和TCP包头,您可能想要选择一个较小的快照长度。这样只需要较少的cpu占用时间用于复制包,包需要的缓存也较少。如此在繁忙网络中捕捉时丢失的包也可能会相应少一点。
如果你没有捕捉包中的所有数据(适用snpaplen截断了包),你可能会发现有时候你想要的包中的数据部分被截断丢弃了。或者因为缺少重要的部分,想对某些包进行重组而发现失败。
Capture Filter
指定捕捉过滤。捕捉过滤器将会在有第 节 “捕捉时过滤”详细介绍,默认情况下是空的。
同样你也可以点击捕捉按钮,通过弹出的捕捉过滤对话框创建或选择一个过滤器,详见第 节 “定义,保存过滤器”
4.5.2. 捉数据帧为文件。
捕捉文件设置的使用方法的详细介绍见第 节 “捕捉文件格式、模式设置”
File
指定将用于捕捉的文件名。该字段默认是空白。如果保持空白,捕捉数据将会存储在临时文件夹。详见第 节
“捕捉文件格式、模式设置”
你可以点击右侧的按钮打开浏览窗口设置文件存储位置
Use multiple files
如果指定条件达到临界值,Wireshark将会自动生成一个新文件,而不是适用单独文件。
Next file every n megabyte(s)
仅适用选中Use multiple files,如果捕捉文件容量达到指定值,将会生成切换到新文件
Next file every n minutes(s)
仅适用选中Use multiple files,如果捕捉文件持续时间达到指定值,将会切换到新文件。
Ring buffer with n files
仅适用选中Use multiple files,仅生成制定数目的文件。
Stop caputure after n file(s)
仅适用选中Use multiple files,当生成指定数目文件时,在生成下一个文件时停止捕捉(生成n个还是n+1个文件)
4.5.3. 停止捕捉桢
... after n packet(s)
在捕捉到指定数目数据包后停止捕捉
... after n megabytes(s)
在捕捉到指定容量的数据(byte(s)/kilobyte(s)/megabyte(s)/gigabyte(s) )后停止捕捉。如果没有适用"user
multiple files",该选项将是灰色
... after n minute(s)
在达到指定时间后停止捕捉
4.5.4. 显示桢选项
Update list of packets in real time
在包列表面板实时更新捕捉数据。如果未选定该选项,在Wireshark捕捉结束之前将不能显示数据。如果选中该选项,Wireshark将生成两个独立的进程,通过捕捉进程传输数据给显示进程。
Automatic scrolling in live capture
指定Wireshark在有数据进入时实时滚动包列表面板,这样您将一直能看到最近的包。反之,则最新数据包会被放置在行末,但不会自动滚动面板。如果未设置"update list of packets in real time",该选项将是灰色不可选的。
Hide capture info dialog
选中该选项,将会隐藏捕捉信息对话框
4.5.5. 名称解析设置
Enable MAC name resolution
设置是否让Wireshark翻译MAC地址为名称,见第 节 “名称解析”
Enable network name resolution
是否允许Wireshark对网络地址进行解析,见第 节 “名称解析”
4.5.6. 按钮
进行完上述设置以后,你可以点击start按钮进行捕捉,也可以点击Cancel退出捕捉.
开始捕捉以后,在你收集到足够的数据时你可以停止捕捉。见第 节 “在捕捉过程中”
. 捕捉文件格式、模式设置
在 捕捉时,libpcap 捕捉引擎(linux环境下)会抓取来自网卡的包存放在(相对来说)较小的核心缓存内。这些数据由Wireshark读取并保存到用户指定的捕捉文件中。
保存包数据到捕捉文件时,可采用差异模式操作。
提示
处理大文件(数百兆)将会变得非常慢。如果你计划进行长时间捕捉,或者处于一个高吞吐量的网络中,考虑使用前面提到的"Multiple files/多文件"选项。该选项可以将捕捉包分割为多个小文件。这样可能更适合上述环境。
注意
使用多文件可能会切断上下文关联信息。Wireshark保留载入包的上下文信息,所以它会报告上下文关联问题(例如流问题)和关联上下文协议信息(例如:何处数据产生建立阶段,必须查找后续包)。这些信息仅能在载入文件中显示,使用多文件模式可能会截断这样的上下文。如果建立连接阶段已经保存在一个文件中,你想要看的在另一个文件中,你可能无法看到可用的上下文关联信息。
提示
关于捕捉文件的目录信息,可见
表 . 捕捉文件模式选项
"File"选项
"Use multiple
files"选项
"Ring buffer with n
Mode
files"选项
etherXXXXXX (where XXXXXX 是最终文件命名方式
- - - Single temporary file
一个独立值)
- - Single named file
Multiple
x -
files,continuous
, , ...
x x Multiple files,ring , , ...
"File"选项
"Use multiple
files"选项
"Ring buffer with n
Mode
files"选项
buffer
最终文件命名方式
Single temporary file
将会创建并使用一个临时文件(默认选项).捕捉文件结束后,该文件可以由用户指定文件名。
Single named file
使用单独文件,如果你想放到指定目录,选择此模式
Multiple files,continuous
与single name file模式类似,不同点在于,当捕捉达到多文件切换临界条件时之一时,会创建一个新文件用于捕捉
Multiple files,ring buffer
与"multiple files continuous"模式类似,不同之处在于,创建的文件数目固定。当达到ring buffer with n值时,会替换掉第一个文件开始捕捉,如此循环往复。
该模式可以限制最大磁盘空间使用量,即使未限制捕捉数据输入,也只能保留最后几个捕捉数据。
. 链路层包头类型
在通常情况下,你不需要选择链路层包头类型。下面的段落描述了例外的情况,此时选择包头类型是有必要的,所以你需要知道怎么做:
如果你在某种版本BSD操作系统下从某种 设备(无线局域网设备)捕捉数据,可能需要在""和"Ethernet"中做出选择。"Ethernet"将会导致捕捉到的包带有伪以太网帧头(不知道是不是应该叫伪首部更准确些);""将会导致他们带有帧头。如果捕捉时的应用程序不支持"帧头",你需要选择""
如果你使用Endace DAG card(某种网络监视卡)连接到同步串口线(译者注:E文为synchronous serial line,权且翻译作前文吧,未接触过此卡、未熟稔此线名称),可能会出现"PPP over serial" 或 "Cisco HDLC"(自己google去)供选择。根据你自己的情况选择二者中的一个。
如果你使用Endace DAG card(同上)连接到ATM网络,将会提供"RFC 1483 IP-over-ATM"、"Sun raw ATM"供选择。如果捕捉的通信是RFC 1483封装IP(RFC 1483 LLC-encapsulated IP,不翻译为妙),或者需要在不支持SunATM帧头的应用程序下捕捉,选择前者。反之选择后者。
如果你在以太网捕捉,将会提供"Ethernet"、"DOCSIS"供选择,如果您是在Cisco Cable Modem Termination
System(CMTS是思科同轴电缆终端调制解调系统)下捕捉数据。它会将DOCSIS(同轴电缆数据服务接口)通信放置到以太网中,供捕捉。此时需要选择"DOCSIS",反之则反之。
. 捕捉时过滤
Wireshark使用libpcap过滤语句进行捕捉过滤(what about winpcap)。在tcpdump主页有介绍,但这些只是过于晦涩难懂,所以这里做小幅度讲解。
提示
你可以从找到捕捉过滤范例.
在Wireshark捕捉选项对话(见图 “"Capture Option/捕捉选项"对话框”)框输入捕捉过滤字段。下面的语句有点类似于tcpdump捕捉过滤语言。在tcpdump主页可以看到tcpdump表达式选项介绍。
捕捉过滤的形式为:和取值(and/or)进行进行基本单元连接,加上可选的,高有限级的not:
[not] primitive [and|or [not] primitive ...]
例 . 捕捉来自特定主机的telnet协议
tcp port 23 and host 10.0.0.5
本例捕捉来自或指向主机10.0.0.5的Telnet 通信,展示了如何用and连接两个基本单元。另外一个例子例 “捕捉所有不是来自的telnet 通信”展示如何捕捉所有不是来自的telnet 通信。
例 . 捕捉所有不是来自10.0.0.5的telnet 通信
tcp host 23 and not src host 10.0.0.5
此处笔者建议增加更多范例。但是并没有添加。
一个基本单元通常是下面中的一个
[src|dst] host
此基本单元允许你过滤主机ip地址或名称。你可以优先指定src|dst关键词来指定你关注的是源地址还是目标地址。如果未指定,则指定的地址出现在源地址或目标地址中的包会被抓取。
ether [src|dst] host
此单元允许你过滤主机以太网地址。你可以优先指定关键词src|dst在关键词ether和host之间,来确定你关注的是源地址还是目标地址。如果未指定,同上。
gateway host
过滤通过指定host作为网关的包。这就是指那些以太网源地址或目标地址是host,但源ip地址和目标ip地址都不是host的包
[src|dst] net
通过网络号进行过滤。你可以选择优先指定src|dst来确定你感兴趣的是源网络还是目标网络。如果两个都没指定。指定网络出现在源还是目标网络的都会被选择。另外,你可以选择子网掩码或者CIDR(无类别域形式)。
[tcp|udp] [src|dst] port 过滤tcp,udp及端口号。可以使用src|dst和tcp|udp关键词来确定来自源还是目标,tcp协议还是udp协议。tcp|udp必须出现在src|dst之前。 less|greater 选择长度符合要求的包。(大于等于或小于等于) ip|ether proto 选择有指定的协议在以太网层或是ip层的包 ether|ip broadcast|multicast 选择以太网/ip层的广播或多播 创建一个复杂过滤表达式,来选择包的字节或字节范围符合要求的包。请参考 4.8.1. 自动过滤远程通信 如果Wireshark是使用远程连接的主机运行的(例如使用SSH,X11 Window输出,终端服务器),远程连接必须通过网络传输,会在你真正感兴趣的通信中产生大量数据包(通常也是不重要的) 想要避免这种情况,wireshark可以设置为如果发现有远程连接(通过察看指定的环境变量),自动创建一个过滤器来匹配这种连接。以避免捕捉Wireshark捕捉远程连接通信。 下列环境变量可以进行分析 SSH——CONNECTION(ssh) SSH_CLIENT (ssh) REMOTEHOST (tcsh, others) DISPLAY (x11) [remote name]: SESSIONNAME (terminal server) . 在捕捉过程中 捕捉时,会出现下面的对话框 图 . 捕捉信息对话框 上述对话框会向你显示捕捉到包的数目,捕捉持续时间。选择的被统计的协议无法更改(什么鸟意思) 提示 这个对话框可以被隐藏,在前次的捕捉选项对话框设置"Hide capture info dialog box"即可。 4.9.1. 停止捕捉 运行中的捕捉线程可以用下列方法停止: 1. 使用捕捉信息对话框上的"stop"按钮停止。 注意 捕捉信息对话框有可能被隐藏,如果你选择了"Hide capture info dialog" 2. 使用菜单项"Capture/3. 使用工具栏项" Stop" Stop" 4. 使用快捷键:Ctrl+E 5. 如果设置了触发停止的条件,捕捉达到条件时会自动停止。 4.9.2. 重新启动捕捉 运行中的捕捉进程可以被重新启动。这将会移出上次捕捉的所有包。如果你捕捉到一些你不感兴趣的包,你不想保留它,这个功能十分有用。 重新启动是一项方便的功能,类似于停止捕捉后,在很短的时间内立即开始捕捉。以下两种方式可以实现重新启动捕捉: 1. 使用菜单项"Capture/2. 使用工具栏项" Restart" Restart" [12] 记得在Windows安装那一节层提到如果作为服务启动可以避免非管理员无法进行捕捉,不知道二者能否相互印证。 [13] 网卡在局域网内会接到很多不属于自己的包,默认情况下,网卡会不对这些包进行处理。貌似设置为杂收模式,Wireshak会监听所有的包,但并不作出相应。 [14] 粗略查了一下,未找到该词的合适翻译,多见于Winpcap的描述,如果把该单词拆分,snap:单元,快照,len:长度,似乎就是单位长度,单元大小的意思。在看看该段下面第二个如果中提到的snapshot length,snaplen应该是二者的简写形式,快照长度 第 5 章 文件输入/输出及打印 . 说明 本章将介绍捕捉数据的输入输出。 打开/导入多种格式的捕捉文件 保存/导出多种格式的捕捉文件 合并捕捉文件 打印包 . 打开捕捉文件 Wireshark可以读取以前保存的文件。想读取这些文件,只需选择菜单或工具栏的:“File/将会 弹出打开文件对话框。详见第 节 “打开捕捉文件对话框” Open”。Wireshark如果使用拖放功能会更方便 要打开文件,只需要从文件管理器拖动你想要打开的文件到你的Wireshark主窗口。但拖放功能不是在所有平台都支持。 在你载入新文件时,如果你没有保存当前文件,Wireshark会提示你是否保存,以避免数据丢失。(你可以在首选项禁止提示保存) 除Wireshark原生的格式(libpcap 格式,同样被 tcpdump/Windump和 其他基于libpcap/WinPcap使用)外,Wireshark可以很好地读取许多捕捉文件格式。支持的格式列表见第 节 “输入文件格式” 5.2.1. 打开捕捉文件对话框 打开文件对话框可以用来查找先前保存的文件。表 “特定环境下的打开文件对话框”显示了一些Wireshark打开文件对话框的例子。 对话框的显示方式取决于你的操作系统 对话框的显示方式取决于操作系统,以及GTK+工具集的版本。但不管怎么说,基本功能都是一样的。 常见对话框行为: 选择文件和目录 点击Open/OK按钮,选择你需要的文件并打开它 点击Cancle按钮返回Wireshark主窗口而不载入任何文件。 Wireshark对话框标准操作扩展 如果选中文件,可以查看文件预览信息(例如文件大小,包个数。。。) 通过"filter:"按钮、显示字段指定显示过滤器。过滤器将会在打开文件后应用。在输入过滤字符时会进行语法检查。如果输入正确背景色为绿色,如果错误或输入未结束,背景色为绿色。点击filter按钮会打开过滤对话框,用于辅助输入显示过滤表达式。(详见第 节 “浏览时过滤包”) XXXX-we need a better description of these read filters(貌似说这一段需要更多的做介绍) 通过点击复选框指定那些地址解析会被执行。详见第 节 “名称解析” 在大文件中节约大量时间 你可以在打开文件后修改显示过滤器,和名称解析设置。但在一些巨大的文件中进行这些操作将会占用大量的时间。在这种情况下建议在打开文件之前就进行相关过滤,解析设置。 表 . 特定环境下的打开文件对话框 图 . Windows下的打开对话框 Microsoft Windows(GTK2 installed) 此对话框一般都带有一些wireshark扩展 此对话框的说明: 如果可用,"help"按钮将会打开本节的用户手册。 "Filter."按钮 在当前版本的windows下不可用(我看了一下,的确不可用,但过滤输入框还是可用的) 错误提示功能:如果Wireshark无法识别选中的捕捉文件,Open按钮将为灰色不可用[a] 图 . 新版GtK下的打开对话框 Unix/Linux:GTK version >= 这是在Gimp/GNOME桌面环境下的打开文件对话框 对此对话框的说明。 “+”按钮可以将右侧选中的目录添加到收藏夹。成为预设目录。 "-"按钮可以移除左侧目录列表中选中的目录。("Home","Desktop","Filesystem"不可以移除) 如果Wireshark不能识别选中的捕捉文件,"Open"按钮将是灰色不可用。 Unix/Linux: GTK version < / Microsoft Windows (GTK1 图 . 旧版GTK下的打开对话框 installed) gimp/gnome桌面环境,或windows gtk1下的的。 该对话框说明 如果未能识别不做文件,Open按钮将为灰色不可用 [a] 我测试了一下,无论什么文件,Wireshark都会去尝试打开,更遑论错误检查 5.2.2. 输入文件格式 可以打开的捕捉文件格式列表: libpcap, tcpdump and various other tools using tcpdump's capture format Sun snoop and atmsnoop Shomiti/Finisar Surveyor captures Novell LANalyzer captures Microsoft Network Monitor captures AIX's iptrace captures Cinco Networks NetXray captures Network Associates Windows-based Sniffer and Sniffer Pro captures Network General/Network Associates DOS-based Sniffer (compressed or uncompressed) captures AG Group/WildPackets EtherPeek/TokenPeek/AiroPeek/EtherHelp/PacketGrabber captures RADCOM's WAN/LAN Analyzer captures Network Instruments Observer version 9 captures Lucent/Ascend router debug output HP-UX's nettl Toshiba's ISDN routers dump output ISDN4BSD i4btrace utility traces from the EyeSDN USB S0 IPLog format from the Cisco Secure Intrusion Detection System pppd logs (pppdump format) the output from VMS's TCPIPtrace/TCPtrace/UCX$TRACE utilities the text output from the DBS Etherwatch VMS utility Visual Networks' Visual UpTime traffic capture the output from CoSine L2 debug the output from Accellent's 5Views LAN agents Endace Measurement Systems' ERF format captures Linux Bluez Bluetooth stack hcidump -w traces Catapult DCT2000 .out files 不正确的包类型可能无法会导致打开错误。 某些类型的捕捉包可能无法读取。以太网环境下捕捉的大部分类型格式一般都等打开。但有些包类型(如令牌环环包),不是所有的格式都被wireshark支持。 . 保存捕捉包 你可以通过File->菜单保存捕捉文件。在保存时可以选择保存哪些包,以什么格式保存。 保存可能会丢失某些有用的信息 保存可能会少量都是某些信息。例如:已经被丢弃的包会丢失。详见 5.3.1. "save Capture File As/保存文件为"对话框 "Save Capture File As"对话框用于保存当前捕捉数据到文件。列举了该对话框的一些例子。 对话框的显示方式取决于你的操作系统 对话框的显示方式取决于你的操作系统和GTK+工具集版本的不同。但大部分基本功能都是一样的。 表 . 特定环境下的"Save Capture File As"对话框 图 . Windows下的保存为对话框 Microsoft Windows(GTK2 installed) 此对话框一般都带有一些wireshark扩展 此对话框的说明: 如果可用,"help"按钮将会打开本节的用户手册。 如果你未输入文件扩展名-例如.pcap,Wireshark会自动添加该文件格式的标准扩展名。 Unix/Linux:GTK version >= 这是在Gimp/GNOME桌面环境下的保存文件对话框 图 . 新版GtK下的保存为对话框 对此对话框的说明。 "Browse for other flders"前的“+”按钮可以让你指定文件保存的位置。。 图 . 旧版GTK下的保存为对话框 Unix/Linux: GTK version < / Microsoft Windows (GTK1 installed) gimp/gnome桌面环境,或windows gtk1下的的。 通过这些对话框,你可以执行如下操作: 1. 输入你指定的文件名。 2. 选择保存的目录 3. 选择保存包的范围,见第 节 “包范围选项” 4. 通过点击"File type/文件类型"下拉列表指定保存文件的格式。见 可供选中的文件格式可能会没有那么多 有些类型的捕捉格式可能不可用,这取决于捕捉包的类型。 可以直接保存为另一种格式。 你可以以一种格式读取捕捉文件,保存时使用另外一种格式(这句可能翻译有误。) 5. 点击"Save/OK"按钮保存。如果保存时遇到问题,会出现错误提示。确认那个错误提示以后,你可以重试。 6. 点击"Cancel"按钮退出而不保存捕捉包。 5.3.2. 输出格式 可以将Wireshark不着的包保存为其原生格式文件(libpcap),也可以保存为其他格式供其他工具进行读取分析。 各文件类型之间的时间戳精度不尽相同 将当前文件保存为其他格式可能会降低时间戳的精度,见第 节 “时间戳” Wireshark可以保存为如下格式。 libpcap, tcpdump and various other tools using tcpdump's capture format (*.pcap,*.cap,*.dmp) Accellent 5Views (*.5vw) HP-UX's nettl (*.TRC0,*.TRC1) Microsoft Network Monitor - NetMon (*.cap) Network Associates Sniffer - DOS (*.cap,*.enc,*.trc,*fdc,*.syc) Network Associates Sniffer - Windows (*.cap) Network Instruments Observer version 9 (*.bfr) Novell LANalyzer (*.tr1) Sun snoop (*.snoop,*.cap) Visual Networks Visual UpTime traffic (*.*) . 合并捕捉文件 有时候你需要将多个捕捉文件合并到一起。例如:如果你对多个接口同时进行捕捉,合并就非常有用(Wireshark实际上不能在同一个实体运行多次捕捉,需要开启多个Wireshark实体) 有三种方法可以合并捕捉文件: 从"File"菜单使用,menu item "Merge"(菜单项 "合并"),打开合并对话框,见第 节 “合并文件对话框” 使用拖放功能,将多个文件拖放到主窗口。Wireshark会创建一个临时文件尝试对拖放的文件按时间顺序进行合并。如果你只拖放一个文件,Wireshark可能(只是)简单地替换已经打开的文件。 使用mergecap工具。该工具是在命令行进行文件合并的。它提供了合并文件的丰富的选项设置。见 5.4.1. 合并文件对话框 通过该对话框可以选择需要合并的文件,并载入合并它们。 首先你会被提示有一个文件未保存 如果当前文件未保存,Wireshark会在启动合并对话框之前提示你是否保存文件。 此处的对话框的大多数内容与"Open Capture Files/打开捕捉文件"对话框类似,参见第 节 “打开捕捉文件对话框” 合并对话框中用于合并的控制选项: 将包插入已存在文件前 将选择文件内的包插入到当前已经载入文件之前 按时间顺序合并文件 将当前选择的文件和已载入的文件里的所有包按时间顺序合并 追加包到当前文件 将选择文件的包插入到当前载入文件的末尾 表 . 不同环境下的"Merge Capture File As"对话框 图 . Windows下的"合并"对话框 Microsoft Windows(GTK2 installed) 此对话框一般都带有一些wireshark扩展 图 . 新版GtK下的合并话框 Unix/Linux:GTK version >= 这是在Gimp/GNOME桌面环境下的合并对话框 图 . 旧版GTK下的合并对话框 Unix/Linux: GTK version < / Microsoft Windows (GTK1 installed) . 文件集合 在进行捕捉时(见:第 节 “捕捉文件格式、模式设置”)如果设置"Multiple Files/多文件"选项,捕捉数据会分割为多个文件,称为文件集合. 大量文件手动管理十分困难,Wirreshark的文件集合特性可以让文件管理变得方便一点。 Wireshark是如何知道一个文件所属的文件集合t的 文件集合中的文件名以前缀号码+"_"+号码+"_"+日期时间+后缀的形式生成的。类似于:"".文件集合所有的文件都有一个共同的前缀(例如前面的"test")和后缀(例如:".pcap")以及变化的中间部分。 要查找一个文件集合的所有文件。Wireshark会扫描当前载入文件的目录下的所有文件,找到那些和当前文件名具有相同部分(前缀和后缀)的作为文件集合。 这个简单的机制通常能正常运行,但也有它的弊端。如果几次进行的捕捉具有相同的前缀和后缀,Wireshark会将它们看作同一个文件集合。如果文件被更名或者放在不同的目录下,这样的按文件名查找机制会无法找到文件集合的所有文件。 使用"File"菜单项的子菜单"File Set"可以对文件集合集合进行很方便的控制。 List Files 对话框显示一个对话框列出所有被识别出来属于当前文件集合的文件列表。 Next Files 关闭当前文件,打开文件集合列表中的下一个文件。 Previous Files 关闭当前文件,打开文件集合列表中的前一个文件。 5.5.1. 文件列表对话框 图 . 文件列表对话框 每行包含文件集合中的一个文件的相关信息。 Filename 文件名称。如果你双击文件名称(或者单击单选钮),当前文件会被关闭,同时载入对应的文件。 Created 文件创建时间。 Last Modified 最后一次修改文件的时间。 size 文件的大小。 最后一行"...indirctory:"显示所有文件所在的目录。 在每次捕捉文件被打开、关闭时,对话框的内容会变化。 Close按钮关闭该对话框。 . 导出数据 Wireshark支持多种方法,多种格式导出包数据,本节描述Wireshark常见的导出包数据方法。 注意 个别数据需要使用许多特殊方式导出,在合适的时候我们会对其进行介绍。 XXX - add detailed descriptions of the output formats and some sample output, too./同样需要对导出格式进行介绍,同样也需要一些范例范例 5.6.1. "Export as Plain Text File"对话框 导出包数据为"plain AscⅡ "文本文本见,适合打印包数据。 图 . "Export as Plain Text File"对话框 Export to file:导出包数据为指定的文件 Packet Range 参见第 节 “包范围选项” Packet Details 参见 5.6.2. "Export as PostScript File" 对话框 导出数据为PostScript格式,PostScript是一种打印格式。 提示 PostScribt文件可以使用ghostscrip转换为PDF格式。例如导出文件名为,然后调用ps2pdf 命令就可以进行转换。 图 . "Export as PostScript File" 对话框 Export to file: 导出包数据为指定的文件 Packet Range: 参见第 节 “包范围选项” Packet Details: 参见 5.6.3. "Export as CSV (Comma Separated Values) File" 对话框 注:笔者认为此处应该增加截屏,因为我的xp下界面与前图风格迥异,这里就不提供了 导出包的摘要为CVS格式,可以被电子表格程序使用。 Export to file 导出包数据为指定的文件 Packet Range 参见第 节 “包范围选项” 5.6.4. "Export as PSML File" 对话框 导出包数据为PSML格式,它是一种仅包含包摘要信息的xml格式。PSML格式的说明参见:图 . "Export as PSML File"对话框 Export to file:导出包数据为指定的文件 Packet Range: 参见第 节 “包范围选项” 上图没有诸如Packet details的选项,因为PSML文件格式有特殊要求,不包含这些内容。 5.6.5. "Export as PDML File" 对话框 导出数据包为PDML格式,PDML是包含包详情的xml格式文件。PDML文件的说明见: 注意 PDML格式还没有发行版,Wireshark执行PDML还处在测试阶段,期望外来版本会有所变化。 图 . "Export as PDML File"对话框 Export to file:将包数据导出到 Packet Range: 参见第 节 “包范围选项” 上述对话框里没有诸如Packet details选项,这是由于PDML格式约定的内容决定的。 5.6.6. "Export selected packet bytes" 对话框 图 . "Export Selected Packet Bytes" 对话框 Name: 导出数据包为文件 Save in folder:导出数据包到指定目录 Browser for other folders 通过浏览来指定导出数据的目录。 5.6.7. "Export Objects" 对话框 这个对话框是用来扫描当前打开包文件或者是正在捕捉中的包文件,将其中的对象,如HTML文档,图片文件,可执行文件等等任何可以通过HTTP传输的对象进行重组集合,让你可以将他们保存刀磁盘。如果捕捉正在进行中,列表会在发现新对象之后的几秒内立即更新。保存的对象不需要进行额外处理就可以被对应的查看工具打开,或者直接运行(如果它可以在Wireshark所在的平台运行的话)。这项功能在GTK1下的Wireshark中无法使用。 图 . "Export Objects"对话框 各列说明 Packet num 包含该对象数据的包的数目,有时候多个对象可能包含在同一个包里。 Hostname 作为服务器相应HTTP请求发送对象的主机的主机名。 Content Type 对象的HTTP内容类型 Bytes 对象的字节数 Filename URL的最后一部分(最后一个"/"之后)。通常这部分是文件名,但有时是一个又常又复杂的字符串,这通常表明该文件是一个"HTTP POST"请求。(类似于填写表单以后通过CGI提交后跳转页面的URL) 按钮说明: Help 打开本节的用户手册(5.6.7节) Close 关闭该对话框 Save As 用指定文件名保存当前选择对象。默认文件名是filename列中显示的对象文件名。 Save All 将列表中所有对象按filename列显示名称保存。系统会提示你选择哪个目录/文件夹保存他们。如果文件名在当前操作系统或者文件系统下不合法,Wireshark会提示错误,该对象不会被保存(但其他对象会被保存)。 . 打印包 要打印包,选择File菜单的""菜单项。这时会弹出如图 “ "Print" 对话框”所示的打印对话框。 5.7.1. 打印 对话框 图 . "Print" 对话框 下面的字段在打印对话可用。 Printer 该字段包括一对互斥的单选钮 Print Text 指定包打印为plain text格式 PostScript 在打印过程中使用PostScrtipt打印软件生成打印输出。[15] Output to file 打印为文件,文件名使用输入的字段或者在浏览按钮选择。 如果你没有选择Output to file:复选框,你输入字段的地方或Browse。。按钮都是灰色。 Print command 设置打印时使用的命令 注意 打印命令在Windows平台不可用。 用于打印的命令通常是 would change it to specify a particular queue if you need to print to a queue other than the default.例如: lpr -Pmypostscript 如果没有选中Output to file,该字段将是灰色不可用的。 Packet Range 需要要被打印的包,参见:第 节 “包范围选项” Packet Format 选择输出文件的格式。你可以选择包以何种方式打印包。见图 “"Packet Format"选项卡” . 包范围选项 在前面提到的很多输出对话框,以及其他相关的对话框(比如捕捉)都有这个"Packet Range"选项,它可以对输出哪些包进行控制。 图 . "Packet Range"选项卡 如果设置Captured按钮,所有被输出规则选中的包都会被导出,如果设置Displayed按钮,则只有显示中的包被规则选中的才会导出。 All packets 处理所有包 Selected packet only 仅处理被选中的包 Marked packets only 处理被标记的包 From first to last marked packet 处理第一个被标记的包,到最后一个被标记的包的加上之间的所有包。 Specify a packet range 处理用户指定范围内的包,例如 5,50-15,20- 会处理编号为5,编号10-15之间的包(包括10,15),以及编号20到最后一个包。 . 包格式选项 包格式选项卡在很多输出对话框都能看到,它可以指定包的那些部分会被输出。 图 . "Packet Format"选项卡 Packet summary line 导出包的摘要行,就是"Packet List"面板的内容 Packet Details 导出Packet Details树 All collaspsed "Packet Details"面板在"all collapsed"状态下的所有信息(折叠所有分支) As displayed "Packet Details"面板当前状态下的信息 All expanded "Packet Details"面板"all expanded"状态下的信息(展开所有分支) Packet bytes 导出包字节,就是"Packet Bytes"面板的内容 Each Packet on a new page 输出是每个包单独一页(例如,如果保存/打印成text文件,会在包之间加上分节符) [15] 译者注:此处需要说明的是,如果没有打印机,或者不想打印,你应该在后面指定Output to file,指定打印输出未知,另,out put to file输出的后缀名是.out,如果想用acrobat导入,可以考虑将后缀名修改为.ps,这样可以被直接识别,当然,直接把文件拖放到Acrobat Distiller也可以直接生成PDF文件。 另:使用PostScript输出的文件具有良好的形式,比如在页首会加上列名,而直接打印为print text却没有这样的内容。 第 6 章 处理已经捕捉的包 . 浏览您捕捉的包 在你已经捕捉完成之后,或者打开先前保存的包文件时,通过点击包列表面版中的包,可以在包详情面板看到关于这个包树状结构以及字节面版 通过点击左侧"+"标记,你可以展开树状视图的任意部分。你可以在面板点击任意字段来选择它。例如:在下图图 “Wireshark选择了一个TCP包后的界面”显示的就是选中TCP字段。同样可以选择TCP包头的应答号(ack:190),同时会出现在下方的字节浏览面版中。[16] 图 . Wireshark选择了一个TCP包后的界面 在Wireshark正在捕捉时,您也可以进行同样的选择。(前提是您在捕捉选项对话框选择了实时更新列表(update list of packet in real time )) 另外,您可以使用分离的窗口浏览单独的数据包,见图 “在分离窗口浏览包” ,想要这样做,你只需要在选中包列表面版中您感兴趣的包,菜单 Display->Show Packet in New Windows 。它可以让你很轻松地比较两个或多个包。 图 . 在分离窗口浏览包


发布评论