我试图将OAuth支持添加到现有的Spring中,允许用户使用他们的Google/Facebook/Twitter/等等登录。为此,我使用了“spring-social”框架和“spring-social-google”库。我还试图在许多限制条件下工作时做到这一点:
Principal跟踪经过身份验证的用户详细信息,而是在HTTP会话中存储对经过身份验证的用户的引用。/)。数据库中的帐户被电子邮件唯一地键控,所以我真正想要做的就是把一个流粘合在一起,这个流大概是这样的:
Login Page (user chooses between OAuth and direct login)
-> <Provider OAuth Flow> (user completes OAuth authorization)
-> OAuth Callback URL (grab user email, check for existing account, create if needed)
-> Post-login Landing Page (done)无论如何,上面提到的限制引起了各种各样的问题,其中大部分我已经找到了解决办法。然而,我从Google OAuth连接器上得到了一些奇怪的行为(Twitter和Facebook似乎工作正常)。基本上,在最终请求期间,它似乎没有向Google发送OAuth clientId或clientSecret:
DEBUG: org.springframework.web.client.RestTemplate - Writing [
{code=[4/dVVrFDpNLDGTmXCuuQj6fcfaetEU.UkLPQd7NOLYbgrKXntQAax0INYiydQI],
redirect_uri=[http://localhost:8080/oauth/signin/google],
grant_type=[authorization_code]}] as "application/x-www-form-urlencoded"这将返回一个代码400 (“坏请求”)。
如果我转到hurl.it并将相同的数据发送到同一个URL (https://accounts.google.com/o/oauth2/token),并手动添加client_id和client_secret值,则调用将返回一个成功的响应。
那么,是什么原因导致Google连接器忽略了这些值呢?
作为参考,我在我的项目中包括了spring-social-google库,比如:
<dependency>
<groupId>org.springframework.social</groupId>
<artifactId>spring-social-google</artifactId>
<version>1.0.0.M1</version>
</dependency>...and,在我的@Configuration课堂上,我得到了:
@Bean
@Scope(value="singleton", proxyMode=ScopedProxyMode.INTERFACES)
public ConnectionFactoryLocator connectionFactoryLocator() {
ConnectionFactoryRegistry registry = new ConnectionFactoryRegistry();
registry.addConnectionFactory(
new GoogleConnectionFactory(
"<google client id>",
"<google secret key>"));
registry.addConnectionFactory(
new FacebookConnectionFactory(
"<facebook client id>",
"<facebook secret key>"));
registry.addConnectionFactory(
new TwitterConnectionFactory(
"<twitter client id>",
"<twitter secret key>"));
return registry;
}我使用的其余部分基本上是标准的,直接从春季社交展示例中提取出来(尽管是为了删除无关的内容并在上面提到的约束范围内工作)。奇怪的是,尝试使用谷歌登录会正确显示谷歌上的OAuth授权页面,我的应用程序/项目名称也会正确显示。这个错误发生在我点击“允许”按钮来授权OAuth登录并返回到webapp之后。
无论如何,造成这个问题的原因是什么,如何解决呢?
发布于 2015-01-19 00:49:43
您可能还没有在控制台中打开google+ api。
这是一个与获取OAuth 2令牌或api键不同的任务。
如果你还没有这样做
https://stackoverflow.com/questions/13263821
复制相似问题