对于Picasa Web Service,使用authTokenType =“lh2”调用AccountManager.getAuthToken()现在不会在Android 5.x上返回;带有“lh2”的getAuthToken仍适用于Android 4.4.x和6.x,而不是5.x.直到2016年8月至9月的某个时候,Lollipop一切正常,并且在那段时间内代码或应用程序没有任何变化。
在Lollipop设备上使用getAuthToken为“lh2”遇到此问题的其他人?是否有其他方法可以将帐户身份验证令牌传递给PicasaWebService?
以下是getAuthToken的相关代码:
//...
String accountName = "someone@somedamain.com"
Account selectedAccount = null;
AccountManager accountManager = (AccountManager)activity.getSystemService(Context.ACCOUNT_SERVICE);
Account[] list = accountManager.getAccounts();
for (android.accounts.Account a:list) {
if (a.name.equals(accountName)) {
selectedAccount = a;
break;
}
}
accountManager.invalidateAuthToken("com.google", null);
AccountManagerFuture<Bundle> tokenFuture = getAccountManager().getAuthToken(
selectedAccount,
"lh2",
null,
activity,
new OnTokenAcquired(),
new Handler(new OnTokenError()));
//...
private class OnTokenAcquired implements AccountManagerCallback<Bundle> {
@Override
public void run(AccountManagerFuture<Bundle> result) {
try {
Bundle b = result.getResult();
if (b.containsKey(AccountManager.KEY_INTENT)) {
Intent intent = b.getParcelable(AccountManager.KEY_INTENT);
int flags = intent.getFlags();
flags &= ~Intent.FLAG_ACTIVITY_NEW_TASK;
intent.setFlags(flags);
activity.startActivityForResult(intent, REQUEST_AUTHENTICATE);
return;
}
if (b.containsKey(AccountManager.KEY_AUTHTOKEN)) {
String authToken = b.getString(AccountManager.KEY_AUTHTOKEN);
// set authtoken to Picasa Web Service
_picasaService = new PicasawebService("myApp");
_picasaService.setUserToken(authToken);
return;
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
private class OnTokenError implements Handler.Callback {
@Override
public boolean handleMessage(Message msg) {
Log.e("onError","ERROR");
return false;
}
}
//...
谢谢!
答案 0 :(得分:0)
似乎authTokenType应该是https://developers.google.com/oauthplayground/上的“OAuth范围”,前缀为“oauth2:”。
对于Picasa网站,这是https://picasaweb.google.com/data/
accountManager.getAuthToken(account, "oauth2:https://picasaweb.google.com/data/",
options, false, new GetAuthTokenCallback(), null);