简体   繁体   English

GoogleAuthUtil.getToken导致android应用程序崩溃

[英]GoogleAuthUtil.getToken causing android app crash

I'm attempting to use GoogleAuthUtil.getToken to generate a token that I can use to sign into another service. 我正在尝试使用GoogleAuthUtil.getToken生成可用于登录其他服务的令牌。 When I attempt to use this method my app "hangs" and stops responding. 当我尝试使用此方法时,我的应用程序“挂起”并停止响应。 Eventually my phone spits out some IO error messages. 最终,我的手机吐出了一些IO错误消息。 I receive no result from the server. 我没有收到来自服务器的结果。

The email address is my email address formatted as myname@gmail.com, I have used the server address for my scope, but right now I'm just trying to use the simplest strings possible just to get a result that I can start working with. 电子邮件地址是我的电子邮件地址,格式为myname@gmail.com,我已将服务器地址用于我的作用域,但是现在我正试图使用​​最简单的字符串,以获得可以开始使用的结果。 。

public  class GetTokens extends AsyncTask<String,Void,String>{
 Context c;
 String TAG = "wnycmap issues";

public GetTokens(Context c) {
    this.c=c;
}

@Override
protected String doInBackground(String...mEmail) {
    String token = "null";
    String mScope = "oauth2:https://www.googleapis.com/auth/plus.me";
    String email = mEmail[0];
    System.out.println(c+email+mScope);
    try {
        token = GoogleAuthUtil.getToken(
                c,
                email,
                mScope);

        System.out.println(token);
    } catch (IOException transientEx) {
        // Network or server error, try later
        Log.e(TAG, transientEx.toString());
    } catch (UserRecoverableAuthException e) {
        // Recover (with e.getIntent())
        Log.e(TAG, e.toString());
        // Intent recover = e.getIntent();
        //startActivityForResult(recover, REQUEST_CODE_TOKEN_AUTH);
    } catch (GoogleAuthException authEx) {
        Log.e(TAG, authEx.toString());
    }

    return token;

The Errors: 错误:

 E/SnepServer(32677): IO error
 E/SnepServer(32677): java.io.IOException
 E/SnepServer(32677):   at com.android.nfc.dhimpl.NativeLlcpServiceSocket.accept(NativeLlcpServiceSocket.java:42)
 E/SnepServer(32677):   at com.android.nfc.snep.SnepServer$ServerThread.run(SnepServer.java:213)
 D/NdefPushServer(32677): stop, thread = Thread[Thread-8152,5,main]
 D/NdefPushServer(32677): shuting down server thread
 E/HandoverServer(32677): IO error
 E/HandoverServer(32677): java.io.IOException
 E/HandoverServer(32677):   at com.android.nfc.dhimpl.NativeLlcpServiceSocket.accept(NativeLlcpServiceSocket.java:42)
 E/HandoverServer(32677):   at com.android.nfc.handover.HandoverServer$ServerThread.run(HandoverServer.java:108)
 E/NdefPushServer(32677): IO error
 E/NdefPushServer(32677): java.io.IOException
 E/NdefPushServer(32677):   at com.android.nfc.dhimpl.NativeLlcpServiceSocket.accept(NativeLlcpServiceSocket.java:42)
 E/NdefPushServer(32677):   at com.android.nfc.ndefpush.NdefPushServer$ServerThread.run(NdefPushServer.java:154)

And the code that I'm using to call my AsyncTask 还有我用来调用AsyncTask的代码

private void authenticate() {
      String accountEmail="asdf";
      String authToken = "null";
      AccountManager am = AccountManager.get(context);
      Account[] accounts = am.getAccountsByType("com.google");

      if (accounts != null){
          Account account = accounts[0];
          accountEmail = account.name;

          System.out.println(context);
          try {
                authToken=new GetTokens(context).execute(accountEmail).get();
          } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
          } catch (ExecutionException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
          } 
      }
}    

Try few things, 尝试几件事,

  1. Put a catch for GooglePlayServicesAvailabilityException 抓住GooglePlayServicesAvailabilityException的麻烦
  2. Check if you have placed correct meta-data in application element in AndroidManifest.xml <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" /> 检查您是否在AndroidManifest.xml中的application元素中放置了正确的元数据<meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />
  3. Put a catch for RuntimeException as a last resort to dig the source of crash. 抓住RuntimeException作为最后的手段来挖掘崩溃的根源。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM