Jpcap使用指南

1.    获取网络接口列表

要想从网络中捕获数据包,第一件必须要做的事就是获取本机的网络接口列表。

Jpcap提供了方法JpcapCaptor.getDeviceList()完成这个任务,该方法返回一组NetworkInterface对象。

NetworkInterface接口对象包含了对应网络接口的一些信息,例如:名称、描述、IP以及MAC地址以及数据链路层名称和描述。

  1. import jpcap.JpcapCaptor;
  2. import jpcap.NetworkInterface;
  3. import jpcap.NetworkInterfaceAddress;
  4. public class TCPCollection {
  5. public static void main(String[] args){
  6. NetworkInterface[] devices = JpcapCaptor.getDeviceList();//获取网络接口列表
  7. for(int i = 0; i < devices.length; i++){
  8. //名称、描述
  9. System.out.println(i + ":" + devices[i].name + "(" + devices[i].description + ")");
  10. //数据链路层名称、描述
  11. System.out.println("datalink:" + devices[i].datalink_name + "(" + devices[i].datalink_description + ")");
  12. //MAC地址
  13. System.out.print(" MAC address:");
  14. for(byte b: devices[i].mac_address){
  15. System.out.print(Integer.toHexString(b & 0xff) + ":");
  16. }
  17. System.out.println();
  18. //IP地址、子网掩码、广播地址
  19. for(NetworkInterfaceAddress a : devices[i].addresses){
  20. System.out.println(" address: " + a.address + "|" + a.subnet + "|" + a.broadcast);
  21. }
  22. }
  23. }
  24. }

2.    打开网络接口

一旦有了网络接口列表就可以从选定用于捕获数据包的网络接口,可以使用方法JpcapCaptor.openDevice()来打开网络接口。

  1. public static void main(String[] args){
  2. NetworkInterface[] devices = JpcapCaptor.getDeviceList();//获取网络接口列表
  3. int index = 0;
  4. try {
  5. JpcapCaptor captor = JpcapCaptor.openDevice(devices[index], 65535, false, 20);
  6. } catch (IOException e) {
  7. e.printStackTrace();
  8. System.out.println("抓取数据包时出现异常!!!");
  9. }
  10. }

调用JpcapCaptor.openDevice()方法必须指定下列参数:

名称                                   目的

NetworkInterderface       要打开的网络接口。

intrface                              

int
snaplen                       
一次捕获数据包的最大byte数。

boolean
prommics         
是否采用混乱模式

混乱模式中,可以捕获所有数据包,即便源MAC或目的MAC地址与打开的网络接口的MAC地址不相同。

而非混乱模式中只能捕获由宿主机发送和接收的数据包。

int
to_ms                         
捕获的数据包的超时设置(数量级为毫秒)。

3.    从网络接口捕获数据包

一旦获得了JpcapCaptor实例就可以用来捕获来自网络接口的数据包。

使用JpcapCaptor实例来捕获数据包主要有两种方法:回调(callback)以及逐个捕获(one-by-one)。

回调方法

实现的细节:

首先定义一个实现PacketReceiver接口的类。PacketReceiver接口中定义了receivePacket()方法,只需实现receivePacket()这个方法。

  1. class PacketPrinter implements PacketReceiver {
  2. //this method is called every time Jpcap captures a packet
  3. public void receivePacket(Packet packet){
  4. System.out.print(packet);
  5. }
  6. }

然后可以使用回调的方法调用JpcapCaptor.processPacket()或JpcapCaptor.loopPacket()方法开始数据包的捕获。

processPacket()或loopPacket()方法可以指定捕获的数据包的数量。-1表示无限地捕获数据包。

  1. JpcapCaptor captor = JpcapCaptor.openDevice(devices[index], 65535, false, 20);
  2. captor.processPacket(2, new PacketPrinter());
  3. captor.close();

两种回调方法:processPacket()和loopPacket()非常相似。通常建议使用processPacket(),因为它支持超时以及非阻塞模式,而loopPacket()并不支持。

逐个捕获

