2016-02-29 23 views
9

Sto lavorando a un'app che esegue un'autenticazione oauth2 che prima funzionava, ma purtroppo non funziona più. Per quanto ne so (ma non sicuro al 100%) nulla è cambiato nel codice, quindi non so perché non funzionerebbe più.Perché gmail oauth non funziona nella mia app per Android?

L'applicazione crea un WebView e carica un URL dal nostro server, che reindirizza a Google per l'autenticazione su questo URL (appena cambiato id cliente e il mio dominio):

https://accounts.google.com/o/oauth2/auth?response_type=code&client_id=1234567890-XXXXXXX.apps.googleusercontent.com&redirect_uri=http%3A%2F%2Fexample.com%3A5000%2Fchannel%2Fgmail%2Fcallback&scope=https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fuserinfo.email+https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fgmail.readonly&access_type=offline 

che reindirizza immediatamente a:

https://accounts.google.com/ServiceLogin?passive=1209600&continue=https://accounts.google.com/o/oauth2/auth?access_type%3Doffline%26scope%3Dhttps://www.googleapis.com/auth/userinfo.email%2Bhttps://www.googleapis.com/auth/gmail.readonly%26response_type%3Dcode%26redirect_uri%3Dhttp://example.com:5000/channel/gmail/callback%26client_id%3D123456789-XXXXX.apps.googleusercontent.com%26hl%3Dnl%26from_login%3D1%26as%3D-2178738b5063e716&ltmpl=popup&oauth=1&sarp=1&scc=1 

Lo stesso sistema viene utilizzato dal nostro iOS-app, che funziona come un fascino. Quindi non c'è niente di sbagliato con la nostra implementazione del server. Dopo che la webview è stata reindirizzata a google, torna automaticamente all'app senza mostrare alcuna schermata di google. Sto utilizzando il seguente codice per aprire il WebView:

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { 
    View view = inflater.inflate(R.layout.fragment_browser_webview, container, false); 

    webView = (WebView) view.findViewById(R.id.web_view); 

    webView.getSettings().setJavaScriptEnabled(true); 
    webView.getSettings().setDisplayZoomControls(false); 
    webView.getSettings().setLoadWithOverviewMode(true); 
    webView.getSettings().setUseWideViewPort(true); 
    webView.getSettings().setDomStorageEnabled(true); 

    webView.setWebViewClient(new WebViewClient() { 
     public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { 
      Log.wtf("ERROR", description + " " + failingUrl); 
     } 

     @Override 
     public boolean shouldOverrideUrlLoading(WebView view, String url) { 
      Log.wtf("WEBVIEW URL", url); 
      if (url.contains(Api.API_ENTER_POINT)) { 
       // We never actually get here 
       getActivity().finish(); 
      } 

      return false; //Allow WebView to load url 
     } 
    }); 
    if (userId != null & userToken != null) { 
     Log.d("Gmail login", String.format(Api.API_GMAIL,userId,userToken)); 
     webView.loadUrl(String.format(Api.API_GMAIL,userId,userToken)); 
    } 
    return view; 
} 

e l'uscita logcat è la seguente:

02-29 18:56:39.028 27510-27510/com.example D/Gmail login: http://example.com:5000/api/v1/channel/gmail/on/1/CAAV8cDYVv9wBAKDfKu7zjInpUbSxBjSiouG8iFtP2EGKjb63AOAjirFf9SepSwe62PsNt0pflwZBKs8xvoH2Y7cnOsHTC33ikbwLFgwiqmK7AtHYzo2BTZAmiDGQvCKZBSdjIR5o5zvgqSZAFiGEU10PVTnXw2fRJzukQ0VEVoZC9VrO7el8hjeg2VoVBFhb9ppPCsHYkPKRWgThKJ76VJS4K3m2X7LwZD 
02-29 18:56:39.092 27510-27510/com.example D/cr_Ime: [ImeAdapter.java:358] onViewFocusChanged: gainFocus [true] 
02-29 18:56:39.119 27510-27510/com.example D/cr_Ime: [ImeAdapter.java:140] onCreateInputConnection returns null. 
02-29 18:56:39.162 27510-27510/com.example I/Timeline: Timeline: Activity_idle id: [email protected] time:227199315 
02-29 18:56:39.163 27510-27510/com.example A/WEBVIEW URL: https://accounts.google.com/o/oauth2/auth?response_type=code&client_id=1234567890-XXXXXXXXXX.apps.googleusercontent.com&redirect_uri=http%3A%2F%2Fexample.com%3A5000%2Fchannel%2Fgmail%2Fcallback&scope=https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fuserinfo.email+https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fgmail.readonly&access_type=offline 
02-29 18:56:39.216 27510-27510/com.example A/WEBVIEW URL: https://accounts.google.com/ServiceLogin?passive=1209600&continue=https://accounts.google.com/o/oauth2/auth?access_type%3Doffline%26scope%3Dhttps://www.googleapis.com/auth/userinfo.email%2Bhttps://www.googleapis.com/auth/gmail.readonly%26response_type%3Dcode%26redirect_uri%3Dhttp://example.com:5000/channel/gmail/callback%26client_id%3D1234567890-XXXXXXXXXX.apps.googleusercontent.com%26hl%3Dnl%26from_login%3D1%26as%3D-231b0767e02a8ca9&ltmpl=popup&oauth=1&sarp=1&scc=1 
02-29 18:56:39.283 27510-27510/com.example I/Timeline: Timeline: Activity_idle id: [email protected] time:227199436 
02-29 18:56:39.287 27510-27510/com.example D/cr_Ime: [ImeAdapter.java:358] onViewFocusChanged: gainFocus [false] 
02-29 18:56:39.287 27510-27510/com.example D/cr_Ime: [ImeAdapter.java:326] hideKeyboard 
02-29 18:56:39.288 27510-27510/com.example D/cr_Ime: [InputMethodManagerWrapper.java:56] isActive: false 

