我正在开发一个可以连接到 SSL 的 php web 服务的 Android 3.0 程序(以 JSON 格式输出数据,我可以修改服务器)。连接到此服务的平板电脑有一个公司 Microsoft ActiveSync (exchange 2010) 帐户,并且只有该帐户(没有 google 帐户、FB 等)。我想编写一个程序,可以使用平板电脑的android.accounts.AccountManager中保存的凭据在该 PHP Web 服务上发出安全请求。我尝试遵循一些谷歌示例,但我认为问题出在我使用以下行时:
AccountManagerFuture<Bundle> data = am.getAuthToken(b, "JWT", options, this, ota, null);
应用程序只是挂起,我没有得到任何结果。事实上,在 OnTokenAcquired 类中的任何一行设置断点都不会做任何事情。AKA OnTokenRequired 永远不会被执行
有什么建议或方向吗?我相信这可能有助于获取企业 android 客户端软件
import android.accounts.Account;
import android.accounts.AccountManager;
import android.accounts.AccountManagerFuture;
import android.app.Activity;
import android.os.Bundle;
import android.widget.EditText;
public class AcctestActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
AccountManager am = AccountManager.get(this);
EditText et = (EditText) findViewById(R.id.editText1);
OnTokenAcquired ota = new OnTokenAcquired(et);
Account exchange = null;
Bundle options = new Bundle();
for(Account a : am.getAccounts()){
if(a.type.equals("com.android.exchange") && a.name.endsWith("@domain.com"))
exchange = a;
}
AccountManagerFuture<Bundle> data = am.getAuthToken(exchange, "JWT", options, this, ota, null);
}
}
import android.accounts.AccountManager;
import android.accounts.AccountManagerCallback;
import android.accounts.AccountManagerFuture;
import android.accounts.AuthenticatorException;
import android.accounts.OperationCanceledException;
import android.os.Bundle;
import android.widget.EditText;
import android.widget.Toast;
import java.io.IOException;
import java.util.concurrent.TimeUnit;
public class OnTokenAcquired implements AccountManagerCallback<Bundle> {
private EditText et;
public OnTokenAcquired(EditText et){
this.et = et;
}
public void run(AccountManagerFuture<Bundle> result) {
Bundle bundle;
try {
Toast.makeText(null, "Start!", Toast.LENGTH_LONG).show();
bundle = result.getResult(1, TimeUnit.SECONDS);
String token = bundle.getString(AccountManager.KEY_AUTHTOKEN); et.append("\nToken: " + token);
Toast.makeText(null, token, Toast.LENGTH_LONG).show();
} catch (OperationCanceledException e) {
e.printStackTrace();
} catch (AuthenticatorException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}