2016-02-29 3 views
9

Я работаю над приложением, которое выполняет аутентификацию oauth2, которая раньше работала, но, к сожалению, больше не работает. Насколько я знаю (но не на 100% уверен) ничего не изменилось в коде, поэтому я не знаю, почему это больше не будет работать.Почему в моем приложении Android не работает gmail oauth?

приложение создает WebView и загружает URL с нашего сервера, который перенаправляет его на Google для аутентификации на этот адрес (только что изменили идентификатором клиента и мой домен):

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 

который сразу же перенаправляет его:

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 

Такая же система используется в нашем iOS-приложении, которое работает как шарм. Поэтому в нашей реализации сервера нет ничего плохого. После того, как веб-просмотр перенаправлен на google, он автоматически вернется в приложение, не показывая экран Google. Я использую следующий код, чтобы открыть 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; 
} 

и выход LogCat выглядит следующим образом:

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 

Поскольку этот журнал действительно не дает ошибку, я не уверен что может быть неправильно.

Кто-нибудь знает, что может быть неправильным или как я могу отладить это? Все советы приветствуются!

+0

Возможно, это поможет: http://stackoverflow.com/questions/12854468/google-oauth-api-not-working-anymore-404-error – domax

+0

Просто дикое предположение: это может быть потому, что вы разрешили доступ чтобы запомниться и Google успешно прошла проверку подлинности на основе учетной записи google, зарегистрированной на вашем устройстве? Попробуйте удалить учетную запись google на своем устройстве, очистите данные в своем приложении и повторите попытку. – Codebender

+0

Используйте Stetho из facebook http://facebook.github.io/stetho/ для мониторинга связи между вашим приложением с сервером и сервером google. –

ответ

1

Скорее всего, вы перестали работать из-за обновления в той части API, которую используете; Я предполагаю, что он может обновляться с OAuth до OAuth2 или, возможно, с простым обновлением патча. Самое простое решение было бы добавить использует разрешения и метаданные для вашего 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" /> 

Если это не исправить это, то, скорее всего, большая проблема под рукой.

Согласно this post, лучше использовать onCreate() для выполнения каких-либо неграфических инициализаций, так как он вызывается до onCreateView(). Для того, чтобы иметь возможность войти в Google, как указано в this post, в первую очередь необходимо выбрать учетную запись с устройства, как так (это в вашем Main.java или MainActivity.java):

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

Затем вам нужно получить маркер с выбранной учетной записи следующим образом:

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); 
} 

Затем, когда вы аутентификации токена и счета, вы сможете войти в Google с помощью oauth2 (Обратитесь к OAuth2 GitHub Source для кода аутентификации).

Если вы все еще возникают проблемы, и/или я не полностью ответить на ваш вопрос, проверить this о том, как использовать oauth2 с AccountManager и вызовов API, или this о том, как использовать oauth2 с WebView , Последнее, вероятно, больше относится к вашим потребностям. Оба дают целые примеры файлов о том, как делать то, что вы ищете.

Если даже после прочтения двух ссылок выше вам еще нужна помощь или есть вопрос или беспокойство, не стесняйтесь оставить комментарий!

Смежные вопросы