android OAuth-2.0 google登录使用webview获取用户信息

标签 android oauth-2.0 userinfo

我正在创建允许用户使用 facebook 或 google 帐户登录的应用程序。他们按下“登录”按钮,然后他们被要求使用 facebook 或 google 登录,当他们选择其中之一时,webview 会弹出。

问题出在谷歌验证上,阅读了一些文章并搜索了网络,仍然可以在没有客户管理器的情况下进行谷歌登录,我知道他们改变了一些东西。

如果可能的话,也许我可以处理一些例子或看到它工作。 我试过这个:http://blog.doityourselfandroid.com/2011/08/06/oauth-2-0-flow-android/ 只是编辑不做纬度但用户信息总是得到错误 400。

感谢您的帮助,到目前为止你们都帮了很多忙!

编辑: 关于错误:我收到 400 错误请求 我通常知道哪一行有什么问题。

问题出在我创建 AccessTonekResponse 并执行的地方,因为它需要客户端密码,而且我无法在 google api 页面上找到客户端密码,仅在网络应用程序中没有安装的应用程序。

        public void onPageStarted(WebView view, String url,Bitmap bitmap)  {  
            System.out.println("onPageStarted : " + url);
        }
        @Override  
        public void onPageFinished(WebView view, String url)  {  

            if (url.startsWith(OAuth2ClientCredentials.REDIRECT_URI)) {
                try {

                    if (url.indexOf("code=")!=-1) {

                        String code = extractCodeFromUrl(url);
                        System.out.println(code);
                          AccessTokenResponse accessTokenResponse = new GoogleAuthorizationCodeGrant(new NetHttpTransport(),
                                          new JacksonFactory(),
                                          OAuth2ClientCredentials.CLIENT_ID,
                                          OAuth2ClientCredentials.CLIENT_SECRET,
                                          code,
                                          OAuth2ClientCredentials.REDIRECT_URI).execute();

                          CredentialStore credentialStore = new SharedPreferencesCredentialStore(prefs);
                          credentialStore.write(accessTokenResponse);
                          view.setVisibility(View.INVISIBLE);
                          startActivity(new Intent(OAuthAccessTokenActivity.this,LatitudeApiSample.class));
                    } else if (url.indexOf("error=")!=-1) {
                        view.setVisibility(View.INVISIBLE);
                        new SharedPreferencesCredentialStore(prefs).clearCredentials();
                        startActivity(new Intent(OAuthAccessTokenActivity.this,LatitudeApiSample.class));
                    }

                } catch (IOException e) {
                    e.printStackTrace();
                    System.out.println(e.getLocalizedMessage());
                }

            }
            System.out.println("onPageFinished : " + url);

        }

错误代码:

08-22 09:22:07.866: W/System.err(391): com.google.api.client.http.HttpResponseException: 400 Bad Request
08-22 09:22:07.866: W/System.err(391):  at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:380)
08-22 09:22:07.876: W/System.err(391):  at com.google.api.client.auth.oauth2.draft10.AccessTokenRequest.executeUnparsed(AccessTokenRequest.java:457)
08-22 09:22:07.876: W/System.err(391):  at com.google.api.client.auth.oauth2.draft10.AccessTokenRequest.execute(AccessTokenRequest.java:473)
08-22 09:22:07.876: W/System.err(391):  at com.ecs.android.sample.oauth2.OAuthAccessTokenActivity$1.onPageFinished(OAuthAccessTokenActivity.java:79)
08-22 09:22:07.876: W/System.err(391):  at android.webkit.CallbackProxy.handleMessage(CallbackProxy.java:274)
08-22 09:22:07.896: W/System.err(391):  at android.os.Handler.dispatchMessage(Handler.java:99)
08-22 09:22:07.896: W/System.err(391):  at android.os.Looper.loop(Looper.java:123)
08-22 09:22:07.896: W/System.err(391):  at android.app.ActivityThread.main(ActivityThread.java:4627)
08-22 09:22:07.896: W/System.err(391):  at java.lang.reflect.Method.invokeNative(Native Method)
08-22 09:22:07.896: W/System.err(391):  at java.lang.reflect.Method.invoke(Method.java:521)
08-22 09:22:07.896: W/System.err(391):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
08-22 09:22:07.896: W/System.err(391):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
08-22 09:22:07.896: W/System.err(391):  at dalvik.system.NativeStart.main(Native Method)

最佳答案

您可能在 Google's API Console 中创建了您的客户端 ID作为应用程序类型为 Android 的已安装应用程序。这仅适用于 AuthenticationManager。如果您想自己实现流程,请使用应用程序类型其他,您将获得所需的客户端密码

关于android OAuth-2.0 google登录使用webview获取用户信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12063097/

相关文章:

php - Android PostResponseAsyncTask 无法从 android 获取字符串

android - ProGuard for Android 和 Retrofit2 Converter Gson?

oauth-2.0 - 如何使用 OIDC/OAuth 保护 API

gmail - 如何获得对 GMail 的 OAuth 访问权限?

c# - 使用 Azure ActiveDir oAuth2.0 JWT token 的 Asp-Net-Core WebApi 身份验证 Microsoft Graph

ios - 调用 CLLocation 中的额外参数 'userinfo'

c# - 无法在 UWP 应用程序中获取某些用户帐户信息 - 内部事件目录(不是 Azure AD)

android - 以编程方式从自定义android键盘更改键盘

android - 系统应用是否有权限访问/system目录?