Аутентификация с помощью Google API с помощью AccountManager - PullRequest
6 голосов
/ 02 марта 2012

Я боролся с этим уже пару дней. Я пытаюсь звонить в Календарь Google, используя аутентификацию через Android AccountManager. Я получаю токен авторизации, используя обычный метод:

AccountManager manager = AccountManager.get(this);
String authToken = manager.getAuthToken(account, AUTH_TOKEN_TYPE, true, null, null).getResult().getString(AccountManager.KEY_AUTHTOKEN);

И затем с помощью этого токена я создаю Calendar экземпляр, подобный этому:

HttpTransport transport = AndroidHttp.newCompatibleTransport();
JacksonFactory jsonFactory = new JacksonFactory();
GoogleAccessProtectedResource accessProtectedResource = new GoogleAccessProtectedResource(accessToken);
Calendar calendar = Calendar.builder(transport, jsonFactory).setApplicationName("MyApp/1.0").setJsonHttpRequestInitializer(new JsonHttpRequestInitializer() {
    @Override
    public void initialize(JsonHttpRequest request) {
        CalendarRequest calendarRequest = (CalendarRequest) request;
        calendarRequest.setKey(API_KEY);
    }
}).setHttpRequestInitializer(accessProtectedResource).build();

Однако, когда я делаю вызовы API, используя это, я получаю ошибку 401 Unauthorized, показанную ниже. Обратите внимание, что я включил код для аннулирования маркеров авторизации с истекшим сроком действия, поэтому я не думаю, что в этом проблема.

com.google.api.client.googleapis.json.GoogleJsonResponseException: 401 Unauthorized
{
    "code" : 401,
    "errors" : [ {
        "domain" : "global",
        "location" : "Authorization",
        "locationType" : "header",
        "message" : "Invalid Credentials",
        "reason" : "authError"
    } ],
    "message" : "Invalid Credentials"
}

Есть мысли о том, что я могу делать не так?

Ответы [ 2 ]

11 голосов
/ 02 марта 2012

Да, это возможно. Если у вас есть дескриптор учетной записи Google (как вы описали), вам просто нужно запросить токен авторизации у AccountManager для службы GData.

Если на устройстве Android уже есть токен авторизации (для конкретной службы GData, к которой вы пытаетесь получить доступ), он будет возвращен вам. Если нет, AccountManager запросит его и вернет вам. В любом случае вам не нужно беспокоиться об этом, так как AccountManager обрабатывает это.

В следующем примере я использую API таблиц Google:

ArrayList<Account> googleAccounts = new ArrayList<Account>();

// Get all accounts 
Account[] accounts = accountManager.getAccounts();
  for(Account account : accounts) {
    // Filter out the Google accounts
    if(account.type.compareToIgnoreCase("com.google")) {
      googleAccounts.add(account);
    }
  }
AccountManager accountManager = AccountManager.get(activity);

// Just for the example, I am using the first google account returned.
Account account = googleAccounts.get(0);

// "wise" = Google Spreadheets
AccountManagerFuture<Bundle> amf = accountManager.getAuthToken(account, "wise", null, activity, null, null);

try {
  Bundle authTokenBundle = amf.getResult();
  String authToken = authTokenBundle.getString(AccountManager.KEY_AUTHTOKEN);

  // do something with the token
  InputStream response = sgc.getFeedAsStream(feedUrl, authToken, null, "2.1");

}

И

Пожалуйста, ознакомьтесь с примером кода в API данных Google. После аутентификации важно позвонить в GoogleHeaders.setGoogleLogin (String).

Надеюсь, это поможет.

0 голосов
/ 13 марта 2012

Столкнулся с подобной проблемой сам.Я обнаружил, что мне нужно установить xoauth_requestor_id в списке неизвестных ключей (ссылка: http://www.yenlo.nl/2011/google-calendar-api-v3-and-2lo/)

Это сработало для меня:

com.google.api.services.calendar.Calendar.CalendarList.List list = calendar.calendarList().list();
//Set the requestor id
list.getUnknownKeys().put("xoauth_requestor_id", "user@gmail.com");

После этого пошли вызовы APIthru.

Хотелось бы, чтобы было объяснение, почему нужен идентификатор запрашивающего.Может кто-нибудь объяснить?

...