当前位置:  技术问答>linux和unix

Linux下抓包问题 请做过的指点指点 谢谢

    来源: 互联网  发布时间:2016-11-15

    本文导语:    毕设要做一个在linux下抓包加协议分析的工具。希望做过的前辈们能指点指点,谢谢。 问题:   1 图形化界面用什么,qt吗?linux下我只编过命令行的程序,要是用qt的话都需要安装什么,配置什么?对linux版本有...

  毕设要做一个在linux下抓包加协议分析的工具。希望做过的前辈们能指点指点,谢谢。

问题:
  1 图形化界面用什么,qt吗?linux下我只编过命令行的程序,要是用qt的话都需要安装什么,配置什么?对linux版本有要求吗?会不会发生我在这个linux系统开发完换个别的linux系统就运行不了了的问题呀?
  
  2 抓包用什么方法? 我知道的有socket和libpcap,我想问socket是只能捕获到ip层以上的数据包吗?我想要捕获所有的tcp/ip协议族的数据包应该用什么方法?
  
  3 大家给推荐几本这方面的书,例如socket和libpcap编程的,和图形化界面开发的。

重点是第二个问题,最好能具体说说数据包如何从网卡到你自己定义的缓冲区,程序员在这个过程都需要做什么,而操作系统又做了什么。

|
1 图形化界面用什么,qt吗?linux下我只编过命令行的程序,要是用qt的话都需要安装什么,配置什么?对linux版本有要求吗?会不会发生我在这个linux系统开发完换个别的linux系统就运行不了了的问题呀?

第一个问题qt可以和c结合,c的语言你可以用extern "c"这种来修饰,编译;
   
  2 抓包用什么方法? 我知道的有socket和libpcap,我想问socket是只能捕获到ip层以上的数据包吗?我想要捕获所有的tcp/ip协议族的数据包应该用什么方法?
   
linux的内核里面是支持抓取数据包的.你捕获了数据包后要自己解析,把socket设置成混杂模式就可以了.如果感觉实现比较复杂就可以用winpcap工具来实现,具体要查winpcap的使用手册
给你点抓取ip数据包的代码
int main(void)
{
        int sockfd;
        struct ip *ip;
        char buf[100], sip[INET_ADDRSTRLEN], dip[INET_ADDRSTRLEN];
        ssize_t n;
        /* capture ip datagram without ethernet header */
        if ((sockfd = socket(PF_PACKET, SOCK_DGRAM, htons(ETH_P_IP))) == -1)
                err_sys("socket");
        while (1) {
                if ((n = read(sockfd, buf, sizeof(buf))) == -1)
                        err_sys("read");
                ip = (struct ip *)buf;
                if (inet_ntop(AF_INET, &ip->ip_src, sip, sizeof(sip)) == NULL)
                        err_sys("inet_ntop");
                if (inet_ntop(AF_INET, &ip->ip_dst, dip, sizeof(dip)) == NULL)
                        err_sys("inet_ntop");
                printf("sip: %s  dip: %srn", sip, dip);
        }
        exit(0);
}
void err_sys(const char *errmsg)
{
        perror(errmsg);
        exit(1);
}



  3 大家给推荐几本这方面的书,例如socket和libpcap编程的,和图形化界面开发的。
http://topic.csdn.net/t/20061218/17/5239135.html
这个链接也写了相关的代码,你可以试试看.

|
1.一般是使用QT或GTK2。,前者使用起来比较方便,Nokia的文档写的也很好。配置什么的你上网一搜就行了。不建议用RedHat,QT4支持不好,用Ubuntu或Federa都行。
2.我只用过wireshark,还有命令行的工具tcpdump,据说也不错。
3.抓包的话看你的效率要求了,一般libpcap足够,否则要用涉及底层的东西,也有,忘记叫什么了。


|
1:Qt是可以的。
2:libpcap应该可以,linux上的wireshark就是基于libpcap的,windows上的是基于winpcap的。http://www.tcpdump.org/ 上Documentation上有例子,很简单就可以实现抓到包。
3:http://www.tcpdump.org/  看看这个地址上的Documentation,有教libpcap怎么用的。

|
图形界面 
C++ 用Qt
C   用GTK+