使用回调方法稍微有点复杂,因为并不知道Jpcap什么时候调用回调方法。如果不使用回调方法,可以调用JpcapCaptor.getPacket()方法来捕获数据包。

getPacket()只是简单返回一个捕获的数据包,可以多次使用getPacket()方法捕获连续的数据包。

  1.             JpcapCaptor captor = JpcapCaptor.openDevice(devices[index], 65535, false, 20);
  2. for(int i=0; i<10; i++){
  3. System.out.println(i + ":" + captor.getPacket());
  4. }
  5. captor.close();

4.    设置捕获过滤器

在Jpcap中可以设置过滤器使得Jpcap不捕获不需要的数据包。例如:如果仅仅只需捕获TCP/IPv4数据包,就可以设置过滤器,其方法如下例所示:

  1. JpcapCaptor captor = JpcapCaptor.openDevice(devices[index], 65535, false, 20);
  2. captor.setFilter("ip and tcp", true);

过滤器表达式“ip and tcp”表示“只保留IPv4并且TCP数据包,并将其交付给应用”。过滤器的设置可以减少所需要处理的数据包并且提高应用的性能。

5.    将捕获的数据包存挡

可以将捕获的数据包写入一个二进制文件,事后使用Jpcap或支持tcpdump格式文件的其它应用程序进行查询。

存储捕获的数据包首先需要使用JpcapWriter.openDumpFile()打开一个文件,参数分别是用来捕获数据包的一个JpcapCaptor实例以及String文件名。

  1. JpcapCaptor captor = JpcapCaptor.openDevice(devices[index], 65535, false, 20);
  2. JpcapWriter writer = JpcapWriter.openDumpFile(captor, "yourfilename");

一旦通过openDumpFile()方法获得一个JpcapWriter的实例,就可以使用JpcapWriter.writePacket()存储捕获的数据包。

将所有要存储的数据都存储之后,必须使用JpcapWriter.close()方法关闭打开的文件。

  1. for(int i=0; i<10; i++){
  2. Packet packet = captor.getPacket();
  3. writer.writePacket(packet);
  4. }
  5. writer.close();

6.    读入文件中的数据包

在Jpcap中,可以使用JpcapCaptor.openFile()方法打开一个由JpcapWriter存储的文件,并从中读入数据包。

类似于JpcapCaptor.openDevice()方法,JpcapCaptor.openFile()方法将返回一个JpcapCaptor类的实例,因此可以使用“从网络接口捕获数据包”中描述的方式来从文件中读取数据包。

7.    通过网络接口发送数据包

发送一个数据包首先需要调用JacapSender.openDevice()或JacapSender.getJpcapSenderInstance()方法。

一旦获得一个JpcapSender实例,就可以将Packet类实例传递给JpcapSender.sendPacket()方法。

来自为知笔记(Wiz)

时间: 2024-08-24 20:58:53

Jpcap使用指南的相关文章

最全解析如何正确学习JavaScript指南,必看!

划重点 鉴于时不时,有同学私信问我:怎么学前端的问题.这里统一回复一下,如下次再遇到问我此问题同学,就直接把本文链接地址发给你了. "前端怎么学"应该因人而异,别人的方法未必适合自己.就说说我的学习方法吧:我把大部分时间放在学习js上了.因为这个js的学习曲线,先平后陡.项目实践和练习啥的,我不说了,主要说下工作之外的时间利用问题.我是怎么学的呢,看书,分析源码.个人这几天统计了一下,前端书籍目前看了50多本吧,大部分都是js的.市面上的书基本,差不多都看过. 第一个问题:看书有啥好处

微信Android接入指南

