我是Spring Security的新手,并尝试使用主机名:8080下运行的OAuth2通过Google登录开发Spring Boot应用程序。该应用程序位于Apache反向代理服务器https://url.com后面。
Spring Boot版本2.1.0
Spring Security版本5.1.1
build.gradle:
dependencies {
implementation("org.springframework.boot:spring-boot-starter-web")
implementation("org.springframework.boot:spring-boot-starter-security")
implementation("org.springframework.security:spring-security-oauth2-client")
implementation("org.springframework.security:spring-security-oauth2-jose")
}
application.yml:
oauth2:
client:
registration:
google:
clientId: <clientId>
clientSecret: <clientSecret>
scope: profile, email, openid
server:
use-forward-headers: true
servlet:
session:
cookie:
http-only: false
Spring Security配置:
@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http
.csrf()
.disable()
.authorizeRequests()
.anyRequest()
.authenticated()
.and()
.oauth2Login();
}
}
[invalid_token_response]尝试执行错误时 检索POST上的OAuth 2.0访问令牌响应:I / O错误 请求“ https://www.googleapis.com/oauth2/v4/token”:连接 超时(连接超时);嵌套异常为 java.net.ConnectException:连接超时(连接超时)
此错误是由代理服务器设置或启动应用引起的吗?感谢您的帮助。
答案 0 :(得分:0)
已解决。我必须设置JVM参数:
https.proxyHost=[host]
https.proxyPort=[port]
http.proxyHost=[host]
http.proxyPort=[port]