Dal momento che questo registro in realtà non dà un errore, io sono sicuro cosa potrebbe essere sbagliato.

Qualcuno ha idea di cosa potrebbe essere sbagliato o come posso eseguire il debug di questo? Tutti i suggerimenti sono ben accetti!

+0

Forse questo aiuterà: http://stackoverflow.com/questions/12854468/google-oauth-api-not-working-anymore-404-error – domax

+0

Solo un'ipotesi selvaggia: potrebbe essere perché hai permesso l'accesso per essere ricordato e google si autentica correttamente in base all'account google registrato sul tuo dispositivo? Prova a rimuovere l'account google sul tuo dispositivo, a cancellare i dati sulla tua app e riprova. – Codebender

+0

Usa Stetho da facebook http://facebook.github.io/stetho/ per monitorare le comunicazioni tra la tua app con server e il server di google .. –

risposta

1

Probabilmente il codice ha smesso di funzionare a causa di un aggiornamento in alcune parti dell'API che si sta utilizzando; Immagino che potrebbe essere l'aggiornamento da OAuth a OAuth2, o forse un semplice aggiornamento delle patch. La soluzione più semplice sarebbe quella di aggiungere usi permessi e metadati al tuo AndroidManifest.xml:

<uses-permission android:name="android.permission.INTERNET"/> 
<uses-permission android:name="android.permission.GET_ACCOUNTS"/> 
<uses-permission android:name="android.permission.USE_CREDENTIALS"/> 

<meta-data android:name="com.google.android.gms.version" 
      android:value="@integer/google_play_services_version" /> 

Se questo non risolvere il problema, c'è molto probabilmente un problema più grande a portata di mano.

Secondo this post, è preferibile utilizzare onCreate() per eseguire eventuali inizializzazioni non grafiche, poiché viene chiamato prima dello onCreateView(). Al fine di essere in grado di accedere a Google, come indicato nel this post, è necessario prima di selezionare un account dal dispositivo in questo modo (mettere questo nella tua Main.java o MainActivity.java):

public static AccountManager accountManager; 
accountManager = AccountManager.get(this); 
Account[] accounts = accountManager.getAccountsByType("com.google"); 

Quindi, è necessario per ottenere il token dal conto selezionato in questo modo:

private void onAccountSelected(final Account account) { 
    accountManager.getAuthToken(account, AUTH_TOKEN_TYPE, null, this, new AccountManagerCallback<Bundle>() { 
     public void run(AccountManagerFuture<Bundle> future) { 
      try { 
       String token = future.getResult().getString(AccountManager.KEY_AUTHTOKEN); 
       useToken(account, token); 
      } catch (OperationCanceledException e) { 
       onAccessDenied(); 
      } catch (Exception e) { 
       handleException(e); 
      } 
     } 
    }, null); 
} 

Poi, una volta si autentica il token e account, sarà in grado di accedere a google utilizzando OAuth2 (Fare riferimento alla OAuth2 GitHub Source per il codice di autenticazione).

Se hai ancora dei problemi e/o non ho pienamente rispondere alla tua domanda, prova anche this su come utilizzare OAuth2 con AccountManager e chiamate API, o this su come utilizzare OAuth2 con WebView . Quest'ultimo probabilmente riguarda di più le tue esigenze. Entrambi forniscono interi file di esempio su come fare ciò che stai cercando.

Se anche dopo aver letto i due link sopra è ancora necessario aiuto o hai domande o dubbi, non esitate a lasciare un commento!

Problemi correlati