c++-关于pcap_dump_close出现Segmentation fault

问题描述

关于pcap_dump_close出现Segmentation fault

最近在维护上届学长的一个应用协议识别毕业设计项目。很大一部分内容使用C++写的。其中有个协议的过滤,之前一直使用挺好的,但是数据只要超过30M就出现Segmentation fault(core dump)错误。
使用gdb查看的信息如下:
其中main.cpp内容如下:
这个方法的主要作用就是从一个流文件(pcap格式,经过协议识别处理后,每一条流记录都由一个特殊的数据报文头表示,其中32字节代表一种应用协议的编号)读取某种应用协议的数据报文然后再写入到一个pcap中去。这样子就将某种协议的数据报文给过滤出来了。
由于之前一直都只在做java和php的东西,C++这些可以看得懂,但是很少能写。周边的同学也基本上都不怎么会C++, 恳请有会的给出个大致解决思路。谢谢了。

 //读取流文件并处理
void readFile(string &flowDir, string &confDir, string &rstDir, string &application)
{
    //定义类Compute
    Fliter *fliter = new Fliter(flowDir, confDir, rstDir, application);

    //将目录下的所有文件名存放到文件ls.txt中
    string cmd = "ls " + flowDir + " >ls.txt";
    system(cmd.c_str());
    ifstream files("ls.txt");
    assert(files);

    string pcapdir = rstDir + "pcap/";
    string creatdir_cmd = "mkdir " + rstDir + "pcap";
    system(creatdir_cmd.c_str());

    pcap_dumper_t *pp_write = NULL;
    char pcapFile[256];
    sprintf(pcapFile, "%s%s.pcap", pcapdir.c_str(), application.c_str());
    cout <<"pcap file:" <<pcapFile <<endl;

    //依次读取文件
    u_llong fileNum = 0;
    while(!files.eof())
    {
        //获取文件名
        string filename;
        getline(files, filename);
        if(filename.empty()) break;
        string inFile = flowDir + filename;
        cout <<"read file:" <<inFile <<endl;
        fileNum++;

        //打开pcap文件
        char errbuf[128];
        pcap_t *pp_read_flow = pcap_open_offline(inFile.c_str(), errbuf);
        assert(pp_read_flow);
        pcap_t *pp_read_pack = pcap_open_offline(inFile.c_str(), errbuf);
        assert(pp_read_pack);

        //读pcap文件
        struct pcap_pkthdr ppHdr;   //pcap数据包头,16字节
        const u_char *pkt;

        while((pkt = pcap_next(pp_read_flow, &ppHdr)) != NULL)
        {
            if(0 == ppHdr.ts.tv_sec) //此条数据为流记录
            {
                // 对应协议与提交任务一致
                // pkt[31]处存放的协议号
                if((*(u_short*)&pkt[31]) == fliter->convert_application(application))
                {
                    if(pp_write == NULL)    pp_write = pcap_dump_open(pp_read_flow, pcapFile);
                    assert(pp_write);
                    pcap_dump((u_char*)pp_write, &ppHdr, pkt);
                    while((pkt = pcap_next(pp_read_pack, &ppHdr)) != NULL)
                    {
                        if(ppHdr.ts.tv_sec != 0)
                        {
                            pcap_dump((u_char*)pp_write, &ppHdr, pkt);
                        }
                        else
                            // 到达了下一条流记录
                            break;
                    }
                }

            }
        }
        pcap_close(pp_read_flow);
        pcap_close(pp_read_pack);
    }
**  pcap_dump_close(pp_write);** //  第94行
    files.close();
    cout <<"ntotal files:" <<fileNum <<endl;
}

解决方案

设置一下堆栈大小,使用ulimit设置

时间: 2025-01-21 15:50:47

c++-关于pcap_dump_close出现Segmentation fault的相关文章

【Oracle】安装完oracle 9i,执行sqlplus 遇到Segmentation Fault

