【发布时间】:2018-06-20 16:30:21
【问题描述】:
我在 Eclipse 上有 Android 项目。主要思想是创建 java websocket 客户端。客户端必须向服务器发送消息并返回一些消息。但是当我在模拟器上运行应用程序时,它崩溃了。在日志中,有一个 NoClassDefFoundError。哪里出错了?
我的main.xml很简单:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/messages"
android:text="@string/hello_world"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
这个MainActivity.java:
package com.ab.mywebsocketclient;
import java.net.URI;
import java.net.URISyntaxException;
import org.java_websocket.client.WebSocketClient;
import org.java_websocket.handshake.ServerHandshake;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;
public class MainActivity extends Activity {
private WebSocketClient mWebSocketClient;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
connectWebSocket();
}
private void connectWebSocket() {
URI uri;
try {
uri = new URI("ws://127.0.0.1:80");
}
catch (URISyntaxException e) {
e.printStackTrace();
return;
}
mWebSocketClient = new WebSocketClient(uri) {
@Override
public void onOpen(ServerHandshake serverHandshake) {
Log.i("Websocket", "Opened");
mWebSocketClient.send("123");
}
@Override
public void onMessage(String s) {
final String message = s;
runOnUiThread(new Runnable() {
@Override
public void run() {
TextView msg = (TextView)findViewById(R.id.messages);
msg.setText(msg.getText() + "\n" + message);
}
});
}
@Override
public void onClose(int i, String s, boolean b) {
Log.i("Websocket", "Closed " + s);
}
@Override
public void onError(Exception e) {
Log.i("Websocket", "Error " + e.getMessage());
}
};
mWebSocketClient.connect();
}
}
在 Manifest.xml 我添加 使用权限 android:name="android.permission.INTERNET"
这是日志:
08-22 10:53:10.974: D/AndroidRuntime(1251): Shutting down VM
08-22 10:53:10.974: D/AndroidRuntime(1251): --------- beginning of crash
08-22 10:53:10.991: E/AndroidRuntime(1251): FATAL EXCEPTION: main
08-22 10:53:10.991: E/AndroidRuntime(1251): Process: com.ab.mywebsocketclient, PID: 1251
08-22 10:53:10.991: E/AndroidRuntime(1251): Process: com.ab.mywebsocketclient, PID: 1251
08-22 10:53:10.991: E/AndroidRuntime(1251): java.lang.NoClassDefFoundError: Failed resolution of: Lorg/java_websocket/client/WebSocketClient;
08-22 10:53:10.991: E/AndroidRuntime(1251): at com.ab.mywebsocketclient.MainActivity.connectWebSocket(MainActivity.java:27)
08-22 10:53:10.991: E/AndroidRuntime(1251): at com.ab.mywebsocketclient.MainActivity.onCreate(MainActivity.java:22)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.app.Activity.performCreate(Activity.java:5937)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.app.ActivityThread.access$800(ActivityThread.java:144)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.os.Handler.dispatchMessage(Handler.java:102)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.os.Looper.loop(Looper.java:135)
08-22 10:53:10.991: E/AndroidRuntime(1251): at android.app.ActivityThread.main(ActivityThread.java:5221)
08-22 10:53:10.991: E/AndroidRuntime(1251): at java.lang.reflect.Method.invoke(Native Method)
08-22 10:53:10.991: E/AndroidRuntime(1251): at java.lang.reflect.Method.invoke(Method.java:372)
08-22 10:53:10.991: E/AndroidRuntime(1251): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
08-22 10:53:10.991: E/AndroidRuntime(1251): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
08-22 10:53:10.991: E/AndroidRuntime(1251): Caused by: java.lang.ClassNotFoundException: Didn't find class "org.java_websocket.client.WebSocketClient" on path: DexPathList[[zip file "/data/app/com.ab.mywebsocketclient-2/base.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
08-22 10:53:10.991: E/AndroidRuntime(1251): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
08-22 10:53:10.991: E/AndroidRuntime(1251): at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
08-22 10:53:10.991: E/AndroidRuntime(1251): at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
08-22 10:53:10.991: E/AndroidRuntime(1251): ... 15 more
08-22 10:53:10.991: E/AndroidRuntime(1251): Suppressed: java.lang.ClassNotFoundException: org.java_websocket.client.WebSocketClient
08-22 10:53:10.991: E/AndroidRuntime(1251): at java.lang.Class.classForName(Native Method)
08-22 10:53:10.991: E/AndroidRuntime(1251): at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
08-22 10:53:10.991: E/AndroidRuntime(1251): at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
08-22 10:53:10.991: E/AndroidRuntime(1251): at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
08-22 10:53:10.991: E/AndroidRuntime(1251): ... 16 more
08-22 10:53:10.991: E/AndroidRuntime(1251): Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available
08-22 10:53:16.681: I/Process(1251): Sending signal. PID: 1251 SIG: 9
【问题讨论】:
-
嗯,errr,看起来可能是类路径问题,您确定要加载 websocket jar 库吗?
-
我确定。我正在加载 java-websocket-1.3.0.jar
-
回溯告诉你找不到类: 原因:java.lang.NoClassDefFoundError: Class not found using the boot class loader;没有可用的堆栈。不确定您是如何尝试启动应用程序的,您有调用示例吗?一切以及类路径等......!