zoukankan      html  css  js  c++  java
  • 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()方法。
       























  • 相关阅读:
    6.00 Introduction to Computer Science and Programming lec5: Objects in Python
    6.00 Introduction to Computer Science and Programming lec3 & lec4
    DB2中查询表信息
    修改 unity “显示桌面”快捷键的方法 (Ubuntu 12.10)
    Ubuntu 12.10中阻止启动chrome时“unlock default keyring ...”弹出窗口的方法
    6.00 Introduction to Computer Science and Programming lec1
    Thinkpad T61显卡门的解决(更换集成显卡的主板)
    Ubuntu 12.10中安装Sun的JDK
    【设计模式】抽象工厂
    【设计模式】概述
  • 原文地址:https://www.cnblogs.com/shy-huiying/p/5636274.html
Copyright © 2011-2022 走看看