我正在创建允许用户使用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用户信息所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)