我有一個完全適用於Java的Chat Client。現在我期待在我的android設備上實現相同的功能。我開始在項目中導入ASmack庫,並在每個階段檢查以避免錯誤。儘管如此,我還是陷入了第一步。我的活動無法在ASmack Jar中找到該課程,因此我認爲我無法繼續。無法將XMPP服務器與Android中的ASmack連接起來
我的簡單代碼:
package com.test.mypro;
import org.jivesoftware.smack.ConnectionConfiguration;
import org.jivesoftware.smack.XMPPConnection;
import org.jivesoftware.smack.XMPPException;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;
public class TestProjectActivity extends Activity {
private static final String LOG_TAG = "TESTER";
/** Called when the activity is first created. */
TextView tvHello;
XMPPConnection connection;
ConnectionConfiguration config;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
tvHello = (TextView) findViewById(R.id.tvHello);
Log.i(LOG_TAG, "I'm here");
config = new ConnectionConfiguration("prc.p1.im", 5222, "prc.p1.im");
connection = new XMPPConnection(config);
try {
connection.connect();
// tvHello.setText("Connected to XMPP server");
Log.i(LOG_TAG, "Successfully Connected");
} catch (XMPPException e) {
// TODO Auto-generated catch block
e.printStackTrace();
Log.e(LOG_TAG, "Not Connected");
}
}
}
logcat的日誌:
12-22 15:58:16.319: E/dalvikvm(828): Could not find class 'org.jivesoftware.smack.ConnectionConfiguration', referenced from method com.test.mypro.TestProjectActivity.onCreate
12-22 15:58:16.339: W/dalvikvm(828): VFY: unable to resolve new-instance 26 (Lorg/jivesoftware/smack/ConnectionConfiguration;) in Lcom/test/mypro/TestProjectActivity;
12-22 15:58:16.339: D/dalvikvm(828): VFY: replacing opcode 0x22 at 0x0019
12-22 15:58:16.351: D/dalvikvm(828): VFY: dead code 0x001b-0047 in Lcom/test/mypro/TestProjectActivity;.onCreate (Landroid/os/Bundle;)V
12-22 15:58:16.509: I/TESTER(828): I'm here
12-22 15:58:16.519: D/AndroidRuntime(828): Shutting down VM
12-22 15:58:16.519: W/dalvikvm(828): threadid=1: thread exiting with uncaught exception (group=0x40015560)
12-22 15:58:16.561: E/AndroidRuntime(828): FATAL EXCEPTION: main
12-22 15:58:16.561: E/AndroidRuntime(828): java.lang.NoClassDefFoundError: org.jivesoftware.smack.ConnectionConfiguration
12-22 15:58:16.561: E/AndroidRuntime(828): at com.test.mypro.TestProjectActivity.onCreate(TestProjectActivity.java:24)
12-22 15:58:16.561: E/AndroidRuntime(828): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
12-22 15:58:16.561: E/AndroidRuntime(828): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
12-22 15:58:16.561: E/AndroidRuntime(828): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
12-22 15:58:16.561: E/AndroidRuntime(828): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
12-22 15:58:16.561: E/AndroidRuntime(828): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
12-22 15:58:16.561: E/AndroidRuntime(828): at android.os.Handler.dispatchMessage(Handler.java:99)
12-22 15:58:16.561: E/AndroidRuntime(828): at android.os.Looper.loop(Looper.java:123)
12-22 15:58:16.561: E/AndroidRuntime(828): at android.app.ActivityThread.main(ActivityThread.java:3683)
12-22 15:58:16.561: E/AndroidRuntime(828): at java.lang.reflect.Method.invokeNative(Native Method)
12-22 15:58:16.561: E/AndroidRuntime(828): at java.lang.reflect.Method.invoke(Method.java:507)
12-22 15:58:16.561: E/AndroidRuntime(828): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
12-22 15:58:16.561: E/AndroidRuntime(828): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
12-22 15:58:16.561: E/AndroidRuntime(828): at dalvik.system.NativeStart.main(Native Method)
附加信息:我已經asmack-Android的7.jar庫中導入。我的AVD正在運行2.3.3 Android。
我認爲由於這個,我得到了致命的例外。 我在這裏錯過了什麼?您的幫助將不勝感激。謝謝。
我想你沒有看到正確的日誌。在日誌中應該注意的主要問題是:''無法找到從方法com.test.mypro.TestProjectActivity.onCreate引用的'org.jivesoftware.smack.ConnectionConfiguration'類。我無法調用COnnectionConfiguration類。儘管如此,我嘗試了你的代碼,得到了相同的結果 – harsh8888
一旦把連接代碼放在單獨的方法中,然後嘗試。 – NagarjunaReddy
請檢查日誌。這個問題存在於我假設的圖書館的入口(日誌的第一行)。它無法取出ConnectionConfiguration類,它將啓動進一步的連接過程,因此將它放在單獨的方法中不應該有任何區別。有什麼建議麼? – harsh8888