我的Android应用程序出了问题。我想将android应用程序连接到运行在jboss 7.1上的web服务。当我创建异步任务以在我的webservicde上运行方法时,我在logcat中遇到以下错误:
06-15 15:45:21.731: E/Trace(1958): error opening trace file: No such file or directory (2)
06-15 15:45:45.531: E/AndroidRuntime(1958): FATAL EXCEPTION: AsyncTask #1
06-15 15:45:45.531: E/AndroidRuntime(1958): java.lang.RuntimeException: An error occured while executing doInBackground()
06-15 15:45:45.531: E/AndroidRuntime(1958): at android.os.AsyncTask$3.done(AsyncTask.java:299)
06-15 15:45:45.531: E/AndroidRuntime(1958): at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:352)
06-15 15:45:45.531: E/AndroidRuntime(1958): at java.util.concurrent.FutureTask.setException(FutureTask.java:219)
06-15 15:45:45.531: E/AndroidRuntime(1958): at java.util.concurrent.FutureTask.run(FutureTask.java:239)
06-15 15:45:45.531: E/AndroidRuntime(1958): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
06-15 15:45:45.531: E/AndroidRuntime(1958): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
06-15 15:45:45.531: E/AndroidRuntime(1958): at java.lang.Thread.run(Thread.java:856)
06-15 15:45:45.531: E/AndroidRuntime(1958): Caused by: java.lang.NullPointerException
06-15 15:45:45.531: E/AndroidRuntime(1958): at de.wifhm.se1.android.banking.OnlineBankingSystemStub.login(OnlineBankingSystemStub.java:52)
06-15 15:45:45.531: E/AndroidRuntime(1958): at de.wifhm.se1.android.LoginActivity$LoginLogoutTask.doInBackground(LoginActivity.java:118)
06-15 15:45:45.531: E/AndroidRuntime(1958): at de.wifhm.se1.android.LoginActivity$LoginLogoutTask.doInBackground(LoginActivity.java:1)
06-15 15:45:45.531: E/AndroidRuntime(1958): at android.os.AsyncTask$2.call(AsyncTask.java:287)
06-15 15:45:45.531: E/AndroidRuntime(1958): at java.util.concurrent.FutureTask.run(FutureTask.java:234)
06-15 15:45:45.531: E/AndroidRuntime(1958): ... 3 more
android清单看起来像这样:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="de.wifhm.se1.android"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk android:minSdkVersion="10" />
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<application
android:name=".OnlineBankingApplication"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:name=".LoginActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".TransactionsActivity" android:label="@string/labelTransactions"></activity>
<activity android:name=".PrefsActivity" android:label="@string/labelPrefs"></activity>
</application>
</manifest>
这是我的doInBackground方法:
类LoginLogoutTask扩展了AsyncTask {
/**
* Diese Methode wird in einem nebenläufigen Thread ausgeführt (asynchron). Darum dürfen hier
* keine View-Elemente zugegriffen werden!
*/
@Override
protected String doInBackground(String... params) {
StringBuffer output = null;
if (LoginActivity.this.obsApp.getAngemeldeterKunde() == null) {
/* Login durchfuehren */
String username = LoginActivity.this.prefs.getString("username", "");
String password = LoginActivity.this.prefs.getString("password", "");
Kunde angemeldeterKunde = LoginActivity.this.obsApp.getObsStub().login(username, password);
LoginActivity.this.obsApp.setAngemeldeterKunde(angemeldeterKunde);
//Ergebnisausgabe:
output = new StringBuffer("Sie sind eingeloggt als " + angemeldeterKunde.getUserName() + ".\n\nIhre Konten:\n");
Set<Konto> konten = LoginActivity.this.obsApp.getObsStub().getEigeneKonten();
for (Konto konto : konten){
output.append("- Konto " + konto.getKontoNr() + "\n");
output.append("---Kontostand aktuell: " + LoginActivity.this.obsApp.getObsStub().getKontostand(konto.getKontoNr()) + "EUR\n");
}
}
else {
/* Logout durchfuehren */
LoginActivity.this.obsApp.getObsStub().logout();
LoginActivity.this.obsApp.setAngemeldeterKunde(null);
output = new StringBuffer("Bitte erneut einloggen.");
}
return output.toString();
}
有人可以帮助我吗?
答案 0 :(得分:0)
堆栈跟踪指向您的代码在login
方法中调用doInBackground
时失败。这将通过堆栈跟踪中的以下行显示:
06-15 15:45:45.531: E/AndroidRuntime(1958): at de.wifhm.se1.android.banking.OnlineBankingSystemStub.login(OnlineBankingSystemStub.java:52)
06-15 15:45:45.531: E/AndroidRuntime(1958): at de.wifhm.se1.android.LoginActivity$LoginLogoutTask.doInBackground(LoginActivity.java:118)
考虑到这一点,您的代码会调用login
,结果为NullPointerException
:
String username = LoginActivity.this.prefs.getString("username", "");
String password = LoginActivity.this.prefs.getString("password", "");
Kunde angemeldeterKunde = LoginActivity.this.obsApp.getObsStub().login(username, password);
您的代码中很可能出现问题,其中username
或password
被设置为null。可能两者都有。
您需要调查其余代码,以确定prefs
中缺少其中一个或两个的原因。
答案 1 :(得分:-1)
安迪现在很忙。这是prefs.xml:
<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" >
<EditTextPreference android:key="username"
android:summary="@string/summaryUsername"
android:title="@string/titleUsername"/>
<EditTextPreference android:key="password"
android:summary="@string/summaryPassword"
android:title="@string/titlePassword"
android:password="true"/>
</PreferenceScreen>
和strings.xml:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="myTitle">Willkommen zum OnlineBanking</string>
<string name="app_name">OnlineBankingApp</string>
<string name="titleUsername">Benutzername</string>
<string name="summaryUsername">Joe</string>
<string name="titlePassword">Kennwort</string>
<string name="summaryPassword">Joe1</string>
<string name="labelPrefs">Einstellungen</string>
<string name="labelTransactions">Transaktionen</string>
<string name="bnLogin">Login</string>
<string name="bnLogout">Logout</string>
<string name="bnTransactions">Transaktionen</string>
<string name="msgLoginFehlt">Bitte loggen Sie sich ein.</string>
</resources>