android OAuth-2.0谷歌登录使用webview用户信息

android OAuth-2.0谷歌登录使用webview用户信息,第1张

概述我正在创建允许用户使用Facebook或Google帐户登录的应用程序.他们按下“登录”按钮,然后在d出的Webview中选择其中之一时,他们被要求使用Facebook或google登录.问题是谷歌的身份认证,阅读一些文章并在网上搜索,仍然可以在没有帐户管理器的情况下进行谷歌登录,我知道他们改变了一

我正在创建允许用户使用Facebook或Google帐户登录的应用程序.他们按下“登录”按钮,然后在d出的WebvIEw中选择其中之一时,他们被要求使用Facebook或Google登录.

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

如果可能的话,也许可以举一些我可以研究或看到的例子.
我尝试了这个:http://blog.doityourselfandroid.com/2011/08/06/oauth-2-0-flow-android/
只是编辑而不是做纬度而是用户信息,总是出现错误400.

感谢您的帮助,到目前为止,大家都提供了很多帮助!

编辑:
关于错误:我收到exeption 400错误的请求,我通常知道哪条线是什么问题.

问题出在哪里我创建AccesstonekResponse并执行,因为它需要客户端密码,而我只能在Web应用程序中的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 Request08-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.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谷歌登录使用webview用户信息全部内容,希望文章能够帮你解决android OAuth-2.0谷歌登录使用webview用户信息所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1075344.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-26
下一篇 2022-05-26

发表评论

登录后才能评论

评论列表(0条)

保存