wireshark不久前升级到1.10.0稳定版,这个版本正如其版本号一样,相比1.8.x有较大变化。

我们先说说在windows下编译的问题,1.8.4/1.8.6版本的编译见我的文章:http://www.cnblogs.com/zzqcn/archive/2013/04/23/3039110.html,这是重要的参考。更早的版本编译也是大同小异。这里要说一句,我在网上搜到的wireshark Windows下编译貌似全是我写的,csdn上那个blackboyofsnp也是我。

编译时的操作系统是Windows 7 32bit, 编译器是Visual C++ 2012,并带有Windows SDK v7.1。

1. 神马?VC++ 2012?? 没错,1.10.0终于支持VC++2012了,这是我发现的最大亮点。我终于不用为了编译它而在电脑上装多个版本的VS了,而且避免了CRT冲突的问题。

2. wireshark 1.10.0在Windows下的编译需要<Windows SDK>/include目录中的win32.mak文件,正好我装了Windows SDK 7.1,于是在编译之前的环境配置批处理脚本中加入了下面这一句:

set INCLUDE=%INCLUDE%;C:\Program Files\Microsoft SDKs\Windows\v7.1A\Include

此时我的bat脚本内容如下所示:

@echo off

set PATH=%PATH%:.
set PATH=%PATH%;d:\dev\cygwin\bin set INCLUDE=%INCLUDE%;C:\Program Files\Microsoft SDKs\Windows\v7.1A\Include echo 设置 Visual Studio environment...
"C:\Program Files\Microsoft Visual Studio 11.0\Common7\Tools\vsvars32.bat" title Command Prompt (MSVC++ 2012)

是的,除了以上的1,2之外,其他应该没啥变化了,照以前的编译方法编译即可。提示:注意debug/release版本和CRT版本哦,见config.nmake文件的LOCAL_LDFLAGS=/DEBUG这一行。

接下来说说1.10.0版本和动态调用libwireshark.dll协议解析库有关的一些变化。

1. 废弃了原来的/epan/libwireshark.def文件和WS_VAR_IMPORT(这个定义在\wireshark-1.8.x/CMakeLists.txt中),而是采用一种叫做C++ Visibility的技术,这种技术其实我也不懂啦,我只觉得Visibility, Niubility,傻傻分不清楚。。。 学有余力的同学请参考 http://gcc.gnu.org/wiki/Visibility。相关的宏定义在/ws_symbol_export.h中。

这会影响到我们调用时头文件的一些声明,我建议在wireshark调用函数声明所在的头文件的最上面,#include ws_symbol_export.h。比如:

#if WIRESHARK_VERSION == WIRESHARK_1_10_0
#include "ws_symbol_export.h"
#elif (WIRESHARK_VERSION == WIRESHARK_1_8_6 || WIRESHARK_VERSION == WIRESHARK_1_8_4)
// see \wireshark-1.8.4\CMakeLists.txt, #481
#define WS_VAR_IMPORT __declspec(dllimport) extern
#else
#error 不支持此版本的wireshark
#endif

2. 解析器执行函数epan_dissect_run()的第2个参数从void* pseudo_header改为struct wtap_pkthdr *phdr,这可是核心函数啊啊啊。。。必须要改,而且要多#include一个/wiretap/wtap.h。在你自己程序的具体调用的代码中,也要初始化好这个结构哦

3. (不关心IP地址查询的同学可能不需要关心第3点。但注意一下是好事)GeoIP模块的初始化不再放在epan_init()中,而是使用一个不可见的回调函数geoip_db_post_update_cb来自动更新GeoIP配置。ChangeLogs里有几个blablabla地注释了一通这种方法的好处,比如配置选项更新后不需要立即重启wireshark就可使改动生效。可尼玛苦了我了。

【以下说法可能不准确,但我确实遇到这问题。】这个改动会造成以下后果:如果你自己的调用程序(也就是调用libwireshark.dll进行解析的程序啦)所在电脑上也安装了wireshark原版,而且wireshark中的GeoIP选项(在Edit/Preferences菜单->Name Resolution->GeoIP database directories)设置了的话,可能会使你的程序只能解析到IP层,就导致运行时断言失败而返回,因为GeoIP相关的指针非法。

做为第3方调用程序,我们无法执行到回调函数。为此我HACK了wireshark源码,在/epan/geoip_db.h & .c中添加了一个导出函数geoip_update_force(),在其中调用geoip_db_post_update_cb,源码如下:

geoip_db.h

/*
* Hacked by blackboycpp, 2013/06/22
*
* for GeoIP bug in wireshark 1.10.0, becaz my app can't call the update callback
*/
WS_DLL_PUBLIC void geoip_update_force(void);

geoip_db.c

// 定义在geoip_db_post_update_cb()下面
void geoip_update_force(void)
{
const gchar* err;
uat_load(geoip_db_paths_uat, &err);
geoip_db_post_update_cb();
}

改完后编译自己的libwireshark.dll。这也意味着你的程序将无法使用原版的libwireshark.dll,因为你改了嘛。

最后记得在你程序的init_dissection()执行之前(或之后??)调用一下我们HACK上去的这个geoip_update_force()函数。

