Java 未找到本机Lcom/slytechs/library/NativeLibrary的实现

Java 未找到本机Lcom/slytechs/library/NativeLibrary的实现,java,android,native-code,jnetpcap,Java,Android,Native Code,Jnetpcap,我正在Android项目中使用JNetPcap库: 我无法使用此代码访问本机应用程序,即使我将JNetPcap设置为该项目的库 有人能帮我吗?plz 我的代码如下: import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.SocketException; import java.net.UnknownHostException; impo

我正在Android项目中使用JNetPcap库: 我无法使用此代码访问本机应用程序,即使我将JNetPcap设置为该项目的库

有人能帮我吗?plz

我的代码如下:

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;
import java.net.UnknownHostException;
import java.util.List;

import org.jnetpcap.PcapIf;
import org.jnetpcap.packet.JMemoryPacket;
import org.jnetpcap.packet.JPacket;
import org.jnetpcap.protocol.JProtocol;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

public class Server_Android extends Activity{

    private final static int SERVER_PORT = 1234;
//    public final static int RECEIVING_TIMEOUT_SERVER = 3000;
    DatagramSocket socket;
    DatagramPacket packetOut;
    DatagramPacket packetIn;
    byte[] DataIn;
    byte[] DataOut;
    List<PcapIf> alldevs;
    StringBuilder errbuf;

    /*Android widgets*/
    TextView text;
    EditText edit;
    Button button;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_server_android);
        //text = (EditText)
        button =(Button)findViewById(R.id.button1);
        edit = (EditText)findViewById(R.id.editText1);
        text =(TextView)findViewById(R.id.textView2);   
        text.setText("");

        handlingpacket();

        /* Thread for receiving Data from CLient */
        new Thread(new Message_handler()).start();
            try {   
        Thread.sleep(500);
        reply();
        }catch(InterruptedException e){
            Log.e("UDP", "UDP receive failed!");
        }

    }

//  
    public void handlingpacket(){

        JPacket jmp = new JMemoryPacket(JProtocol.UDP_ID,
                  "001801bf 6adc0025 4bb7afec 08004500 "  
                + " 0041a983 40004006 d69ac0a8 00342f8c "  
                + " ca30c3ef 008f2e80 11f52ea8 4b578018 "  
                + " ffffa6ea 00000101 080a152e ef03002a "  
                + " 2c943538 322e3430 204e4f4f 500d0a");
        text.append("" + jmp);

    }
