您的位置:首页 > 理论基础 > 计算机网络

用JAVA实现网络数据包嗅探

2016-06-22 11:07 387 查看


用JAVA实现网络数据包嗅探

网络嗅探可是说是网络开发的一个基础,SNIFFER、IDS都是在这个基础上开发的,一个提供了网络分析,一个提供了入侵检测。实现一个网络嗅探程序到底有多难呢?可以很复杂,也可以很简单。在WINDOWS平台下,大多依靠的是WINPCAP,如果你觉得还复杂,那就再封装。JAVA就把它封装成了JPCAP,就是在WINPCAP的DLL基础上又提供了几个包(JAR),你只要引入你的包,创建包中的对象,引用人家的方法就好了。下面是一个很简单的例子,嗅探进入192.168.10.206的HTTP数据包的源地址、长度和二进制数据,并记录到out.txt文件中:

过程很简单,建立PacketCapture对象,lookupDevices发现本地网卡设备,打开其中一个,设置过滤条件,加入监听器,然后在监听程序中判断包格式,把源地址、长度和包数据写入文件。但是要说道原理就复杂多了,那要看网络的书了,各种协议的格式等等。总之有DLL的支援,JAVA的封装,留给我们的就是照猫画虎了。懂如何抓包的么?不懂!但是我可以抓到包并且分析之!这就够了。

import net.sourceforge.jpcap.capture.*;

import net.sourceforge.jpcap.net.*;

import java.util.*;

import java.io.*;

public class mycap implements PacketListener{

    public static FileOutputStream  fos = null;

    private static final String FILTER = "dst host 192.168.10.206 and proto TCP and src port 80";

    public static void main(String[] args)throws Exception{

    int default_num = 1;

     PacketCapture pcap = new PacketCapture();

     String[] capDevices = pcap.lookupDevices();

     pcap.open( (new StringTokenizer(capDevices[default_num],"\n")).nextToken(),true );

     pcap.setFilter(FILTER, true);

     fos = new FileOutputStream("out.txt");

     mycap t1= new mycap();

     pcap.addPacketListener(t1);

     pcap.capture(-1);

    }

   

     public void packetArrived(Packet packet) {

        try{

           if(packet instanceof TCPPacket){

               TCPPacket mytcppacket = (TCPPacket)
packet;

                fos.write("\n-----------------------------------------------------\n".getBytes());

               fos.write((mytcppacket.getSourceAddress()+"\t\t"+mytcppacket.getLength()+"\n").getBytes());

             
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: