// 所有原创文章转载请注明作者及链接
// blackboycpp(AT)gmail.com
// QQ群: 135202158
ethereal/wireshark是最优秀的一款开源协议分析软件。 探索它的内部机理是我很早就有的想法。现在有时间,不如把这件事儿坚持一下吧,好歹给自己一个交待。
首先我们需要一个Linux操作系统环境。对于初学者来说,Windows+虚拟机+Linux是一个不错的选择。我用的是Windows XP + VMware WorkStation 7.1 + Fedora13。后两个都可以在网上下载到。这里需要注意的是几点:
首先肯定是ethereal源码了,我很早以前从国外某个专门保存很多软件的历史版本的网站下载了ethereal的很多早期版本。这里使用0.2.0版。
Fedora本身包含一个添加/删除软件的工具,在"系统"/"管理"/"添加/删除软件"。为了编译ethereal,我们需要下载安装libpcap的开发包。
至于GTK+,在第1步已经安装了。
vi是Linux下开发人员很常用的一个编辑器,功能非常强大,有必要介绍一下它。
首先是配置,例如显示行号,自动缩进等等,可以在shell里使用vi ~/.vimrc建立自己的vim配置文件。
下面是我用的配置文件("号开始的行为注释):
----------------------------------------------------------------
" 语法高亮
syntax on
" 深色背景
color evening
" 显示行号
set number
" 检测文件类型
filetype on
" 设置各种缩进
set tabstop=4
set shiftwidth=4
set autoindent
set smartindent
" 高亮当前行
set cursorline
----------------------------------------------------------------
vi 共分为三种模式,分别是命令模式(Command mode)、编辑模式(Insert mode)与指令列模式(Last line mode)三种;也可以将命令模式与指令列模式统称为「命令模式」。
命令模式与指令列模式说明:
命令模式在最下面一行没有出现『--INSERT--』或『--REPLACE--』字样的时候。
重要性 |
Command mode: |
移动光标 |
* |
h 或 向左方向键 |
光标向左移动一个字符 |
* |
j 或 向下方向键 |
光标向下移动一个字符 |
* |
k 或 向上方向键 |
光标向上移动一个字符 |
* |
l 或 向右方向键 |
光标向右移动一个字符 |
** |
[Ctrl] + [f] |
屏幕『向前』移动一页 |
** |
[Ctrl] + [b] |
屏幕『向后』移动一页 |
|
[Ctrl] + [d] |
屏幕『向前』移动半页 |
|
[Ctrl] + [u] |
屏幕『向后』移动半页 |
|
+ |
光标移动到非空格符的下一列 |
|
- |
光标移动到非空格符的上一列 |
* |
n<space> |
按下数字后再按空格键,光标会向右移动这一行的 n 个字符。例如 20<space> 则光标会向后面移动 20 个字符距离。 |
*** |
0或[HOME] |
这是数字『 0 』:移动到这一行的最前面字符处(常用) |
*** |
$或[END] |
移动到这一行的最后面字符处(常用) |
* |
H |
光标移动到这个屏幕的最上方那一行 |
* |
M |
光标移动到这个屏幕的中央那一行 |
* |
L |
光标移动到这个屏幕的最下方那一行 |
*** |
G |
移动到这个档案的最后一行(常用) |
*** |
gg |
移动到这个档案的第一行(常用) |
** |
nG |
移动到这个档案的第 n 行。例如 20G 则会移动到这个档案的 20 行 |
** |
n<Enter> |
光标向下移动 n 行 |
|
Last line mode: |
搜寻与取代 |
*** |
/word |
向光标之后寻找一个字符串名称为 word 的字符串。搜寻时可按「n」将光标移到下一个字符串 |
** |
?word |
向光标之前寻找一个字符串名称为 word 的字符串。 |
*** |
:n1,n2s/word1/word2/g |
在第n1与n2行之间寻找word1这个字符串,并将该字符串取代为 word2 |
*** |
:1,$s/word1/word2/g |
从第一行到最后一行寻找 word1 字符串,并将该字符串取代为 word2 |
*** |
:1,$s/word1/word2/gc |
从第一行到最后一行寻找 word1 字符串,并将该字符串取代为 word2,且在取代前显示提示字符给使用者确认(conform)是否需要取代 |
重要性 |
Command mode: |
删除、复制与贴上 |
** |
x, X |
x 为向后删除一个字符, X 为向前删除一个字符 |
* |
nx |
向后删除 n 个字符 |
*** |
dd |
删除游标所在的那一整列 |
*** |
ndd |
删除光标所在的向下 n 列,例如 20dd 则是删除 20 列 |
* |
d1G |
删除光标所在到第一行的所有数据 |
* |
dG |
删除光标所在到最后一行的所有数据 |
*** |
yy |
复制游标所在的那一行 |
*** |
nyy |
复制光标所在的向下 n 列,例如 20yy 则是复制 20 列 |
* |
y1G |
复制光标所在列到第一列的所有数据 |
* |
yG |
复制光标所在列到最后一列的所有数据 |
*** |
p, P |
p为复制的数据在光标下一行贴上,P 则为贴在游标上一行 |
* |
J |
将光标所在列与下一列的数据结合成同一列 |
* |
c |
重复删除多个数据,例如向下删除 10 行,[ 10cj ] |
*** |
u |
复原前一个动作(undo) |
*** |
Ctrl+R |
重做(redo)(undo) |
*** |
ZZ(shift+z两次) |
若档案没有更动,则不储存离开,若档案已经经过更动,则储存后离开 |
|
进入Insert mode: |
|
*** |
i, I |
插入:在目前的光标所在处插入输入之文字,已存在的文字会向后退 |
*** |
a, A |
增加:由目前光标所在的下一个字开始输入,已存在的文字会向后退 |
*** |
o, O |
插入新的一行:从光标所在的下一行枝行首开始输入文字 |
** |
r, R |
取代:r 会取代光标所在的那一个字符;R会一直取代光标所在的文字,直到按下 ESC 为止) |
*** |
Esc |
退出编辑模式,回到一般模式中 |
|
Last line mode: |
|
*** |
:w |
将编辑的数据写入硬盘档案中 |
*** |
:w! |
若档案属性为『只读』时,强制写入该档案 |
*** |
:q |
离开 vi(档案未经修改才能直接离开) |
*** |
:q! |
若曾修改过档案,又不想储存,使用 ! 为强制离开不储存档案。 |
*** |
:wq |
储存后离开,若为 :wq! 则为强制储存后离开 |
** |
:e! |
将档案还原到最原始的状态! |
** |
:w [filename] |
将编辑的数据储存成另一个档案(类似另存新档) |
** |
:r [filename] |
在编辑的数据中,读入另一个档案的数据。亦即将 『filename』这个档案内容加到游标所在行后面 |
*** |
:set nu |
显示行号,设定之后,会在每一行的前缀显示该行的行号 |
*** |
:set nonu |
与 set nu 相反,为取消行号!(或:set nu!) |
** |
n1,n2 w [filename] |
将 n1 到 n2 行的内容储存成 filename 这个档案。 |
*** |
:sh |
暂时离开 vi 到Shell下执行指令,执行完毕可打「exit」或按「Ctrl+d」返回vi |
* |
:! command |
暂时离开 vi 到指令列模式下执行 command 的显示结果!例如[ :! ls /home ] |