//  
    public class Message_handler implements Runnable{

            public Message_handler(){}

            public void run(){

            try {
                DataOut = new byte[1024];

            while(true){

                    socket = new DatagramSocket(SERVER_PORT);
                    socket.setReuseAddress(true);
                    socket.setBroadcast(true);
        //          socket.setSoTimeout(RECEIVING_TIMEOUT_SERVER);
                    packetIn = new DatagramPacket(DataOut,DataOut.length);          
                    socket.receive(packetIn);

                        runOnUiThread( new Runnable(){ // original thread for UI interactions

                                public void run(){
                                    String message = new String(packetIn.getData());
                                    text.append("Message " + message +"\n From :" + packetIn.getAddress() + " on port : "+  packetIn.getPort() +"\n");
                                    Log.d("UDP", "le message reçu");
                                    Log.d("Message : ", "" + message);  

                                }
                        });


                }
            }
                catch(UnknownHostException exc) {
                    exc.printStackTrace();
                }
                catch(SocketException exc) {
                    System.out.println("Problem openning socket");
                }
                catch(IOException exc) {
                    System.out.println("Problem in reception of messages");
                }

            socket.close();

            }

        }

        public void reply(){

            DataIn = new byte[1024];
            button.setOnClickListener( new Button.OnClickListener(){    

                    @Override
                    public void onClick(View v) {
                        // TODO Auto-generated method stub
                        try {

                        socket = new DatagramSocket(); 
                        String str = edit.getText().toString();
                        DataIn = str.getBytes();
                        packetOut = new DatagramPacket(DataIn, DataIn.length, packetIn.getAddress(), packetIn.getPort());
                        socket.send(packetOut);
                        }catch (SocketException e1) {
                            // TODO Auto-generated catch block
                            e1.printStackTrace();
                        }   
                         catch (IOException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                    }
                });

        }
}
import java.io.IOException;
导入java.net.DatagramPacket;
导入java.net.DatagramSocket;
导入java.net.SocketException;
导入java.net.UnknownHostException;
导入java.util.List;
导入org.jnetpcap.PcapIf;
导入org.jnetpcap.packet.JMemoryPacket;
导入org.jnetpcap.packet.JPacket;
导入org.jnetpcap.protocol.JProtocol;
导入android.app.Activity;
导入android.os.Bundle;
导入android.util.Log;
导入android.view.view;
导入android.widget.Button;
导入android.widget.EditText;
导入android.widget.TextView;
公共类服务器扩展活动{
专用最终静态int服务器_端口=1234;
//公共最终静态int接收超时服务器=3000;
DatagramSocket套接字;
数据包打包输出;
数据包包装;
字节[]数据输入;
字节[]数据输出;
列出所有开发者;
StringBuilder errbuf;
/*Android小部件*/
文本查看文本;
编辑文本编辑;
按钮;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\u server\u android);
//text=(编辑文本)
按钮=(按钮)findViewById(R.id.button1);
edit=(EditText)findViewById(R.id.editText1);
text=(TextView)findViewById(R.id.textView2);
text.setText(“”);
处理数据包();
/*用于从客户端接收数据的线程*/
新线程(新消息处理程序()).start();
试试{
睡眠(500);
答复();
}捕捉(中断异常e){
Log.e(“UDP”,“UDP接收失败!”);
}
}
//  
公共无效处理包(){
JPacket jmp=新的JMemoryPacket(JProtocol.UDP_ID,
“001801bf 6adc0025 4bb7afec 08004500”
+“0041a983 40004006 d69ac0a8 00342f8c”
+“ca30c3ef 008f2e80 11f52ea8 4b578018”
+“ffffa6ea 00000101 080a152e ef03002a”
+“2c943538 322e3430 204e4f4f 500d0a”);
text.append(“+jmp”);
}
//  
公共类消息\u处理程序实现可运行{
公共消息处理程序(){}
公开募捐{
试一试{
DataOut=新字节[1024];
while(true){
套接字=新的DatagramSocket(服务器端口);
socket.setReuseAddress(真);
插座。路演(真实);
//socket.setSoTimeout(接收服务器超时);
packetIn=newdatagrampacket(DataOut,DataOut.length);
插座。接收(打包);
runOnUiThread(新的Runnable(){//用于UI交互的原始线程
公开募捐{
字符串消息=新字符串(packetIn.getData());
text.append(“Message”+Message+”\n来自端口“+packetIn.getAddress()+”上的“+packetIn.getPort()+”\n”);
Log.d(“UDP”,“le message reçu”);
Log.d(“消息:”,“”+消息);
}
});
}
}
捕获(未知后异常exc){
exc.printStackTrace();
}
捕获(SocketException exc){
System.out.println(“打开插座的问题”);
}
捕获(IOException){
System.out.println(“消息接收问题”);
}
socket.close();
}
}
公开答覆({
数据输入=新字节[1024];
button.setOnClickListener(新建button.OnClickListener(){
@凌驾
公共void onClick(视图v){
//TODO自动生成的方法存根
试一试{
套接字=新的DatagramSocket();
String str=edit.getText().toString();
DataIn=str.getBytes();
packetOut=newdatagrampacket(DataIn,DataIn.length,packetIn.getAddress(),packetIn.getPort());
socket.send(packetOut);
}捕获(SocketException e1){
//TODO自动生成的捕捉块
e1.printStackTrace();
}   
捕获(IOE异常){
//TODO自动生成的捕捉块
e、 printStackTrace();
}
}
});
}
}
日志文件:

