android OAuth-2.0谷歌登录使用webview用户信息
作者:互联网
我正在创建允许用户使用Facebook或Google帐户登录的应用程序.他们按下“登录”按钮,然后在弹出的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 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.如果要自己实现该流程,请使用“其他应用程序类型”,您将获得所需的客户端密码.
标签:oauth-2-0,userinfo,android 来源: https://codeday.me/bug/20191127/2076644.html