wireshark 1.10.0 编译 及 协议解析部分的一些变化的更多相关文章

  1. 使用 lua 编写 wireshark 协议解析插件

    一.平台 操作系统:windows 7 wireshark:1.10.3 lua:5.1 二.准备 lua 语言基本语法,特别是关于表操作和循环 wireshark 文档,包括用户使用文档和开发者文档 ...

  2. 非寻常方式学习ApacheTomcat架构及10.0.12源码编译

    概述 开启博客分享已近三个月,感谢所有花时间精力和小编一路学习和成长的伙伴们,有你们的支持,我们继续再接再厉 **本人博客网站 **IT小神 www.itxiaoshen.com 定义 Tomcat官 ...

  3. 在vs2010中编译log4cxx-0.10.0详细方法

    本文一共包含了17个步骤,按照下面的步骤就可以完成vs2010中编译log4cxx的工作了. 1. 下载 log4cxx 以及 apr 和 apr-util 源码: a) http://www.apa ...

  4. 在vs2010中编译log4cxx-0.10.0具体方法(从下载、编译、解决错误具体介绍)

    一. 简单介绍 log4cxx是Java社区著名的log4j的c++移植版.用于为C++程序提供日志功能,以便开发人员对目标程序进行调试和审计,log4cxx是apache软件基金会的开源项目,基于A ...

  5. 西门子S7comm协议解析 —— 利用Wireshark对报文逐字节进行解析详细解析S7comm所含功能码以及UserData功能

    又一次成为懒蛋了,标题就这么改了改又是一篇新文章. 网上也有很多S7comm协议的解析,但还是如同我上一篇一样我只是做报文的解析对于S7comm的原理并进行阐述. 有些地方有错误的地方尽请大家指出,共 ...

  6. CentOS7 编译安装 nginx-1.10.0

    对于NGINX 支持epoll模型 epoll模型的优点 定义: epoll是Linux内核为处理大批句柄而作改进的poll,是Linux下多路复用IO接口select/poll的增强版本,它能显著的 ...

  7. Windows XP SP3下编译安装check-0.10.0

    软件环境:visual studio 2010 cmake-3.6.3-win32-x86 从github.com下载check-0.10.0到本地,解压出目录check-0.10.0 下载cmake ...

  8. Ubuntu 16.04源码编译安装nginx 1.10.0

    一.下载相关的依赖库 pcre 下载地址 http://120.52.73.43/jaist.dl.sourceforge.net/project/pcre/pcre/8.38/pcre-8.38.t ...

  9. Linux(CentOS6.5)下编译安装Nginx官方最新稳定版(nginx-1.10.0)

    注:此文已经更新为新版:http://comexchan.cnblogs.com/p/5815753.html ,请直接查看新版,谢谢! 本文地址http://comexchan.cnblogs.co ...

随机推荐

  1. maven下拉项目不能同步

    maven下拉项目不能同步,如下图: 解决方法: 对项目右键,team, 选择这里 我选择第一项,有的需要根据情况选择第二项,如果点击完成后,还是不能同步代码,对项目右键,team,disconnec ...

  2. RabbitMQ学习在windows下安装配置

    RabbitMQ学习一. 在windows下安装配置 1.下载并安装erlang,http://www.erlang.org/download.html,最新版是R15B01(5.9.1).由于我机器 ...

  3. 282 expression and operations添加运算符

    [抄题]: 给定一个仅包含数字 0 - 9 的字符串和一个目标值,返回在数字之间添加了 二元 运算符(不是一元)+, - 或 * 之后所有能得到目标值的情况. "123", 6 - ...

  4. Halcon中xld的常见特征的含义总结

    如下图:

  5. 洛谷 P3660 [USACO17FEB]Why Did the Cow Cross the Road III G(树状数组)

    题目背景 给定长度为2N的序列,1~N各处现过2次,i第一次出现位置记为ai,第二次记为bi,求满足ai<aj<bi<bj的对数 题目描述 The layout of Farmer ...

  6. 启动项目报错:502 Server dropped connection The following error occurred while trying to access http://localhost:8080/TestDemo:

    之前的项目一直是好的,可以启动,但最近启动出了问题,访问不了,于是找到原因发现是启用了访问国外网站的加速器, 更改了浏览器的代理模式,如下: 解决方法: 打开浏览器,进入到浏览器的网络设置中,将局域网 ...

  7. PostgreSQL CPU满(100%)性能分析及优化

    业务场景:大批量更新时,数据库长时间CPU占用超过90,影响其他正常业务流程,参考阿里云上的一篇文章:https://help.aliyun.com/knowledge_detail/43562.ht ...

  8. canvas里调用getImageData的报security的问题

    canvas元素支持绘制任意图片元素: var ctx = document.getElementById("canvas").getContext("2d") ...

  9. 超详细JSON解析步骤

    JSON简介 JAVAScript Object Notation是一种轻量级的数据交换格式 具有良好的可读和便于快速编写的特性. 业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了 ...

  10. [Selenium With C#基础教程] Lesson-03 超级链接

    作者:Surpassme 来源:http://www.jianshu.com/p/83809943e751 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 超级链接或链接是We ...