由于工作需要,我编写过一个解析内部通信协议的wireshark的插件,插件是使用lua语言编写的,所以wireshark必须要支持lua接入才行。
一般在windows下的wireshark使用安装包安装后,都是支持lua的。只是默认lua支持是处于关闭状态,在网上一搜索就能知道怎么打开lua支持了。
但是,在Linux下就不一定支持了。我们公司使用的是CentOS的操作系统,默认使用操作系统光盘安装的wireshark是没有lua支持的。所以,我就只能摸索如下的步骤去重新编译wireshark,并且让它支持lua插件了。
对了,我们都是不能联网的机器。只能使用光盘作为yum源了。如何使用光盘yum源,请参考网上资料,或者我前面的文章。
试验环境
操作系统:CentOS 6.3
软件准备
1、CentOS的DVD光盘
但是由于需要支持lua,所以DVD1和DVD2都需要。如果虚拟机使用的,下载下面两个镜像就好。
如果是可以联网的同学,就不需要准备这两个东东了,直接联网用yum就好了。我是个不能联网的小苦逼
2、wireshark源码包
去wireshark官网下载就好了 https://www.wireshark.org/download/src/all-versions/
注意,现在官网首页让下载的是新版本wireshark使用QT开发界面的,我还不会解决依赖关系,所以还是去下载页下载老版本的一点的源码包吧。实验使用的是下面链接的包
https://www.wireshark.org/download/src/all-versions/wireshark-1.10.5.tar.bz2
3、libpcap源码包
作为wireshark的好×××,libpcap咱们也不能忘记了。所以去官网下载吧 www.tcpdump.org
就是下图的红色箭头指示的链接。
实验使用的是首页的这个链接的包
http://www.tcpdump.org/release/libpcap-1.7.4.tar.gz
所需要的东西都准备好了吗?现在将wireshark和libpcap的源码包都放入需要编译wireshark的机器吧,将系统盘DVD1也推进光驱吧!
开始编译
1、编译libpcap
假设咱们将源码包都放到目录/home/下,下面就开始执行命令
cd /home/tar -zxvf libpcap-1.7.4.tar.gzcd libpcap-1.7.4./configure
结果出现下面图的error。
此时,如果出现错误,就证明咱们没有安装开发工具,至少就是gcc什么的没有装了。所以,需要安装上开发工具。具体方法,请参照我前面的那篇文章。
yum groupinstall "开发工具"
接下来我们就可以再次执行上面的编译命令了。
./configuremakemake install
至此,编译libpcap已经完事了。
2、第一次尝试编译wireshark
依然是老方法,解压源码包,然后编译
cd /hometar -jxvf wireshark-1.10.5.tar.bz2cd wireshark-1.10.5./configure
出现下面的错误了,说明咱们没有qt或者gtk的支持和依赖。
3、GTK+安装图形库支持
所以还是使用yum去解决,咱们安装gtk支持。执行如下命令安装。
yum install gtk2-devel
安装完毕之后。接下来,咱们可以继续执行上面的命令尝试预编译了。
./configure
出现如下图所示汇总:
没有提示错误了,有不需要lua插件支持的同学可以直接进行make的编译了。但是,如果需要插件的同学,输出文本的这个提示:
Use Lua library : no
下面我们就为了这个做处理了……
4、安装lua依赖
当然,这个还是用yum来处理啦。不需要lua,只需要wireshark的同学就跳过这一步吧!这个时候就要插入DVD2了,当然有网的同学就不用担心了,直接运行命令就好。
有请yum大神……
yum install lua-devel
安装完毕之后,在执行预编译命令,应该就能看到:
Use Lua library : yes
5、正式开始编译wireshark。
还是那些命令
./configuremakemake install
等待很漫长,很漫长的时间之后。wireshark终于编译完成了。
咱们验证一下。
召唤它吧~~~~
wireshark &
点击菜单的【Help】-->【About Wireshark】
出现如下的窗口:
终于完事了,写这个东西竟然花了我一个下午的时间。我也是醉了……