JpCapWriter崩溃了JVM

时间:2012-10-26 14:13:59

标签: crash jvm writer jpcap

当我尝试使用JpCap Writer将数据包保存到文件时,会导致JVM崩溃。

代码:

captor=JpcapCaptor.openDevice(interfaceList[interfaceNumber], 65535, true, 20);
captor.setFilter("ip and tcp",true);


JpcapWriter writer=JpcapWriter.openDumpFile(captor,"write.txt");
for(int i=0;i<10;i++){
    Packet packet=captor.getPacket();
    writer.writePacket(packet);
  }
writer.close();

崩溃信息:

#
# A fatal error has been detected by the Java Runtime Environment:
#
#  SIGSEGV (0xb) at pc=0x00007f283105953a, pid=3060, tid=139810797537024
#
# JRE version: 6.0_24-b24
# Java VM: OpenJDK 64-Bit Server VM (20.0-b12 mixed mode linux-amd64 compressed oops)
# Derivative: IcedTea6 1.11.4
# Distribution: Ubuntu 12.04 LTS, package 6b24-1.11.4-1ubuntu0.12.04.1
# Problematic frame:
# v  ~BufferBlob::jni_fast_GetLongField
#
# An error report file with more information is saved as:
# /root/workspace/Sniff/hs_err_pid3060.log
#
# If you would like to submit a bug report, please include
# instructions how to reproduce the bug and visit:
#   https://bugs.launchpad.net/ubuntu/+source/openjdk-6/
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#

知道怎么解决吗?或以TCPDump格式保存数据包的任何其他替代方法?

1 个答案:

答案 0 :(得分:0)

我看到你对我的问题的评论。我遇到了同样的问题,这是因为我在关闭后关闭了编写器。你可能会在不知不觉中关闭它。检查您的代码,并了解删除writer.close();对您的影响。

如果您不需要操作数据包,我建议您使用Wireshark。它可以很容易地将数据包捕获为TCPDump并添加捕获过滤器。