現在、AndroidアプリにDropBoxを実装しようとしています。Android用のクライアントjarファイルを追加しましたが、開発用ドロップボックスアカウントにログインしようとすると、アプリが強制的に閉じられ続けます。
以下は、私が使用しているコードです。
import android.os.AsyncTask;
import android.util.Log;
import com.dropbox.client.DropboxAPI;
public class LoginASyncTask extends AsyncTask<Void, Void, Integer> {
private static final String TAG = "LoginASyncTask";
String mUser;
String mPassword;
String mErrorMessage = "";
DropBoxLogin mDropBoxLogin;
DropboxAPI.Config mConfig;
DropboxAPI.Account mAccount;
public LoginASyncTask(DropBoxLogin act, String user, String password, DropboxAPI.Config config)
{
super();
mDropBoxLogin = act;
mUser = user;
mPassword = password;
mConfig = config;
}
@Override
protected Integer doInBackground(Void...params)
{
try
{
DropboxAPI api = mDropBoxLogin.getAPI();
int success = DropboxAPI.STATUS_NONE;
if (!api.isAuthenticated())
{
//Going wrong on this line
mConfig = api.authenticate(mConfig, mUser, mPassword);
mDropBoxLogin.setConfig(mConfig);
success = mConfig.authStatus;
if (success != DropboxAPI.STATUS_SUCCESS)
{
return success;
}
}
mAccount = api.accountInfo();
if (!mAccount.isError())
{
return DropboxAPI.STATUS_SUCCESS;
}
else
{
Log.d(TAG, "Account Info Error: " + mAccount.httpCode + " " + mAccount.httpReason);
return DropboxAPI.STATUS_FAILURE;
}
}
catch (Exception e)
{
Log.d(TAG, "Error in loggin in", e);
return DropboxAPI.STATUS_NETWORK_ERROR;
}
}
@Override
protected void onPostExecute(Integer result)
{
if (result == DropboxAPI.STATUS_SUCCESS)
{
if (mConfig != null && mConfig.authStatus == DropboxAPI.STATUS_SUCCESS)
{
mDropBoxLogin.storeKeys(mConfig.accessTokenKey, mConfig.accessTokenSecret);
mDropBoxLogin.setLoggedIn(true);
mDropBoxLogin.showToast("Logged into dropbox");
}
if (mAccount != null)
{
mDropBoxLogin.displayAccountInfo(mAccount);
}
else
{
if (result == DropboxAPI.STATUS_NETWORK_ERROR)
{
mDropBoxLogin.showToast("Network Error: " + mConfig.authDetail);
}
else
{
mDropBoxLogin.showToast("Unsuccessful Login");
}
}
}
}
}
次のように、logcatでスタックトレースエラーが発生し続けます。
致命的な例外:ASyncTask#1 java.lang.RuntimeException:doInBackground()の実行中にエラーが発生しました
編集
@Kannan Goundanによって、例外として次の原因で発生していることがわかりました。
Java.Lang.NoClassDefFoundError:oath.signpost.basic.DefaultOAuthConsumer
これが何を意味するのか、またはこの問題をどのように修正できるのか理解できません。