配置自己慢慢整,不会就google

|
qt是可以的,请先确定课题是否一定要界面,参考http://qt.nokia.com/title-cn

Sniffer和wireshark都是常见的抓包工具,可以参考它们的源码


    
 
 

您可能感兴趣的文章:

  • 关于Linux中romfs的问题,请高手指点指点
  • 菜鸟求救:在linux下安装jdk失败。初次使用linux,还请各路大虾指点指点,不甚感激!!!
  • 我的linux的安装问题,请大家给指点指点。多谢了!!!
  • 求高手指点,arm-linux
  • Linux 安装开发环境报错 求指点
  • 请各位使用过Linux的进来看看,指点指点(在线等待)! 谢谢
  • Linux的嵌入式开发,请高手指点
  • 我的linux的安装问题,请大家给指点指点。多谢了!!! iis7站长之家
  • linux内核里面的所有头文件,有没有整理过的,请高手指点!谢谢!!!
  • 如何运程控制 linux 请高手指点。
  • 何运程控制 linux 请高手指点。
  • 想走嵌入式linux设备驱动方向,请多指点
  • 请指点: 在windows下能否通过程序来获取linux下的用户列表,甚至通过自己写的windows程序界面增加修改linux的用户
  • 板载AC97声卡的驱动问题,望Linux 高手指点
  • linux平台下面,能同时支持php,asp吗,如果可以,能不能详细指点。 在线等候!
  • 请linux的gnome开发高手指点
  • 关于在VMware下安装linux,请高手指点,先谢过!
  • 下一步该学习linux/unix的什么?请高手指点……
  • 有关linux这方面的应用和发展方向有哪位高手可以指点我一下!!!
  • linux下如何执行project文件,高人指点。
  • 我们知道内核源代码文件都放在/linux下,但目录/linux的绝对路径是啥?谢谢!
  • 想使用Kliyx把Delphi写的代码编译为Linux程序, 装什么Linux什么版本最好?请明人指教,谢谢!?
  • 菜鸟问题:怎样创建一个对所有文件只有只读权限的linux帐号,谢谢!
  • 请大虾推荐Linux内核,驱动等方面的好书!谢谢
  • linux里面的所有头文件,有没有整理过的,发一份,谢谢!!!
  • 求linux C++的时间相关函数及用法,急用,谢谢
  • 谁能说说Linux的类库啊?(谢谢了,^_^)
  • 想好好学linux操作系统,请大家帮忙推荐本入门的好书,谢谢
  • 想装个linux,先弄白几个问题。谢谢!
  • 哪位高人能够向我推荐一本如何学习linux编程的书籍,谢谢!
  • 怎么装linux最省钱啊??谢谢大虾指教!!
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Linux下时钟同步问题:Clock skew detected原因分析及解决方法
  • linux 繁体 汉字输入法 问题 linux 繁体 汉字输入法 问题
  • Linux 下c++开发error while loading shared libraries问题解决
  • 先安装linux,后安装winxp,能否解决正常启动linux的问题不?(初学者问题,很容易回答)
  • 弱弱的一问,linux下的中文问题及网络问题,分不是问题
  • Linux新手问,Linux安装问题。
  • linux下游戏问题。(菜鸟问题)
  • 初学Linux,发现Linux下的版本问题很头痛。【系列问题】
  • 高深问题:有了linux内核源代码如何做成一个linux操作系统
  • 一个很菜的问题,关ARM与linux内核裁剪的问题!
  • vmware装的linux,通过win2000访问linux的web服务器有问题
  • 初次接触linux,关于linux 用户权限问题请教!
  • Linux下是否存在磁盘碎片问题和内存碎片问题?
  • linux开发的应用程序部署到其他linux的问题
  • vmware上装LINUX的问题,WIN7可以拼的通linux的IP,linux拼不通win7的IP
  • Linux互ping在局域网内大量丢包,但是linux和windows互ping就没问题。
  • 最菜的问题—关于linux“动态库”的问题
  • linux下挂载linux分区的问题
  • 一个小问题。Linux下编程语言的问题。
  • linux问题 secureCRT连接的问题 在线等急!~~
  • Linux下环境变量问题以及FLEX安装问题
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3