【问题标题】:Websocket client in Java - NoClassDefFoundErrorJava 中的 Websocket 客户端 - NoClassDefFoundError
【发布时间】:2018-06-20 16:30:21
【问题描述】:

我在 Eclipse 上有 Android 项目。主要思想是创建 java websocket 客户端。客户端必须向服务器发送消息并返回一些消息。但是当我在模拟器上运行应用程序时,它崩溃了。在日志中,有一个 NoClassDefFoundError。哪里出错了?

我的ma​​in.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;没有可用的堆栈。不确定您是如何尝试启动应用程序的,您有调用示例吗?一切以及类路径等......!

标签: java android websocket


【解决方案1】:

在 Android Studio 中,您可以尝试在 build.gradle 中添加编译行:

compile 'org.java-websocket:Java-WebSocket:1.3.0'

http://mvnrepository.com/artifact/org.java-websocket/Java-WebSocket/1.3.0找到

【讨论】:

    【解决方案2】:

    在您的应用级 build.gradle 文件中添加这些行

     repositories {
    mavenCentral()
     }
    

    在依赖项中{}添加此实现

     implementation "org.java-websocket:Java-WebSocket:1.3.0"
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2018-09-10
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-11-07
      • 2014-07-11
      • 2017-03-03
      相关资源
      最近更新 更多