GoogleAuthUtil.getToken() не возвращается

В моем приложении для Android я пытаюсь подключить токен Google к таблицам Google. Это код, который делает это:

AsyncTask<String, Void, String> getTokenTask = new AsyncTask<String, Void, String>() {

    @Override
    protected String doInBackground(String... params) {
        Log.i("Groceryviewer", "doInBackground() - Entry");
        String accountName = params[0];
        String token = null;
        try {
            Log.i("Groceryviewer", "Before get token");
            token = GoogleAuthUtil.getToken(LoginHomeActivity.this, accountName, "https://spreadsheets.google.com/feeds https://docs.google.com/feeds");
            Log.i("Groceryviewer", "After get token. Token: " + token);
        } catch (UserRecoverableAuthException e) {
            Log.e("Groceryviewer", "Exception in getToken() - UserRecoverableAuthException", e);
            Log.i("Groceryviewer", "Exception in getToken() - startActivityForResult");
            startActivityForResult(e.getIntent(), USER_ACCEPTS);
        } catch (IOException e) {
            Log.e("Groceryviewer", "Exception in getToken() - IOException", e);
        } catch (GoogleAuthException e) {
            Log.e("Groceryviewer", "Exception in getToken() - GoogleAuthException", e);
        }
        Log.i("Groceryviewer", "doInBackground() - Exit");
        return token;
    }

};
getTokenTask.execute(accountName);

String token = null;
try {
    token = getTokenTask.get();
} catch(ExecutionException e) {
    Log.i("Groceryviewer", "Exception in get() - ExecutionException", e);
} catch (InterruptedException e) {
    Log.i("Groceryviewer", "Exception in get() - InterruptedException", e);
}
Log.i("Groceryviewer", "Token: " + token);

Я также добавил это в AndroidManifest.xml:

<meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />

Проблема в том, что getToken вообще не возвращается. Вот мои логи:

01-01 17:28:57.583: I/Groceryviewer(1485): doInBackground() - Entry
01-01 17:28:57.583: I/Groceryviewer(1485): Before get token

Может кто-нибудь помочь мне понять, почему происходит эта ошибка?

1 ответ

Решение

Похоже на сферу:

На самом деле вам нужен только один вызов метода, GoogleAuthUtil.getToken(). Он принимает три аргумента: контекст, адрес электронной почты и другой строковый аргумент, называемый областью действия.

 private final static String G_SPREADSHEET_SCOPE = 
  "oauth2:https://docs.google.com/feeds/ https://docs.googleusercontent.com/ https://spreadsheets.google.com/feeds/";

http://android-developers.blogspot.com.au/2012/09/google-play-services-and-oauth-identity.html

Другие вопросы по тегам