为什么我在下面的程序中得到UnsatisfiedLinkError?

问题描述:

Error is :Exception in thread "main" java.lang.UnsatisfiedLinkError: 
    jpcap.JpcapCaptor.getDeviceList()[Ljpcap/NetworkInterface; at 
    jpcap.JpcapCaptor.getDeviceList(Native Method) at 
    jcap.network.main(network.java:63) 

import jpcap.*; 
import jpcap.packet.*; 
import java.io.*; 
import jpcap.packet.TCPPacket.*; 
import java.io.*; 
import jpcap.JpcapCaptor.*; 


class Network implements PacketReceiver { 
    System.out.println(System.getProperty("java.library.path")); 
    String sp=null; 
    String dp=null; 
    String window=null; 
    String sequence=null; 
    String acknowledge=null; 
    FileWriter ff=null; 
    String da=null; 

    public void receivePacket(Packet pt) { 
     try { 
      if(pt instanceof TCPPacket) { 
       TCPPacket tp=(TCPPacket)pt; 
       ff=new FileWriter("da.txt",true); 
       sp=new Integer(tp.src_port).toString(); 
       dp=new Integer(tp.dst_port).toString(); 
       window=new Integer(tp.window).toString(); 
       sequence=new Long(tp.sequence).toString(); 
       acknowledge=new Long(tp.ack_num).toString(); 
       byte[]dat=tp.data; 
       da=new String(dat); 
       ff.write("\r\n Source port is :-"+sp);  
       ff.write("\r\n Desination port is:-"+dp); 
       ff.write("\r\n Sequence no is:-"+sequence); 
       ff.write("\r\n Acknowledgement no is:-"+acknowledge); 
       ff.write("\r\n Status of rsv1 flag is:-"+tp.rsv1); 
       ff.write("\r\n Status of rsv2 flag is:-"+tp.rsv2); 
       ff.write("\r\n Status of Syn flag is:-"+tp.syn); 
       ff.write("\r\n Status of Urg flag is:-"+tp.urg); 
       ff.write("\r\n Status of Fin flag is:-"+tp.fin); 
       ff.write("\r\n Data :-"+da); 
       ff.write("\r\n"); 
       ff.write("\r\n"); 
       ff.close(); 
      }     
     } catch(Exception e) { 
      System.out.println(e.getMessage()); 
     } 
    } 

    public static void main(String args[])throws IOException { 
     int i;   
     try { 
      NetworkInterface[] devices = JpcapCaptor.getDeviceList(); 

      //for each network interface 
      for (i = 0; i < devices.length; i++) { 
       //print out its name and description 
       System.out.println(i+": "+devices[i].name + "(" +  
         devices[i].description+")"+devices[i].loopback); 
       //print out its datalink name and description 
       System.out.println(" datalink: "+devices[i].datalink_name + "(" 
         + devices[i].datalink_description+")"); 

       //print out its MAC address 
       System.out.print(" MAC address:"); 
       for (byte b : devices[i].mac_address) 
        System.out.print(Integer.toHexString(b&0xff) + ":"); 
       System.out.println(); 

       //print out its IP address, subnet mask and broadcast address 
       for (NetworkInterfaceAddress a : devices[i].addresses) 
        System.out.println(" address:"+a.address + " " + a.subnet + " "+ 
          a.broadcast); 
      } 
      JpcapCaptor captor=JpcapCaptor.openDevice(devices[0], 65535, true, 20); 
      captor.loopPacket(-1,new Network()); 
      captor.close(); 
     } 
     catch(Exception e) { 
      System.out.println(e.getMessage()); 
     } 
    } 
} 
+1

必须是因为你的代码不是很好地缩进。 – 2013-02-22 16:25:14

+1

对代码块使用一致的逻辑缩进。代码的缩进旨在帮助人们理解程序流程。 – 2013-02-22 16:25:47

+0

也试图捕捉更具体的异常,永远不会抓住''(例外e)' – cIph3r 2013-02-22 16:26:13

UnsatisfiedLinkError的javadoc是非常简单的。你缺少一些需要的jcap的lib。

将来,javadocs是一个很好的开始,当你遇到你不了解的异常时。

UnsatisfiedLinkError意味着,“JpcapCaptor”本地库没有被加载,

static{ 
     System.loadLibrary("JpcapCaptor.dll"); 
} 
+0

_Francis P第63行is_'NetworkInterface [] devices = JpcapCaptor.getDeviceList(); ' – 2013-02-22 16:42:09

在你的机器上安装JPCAP然后尝试运行代码。 您可以从这里下载jpcap.exe文件http://jpcap.software.informer.com/0.7/

我完全编译和链接Jpcap(在Mac OS X计算机上使用eclipse)后出现同样的问题。原来有两个版本的Jpcap:https://github.com/jpcap/jpcap(没有JpCaptor),和一个JpCaptor版本:https://github.com/mgodave/Jpcap。也许这有帮助。

+0

虽然这个链接可能回答这个问题,但最好在这里包含答案的基本部分,并提供参考链接。如果链接页面更改,则仅链接答案可能会失效。 - [来自评论](/ review/low-quality-posts/10210688) – Zizouz212 2015-11-15 16:29:54

+0

@ Zizouz212 - 这不是一个链接专用的答案。它提供了对这个问题的解释,并将这些链接作为支持性证据。 – APC 2015-11-15 18:06:40