Android デバイスに保存されている Google アカウントから新しいトークンを取得しようとしていますが、取得したのは、過去数日間キャッシュしてきたものと同じ古いトークンだけです。電話のどこかにキャッシュされているようで、インターネットリクエストも送信されていません(インターネットに接続せずにアプリでテストを行い、同じトークンが返されます)。
frominvalidateAuthToken
で新しいメソッドを取得する前に、このメソッドを使用しました。見てください:getResult
AccountManagerFuture
public String updateToken(Activity activity) throws Exception {
AccountManager am = AccountManager.get(activity);
Account[] accounts = am.getAccountsByType("com.google");
if (accounts == null ||
accounts.length == 0 ||
"".equals(accounts[0].name.trim()))
{
throw new Exception("Não há contas Google configuradas no smartphone.");
}
else if (!"crsilva@gmail.com".equals(accounts[0].name.trim()) &&
!"cristiano.bezerra@sulamerica.com.br".equals(accounts[0].name.trim()) &&
!"tholiver@gmail.com".equals(accounts[0].name.trim()))
{
Log.w("Util.updateToken","conta obtida: " + accounts[0].name);
throw new Exception("Conta Google não autorizada.");
}
Log.w("Util.updateToken","conta obtida: " + accounts[0].name);
am.invalidateAuthToken("com.google", null);
Log.w("Util.updateToken","Passou do invalidateAuthToken");
AccountManagerFuture<Bundle> future =
am.getAuthToken(accounts[0], "ah", null, activity, null, null);
Log.w("Util.updateToken","Passou do getAuthToken");
Bundle bundle = future.getResult();
Log.w("Util.updateToken","Passou do getResult");
future = null;
am = null;
accounts = null;
String authToken = bundle.getString(AccountManager.KEY_AUTHTOKEN);
Log.w("Util.updateToken","Token: " + authToken);
return authToken;
}
シングルトン インスタンスによって Util クラスからこのメソッドを呼び出したスレッド。マニフェストには、必要なすべてのアクセス許可があります。トークンが更新されない理由を知っている人はいますか?