0

現在、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

これが何を意味するのか、またはこの問題をどのように修正できるのか理解できません。

4

1 に答える 1

0

私はなんとか問題を解決することができました。jarファイルの1つ(signpost-core)をプロジェクトビルドパスにインポートしませんでした。これがインポートされると、正常に機能しました。

于 2011-04-21T16:28:35.853 に答える