08-21 11:18:36.755: W/dalvikvm(776): No implementation found for native Lcom/slytechs/library/NativeLibrary;.dlopen (Ljava/lang/String;)J
08-21 11:18:36.755: W/dalvikvm(776): Exception Ljava/lang/UnsatisfiedLinkError; thrown while initializing Lorg/jnetpcap/nio/JMemory;
08-21 11:18:36.755: D/AndroidRuntime(776): Shutting down VM
08-21 11:18:36.755: W/dalvikvm(776): threadid=1: thread exiting with uncaught exception (group=0x40a2d1f8)
08-21 11:18:36.760: E/AndroidRuntime(776): FATAL EXCEPTION: main
08-21 11:18:36.760: E/AndroidRuntime(776): java.lang.ExceptionInInitializerError
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.example.server_android.Server_Android.handlingpacket(Server_Android.java:66)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.example.server_android.Server_Android.onCreate(Server_Android.java:50)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.app.Activity.performCreate(Activity.java:4465)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2033)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2104)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.app.ActivityThread.access$600(ActivityThread.java:132)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1157)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.os.Handler.dispatchMessage(Handler.java:99)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.os.Looper.loop(Looper.java:137)
08-21 11:18:36.760: E/AndroidRuntime(776):  at android.app.ActivityThread.main(ActivityThread.java:4575)
08-21 11:18:36.760: E/AndroidRuntime(776):  at java.lang.reflect.Method.invokeNative(Native Method)
08-21 11:18:36.760: E/AndroidRuntime(776):  at java.lang.reflect.Method.invoke(Method.java:511)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
08-21 11:18:36.760: E/AndroidRuntime(776):  at dalvik.system.NativeStart.main(Native Method)
08-21 11:18:36.760: E/AndroidRuntime(776): Caused by: java.lang.UnsatisfiedLinkError: dlopen
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.slytechs.library.NativeLibrary.dlopen(Native Method)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.slytechs.library.NativeLibrary.<init>(Unknown Source)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.slytechs.library.JNILibrary.<init>(Unknown Source)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.slytechs.library.JNILibrary.loadLibrary(Unknown Source)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.slytechs.library.JNILibrary.register(Unknown Source)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.slytechs.library.JNILibrary.register(Unknown Source)
08-21 11:18:36.760: E/AndroidRuntime(776):  at com.slytechs.library.JNILibrary.register(Unknown Source)
08-21 11:18:36.760: E/AndroidRuntime(776):  at org.jnetpcap.nio.JMemory.<clinit>(Unknown Source)
08-21 11:18:36.760: E/AndroidRuntime(776):  ... 16 more
08-21 11:18:36.755:W/dalvikvm(776):未找到本机Lcom/slytechs/library/nativellibrary;的实现;。dlopen(Ljava/lang/String;)J
08-21 11:18:36.755:W/dalvikvm(776):异常Ljava/lang/unsatifiedlinkerror;初始化Lorg/jnetpcap/nio/JMemory时抛出;
08-21 11:18:36.755:D/AndroidRuntime(776):关闭虚拟机
08-21 11:18:36.755:W/dalvikvm(776):threadid=1:线程以未捕获异常退出(组=0x40a2d1f8)
08-21 11:18:36.760:E/AndroidRuntime(776):致命异常:主
08-21 11:18:36.760:E/AndroidRuntime(776):java.lang.ExceptionInInitializeError
08-21 11:18:36.760:E/AndroidRuntime(776):在com.example.server\u android.server\u android.handlingpacket(server\u android.java:66)
08-21 11:18:36.760:E/AndroidRuntime(776):在com.example.server\u android.server\u android.onCreate(server\u android.java:50)
08-21 11:18:36.760:E/AndroidRuntime(776):在安德烈