2

我正在开发一个可以连接到 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();
              }            
       }
}
4

2 回答 2

0

您必须为 Exchange 帐户传递正确的令牌类型。我不知道它是什么,但我怀疑它会是“测试”。首先研究什么是正确的令牌类型(如果支持)。否则你的代码看起来没问题。但是,如何使用令牌对 Exchange 进行身份验证是另一回事。

于 2012-05-30T02:31:08.220 回答
0

在对源代码进行了几个小时的研究后,我发现了这段代码:

public Bundle  getAuthToken(AccountAuthenticatorResponse response, Account account, String authTokenType, Bundle loginOptions) throws NetworkErrorException {
     return null;
}

这意味着,android exchange Authenticator 不为 Exchange-Server 提供基于令牌的身份验证...

于 2012-06-27T07:36:47.633 回答