注:本文为微信Android终端开发工具的新手使用教程,只涉及教授SDK的使用方法,默认读者已经熟悉IDE的基本使用方法(本文以Eclipse为例),以及具有一定的编程知识基础等. 1.申请你的AppID 请到 开发者应用登记页面 进行登记,登记并选择移动应用进行设置后,将该应用提交审核,只有审核通过的应用才能进行开发. 2.下载微信终端开发工具包 开发工具包主要包含3部分内容:(其中,只有libammsdk.jar是必须的) - libammsdk.jar(每个第三方应用必须要导入该sdk库,

【资源共享】Rockchip I2C 开发指南 V1.0

2C设备的设备应用非常广泛,常见的包含重力传感器,触摸屏驱动芯片,音频解码等 这个文档是RK3399的I2C开发文档:<Rockchip I2C 开发指南 V1.0> 内容预览: 下载地址:http://developer.t-firefly.com/thread-12495-1-1.html

Spark性能优化指南——高级篇

Spark性能优化指南--高级篇 [TOC] 前言 继基础篇讲解了每个Spark开发人员都必须熟知的开发调优与资源调优之后,本文作为<Spark性能优化指南>的高级篇,将深入分析数据倾斜调优与shuffle调优,以解决更加棘手的性能问题. 数据倾斜调优 调优概述 有的时候,我们可能会遇到大数据计算中一个最棘手的问题--数据倾斜,此时Spark作业的性能会比期望差很多.数据倾斜调优,就是使用各种技术方案解决不同类型的数据倾斜问题,以保证Spark作业的性能. 数据倾斜发生时的现象 绝大多数tas

&quot;WannaCry&quot;勒索病毒用户处置指南

"WannaCry"勒索病毒用户处置指南 原文: http://mp.weixin.qq.com/s/ExsribKum9-AN1ToT10Zog 前言:北京时间2017年5月12日晚,勒索软件"WannaCry"感染事件爆发,全球范围内99个国家遭到大规模网络攻击,被攻击者电脑中的文件被加密,被要求支付比特币以解密文件:众多行业受到影响,比如英国的NHS服务,导致至少40家医疗机构内网被攻陷,电脑被加密勒索:而我国众多行业也是如此,其中又以教育网最为显著,导致部分

servlet和jsp学习指南(一)servlet

近期接触了些纯servlet与jsp的编程项目,顺便把<servlet和jsp学习指南>这本书拿出来看看,感悟良多.记下随笔,以便会议. 要编写一个servlet首先要实现Servlet或者继承HttpServlet package test.com.servlet; import java.io.IOException; import javax.servlet.Servlet; import javax.servlet.ServletConfig; import javax.servlet

Quartz.NET简介及入门指南

Quartz.NET简介 Quartz.NET是一个功能完备的开源调度系统,从最小的应用到大规模的企业系统皆可适用. Quartz.NET是一个纯净的用C#语言编写的.NET类库,是对非常流行的JAVA开源调度框架 Quartz 的移植. 入门指南 本入门指南包括以下内容: 下载 Quartz.NET 安装 Quartz.NET 根据你的特定项目配置 Quartz 启动一个样例程序 下载和安装 你可以下载 zip 文件或使用 Nuget 程序包.Nuget 程序包只包含 Quartz.NET 运

有奖试读—Windows PowerShell实战指南(第2版)

为什么要学PowerShell? Windows用户都已习惯于使用图形化界面去完成工作,因为GUI总能轻易地实现很多功能,并且不需要记住很多命令.使得短时间学会一种工具成为可能. 但是不幸的是,GUI并不能带来效率提升上的汇报,如果你花费5分钟在活动目录中创建一个新的用户(一般需要填写大量信息),之后再新建用户时,通常不会更快,那么新建100个新用户就会花费500分钟,通常没有任何办法使得我们输入信息以及单击操作更快,从而加快这个过程. 微软一直都有CMD命令来进行Windows的操作,但是很不

Java程序员的Golang入门指南(上)

Java程序员的Golang入门指南 1.序言 Golang作为一门出身名门望族的编程语言新星,像豆瓣的Redis平台Codis.类Evernote的云笔记leanote等. 1.1 为什么要学习 如果有人说X语言比Y语言好,两方的支持者经常会激烈地争吵.如果你是某种语言老手,你就是那门语言的"传道者",下意识地会保护它.无论承认与否,你都已被困在一个隧道里,你看到的完全是局限的.<肖申克的救赎>对此有很好的注脚: [Red] These walls are funny.