我有两个使用相同帐户类型的应用。我希望当用户第一次打开第二个应用并且存在一个帐户时,会显示以下页面:
但是当我运行这段代码时没有任何反应:
final AccountManagerFuture<Bundle> future = mAccountManager.getAuthToken(account, authTokenType, null, this, null, null);
new Thread(new Runnable() {
@Override
public void run() {
try {
Bundle bnd = future.getResult();
final String authtoken = bnd.getString(AccountManager.KEY_AUTHTOKEN);
showMessage((authtoken != null) ? "SUCCESS!\ntoken: " + authtoken : "FAIL");
Log.d("udinic", "GetToken Bundle is " + bnd);
} catch (Exception e) {
e.printStackTrace();
showMessage(e.getMessage());
}
}
}).start();
当我从具有验证器的应用程序运行它时,上面的代码正常工作。当我在代码下面运行时,系统会生成一个通知,当我点击它时,会出现上面的图片。
final AccountManagerFuture<Bundle> future = mAccountManager
.getAuthToken(account, authTokenType, null, true,
null, handler);
单击“允许”按钮可正确返回AuthToken
。但是,我想在调用getAuthToken
时看到授权许可页面(上图),而不是点击通知。我怎么能这样做?
答案 0 :(得分:1)
我使用此方法而不是之前的方法,现在我看到确认对话框:
accountManager.getAuthToken(account, AUTH_TOKEN_TYPE_FULL_ACCESS, null, true, new AccountManagerCallback<Bundle>() {
@Override
public void run(AccountManagerFuture<Bundle> future) {
try {
Bundle bundle = future.getResult();
String authToken = bundle.getString(AccountManager.KEY_AUTHTOKEN);
} catch (OperationCanceledException | IOException | AuthenticatorException e) {
}
}
}, null);
请注意,第二个应用必须具有不同的签名。如果两个应用都具有相同的签名,则无需确认,authToken
将检索。
答案 1 :(得分:0)
这里有几件事要做。在Android中使用线程通常被认为是不好的做法,根据Android文档,建议使用Async任务或Handler。现在,对于每个Android文档的Auth消息,预期输出是一个通知。
getAuthToken(Account account, String authTokenType, Bundle options, boolean notifyAuthFailure, AccountManagerCallback<Bundle> callback, Handler handler)
获取特定帐户的指定类型的身份验证令牌, 如果用户必须输入凭证,则可选择提出通知。
请注意getAuthToken如何具有Handler参数?这将是处理任务异步的首选方法。这里的问题是you CAN NOT have a full screen message on a handler thread, because it can't interrupt the UI thread.
在你的第一个例子中,你实际上在UI线程上调用了调用mAccountManager
,因此它允许它接管UI并发送全屏允许或拒绝消息,但这不是完成处理程序,因为处理程序不能使用UI线程(将在运行时抛出错误)。
我建议的解决方案?如果您想要全屏中断消息,请不要使用处理程序,在UI线程上执行操作,类似于您的第一个代码段。
AccountManagerFuture<Bundle> future = mAccountManager.getAuthToken(account, authTokenType, null, this, callback, null);
//USE implements and implement a listener in the class declaration and
//use 'this' in the callback param OR create a new callback method for it