安装完成oracle 9.2.0.4之后,执行sqlplus 命令时遇到Segmentation Fault 错误,查询 Metalink 是一个bug:Segmentation Fault When Execute Sqlplus, Oracle, Lsnrctl After New/Patchset Install [ID 316746.1] 对于新安装的软件或者打过补丁的oracle数据库(9.2.0.1 to 10.1.0.2,for Linux x86,Linux x86-64)都可能

oracle 9.2.0.8 exp导出dmp导入报Segmentation fault/段错误故障解决

在9.2.0.8 rac环境中,使用exp导出来dmp文件任何报错(按单个表,按用户导出,使用tns方式远程exp导出),包括重启数据库后导出,无法导入到其他数据库中(本库,tns方式远程导入,ftp传输到远程导入,9i/10g/11g版本)报错类似有setillegal instruction(coredump),段错误,Segmentation fault等,以下列出来几个报错信息--导入11.2.0.2版本 Import: Release 11.2.0.2.0 - Production o

c语言-C语言segmentation fault?

问题描述 C语言segmentation fault? #include main(){ int M, N, T, S[M][N], B; scanf("%d%d%d", &M, &N, &T); int i, j; for (i=0;i<M;i++){ for (j=0;j<N;j++){ scanf("%d",&S[i][j]); }; }; if (T == 0){ for (i=0;i<M;i++){ for

指针-么么哒、这题用C语言为什么出现Segmentation fault,求解释并纠错(谢绝新代码)

问题描述 么么哒.这题用C语言为什么出现Segmentation fault,求解释并纠错(谢绝新代码) //依次输出字符串中的数字团,比如poq89ayu1u&129aa //就输出89,129,一共2个数. //萌妹纸诚心诚意求修改 include int main() { char str[80],*pstr; int i=0,flag=1,num=0;pstr=str; gets(str); while(flag==1) { for(i=0;(str+i)!='';i++) { if('

c-C语言输出数字团,代码为什么出现Segmentation fault,求解释并纠错??

问题描述 C语言输出数字团,代码为什么出现Segmentation fault,求解释并纠错?? //题目:输出字符串里数字团,以及个数.比如89cy129 //就输出89,129,一共2个数. 代码在这个百度知道的问题上:well,看来百度知道上面没有人会做? 跪谢!!! 源代码: include int main() { int a[80],i=0,*pa,an=0; char str[80],*pstr=str; void getnum(char pstr); gets(str); get

c++-Segmentation fault问题

问题描述 Segmentation fault问题 //c语言实现输入任意长度的字符串#include #include int main (void ){char *string = NULL *temp = NULL;char ch;int i;//先将字符串初始化为空string = (char *)malloc(1);string[0] = '';//len为实际长度(包括空字符)int len = 1;while ((ch = getchar())!= 'n'){ //申请一个新字符串

iostream-C++ 使用sort()函数 出现segmentation fault

问题描述 C++ 使用sort()函数 出现segmentation fault #include <iostream> #include <algorithm> using namespace std; int main() { int n,m,k; int set=1; int *ptr=nullptr; int nm; int i; while(cin>>n>>m>>k) { if(n<1||n>10|| m<1||m&g

segmentation-justniffer Segmentation fault

问题描述 justniffer Segmentation fault 使用sourceforge的justniffer出现了这个问题,本人不懂C方面的,请教这种问题怎么解决: justniffer.sh: line 7: 28769 Segmentation fault justniffer -l "%source.ip , %dest.ip , %connection.time(0) , %request.timestamp , %response.time(0) , %response.si

execute copyed function code : Segmentation fault

函数在C里面可以认为是指针, 但是又有特殊的一面. 如 调用 函数test 时, *test, test, &test 可以相互通用. 因为它们都指向同一个地址. 如 :  [root@db-172-16-3-150 zzz]# cat a.c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> typedef unsigned char byt