AWS Cognito Angular SpringBoot Oauth2 - ошибка invalid_token
Мы используем AWS Cognito для Oauth2. Наш пользовательский интерфейс построен на Angular. После того, как мой пользователь вошел в систему, я инициирую вызов Cognito для получения токена авторизации. Я использую код авторизации с PKCE для получения токена от Cognito. После получения токена от Cognito я звоню в службу REST Spring Boot. При вызове службы Spring Boot из Angular я отправляю токен в заголовке Authorization как токен "Bearer".
Вот мой ResourceServerConfiguration.java:
import org.springframework.context.annotation.Configuration;
import org.springframework.http.HttpMethod;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.oauth2.config.annotation.web.configuration.EnableResourceServer;
import org.springframework.security.oauth2.config.annotation.web.configuration.ResourceServerConfigurerAdapter;
import org.springframework.security.oauth2.config.annotation.web.configurers.ResourceServerSecurityConfigurer;
@Configuration
@EnableResourceServer
public class ResourceServerConfiguration extends ResourceServerConfigurerAdapter {
private static final String RESOURCE_ID = "resource-server-rest-api";
private static final String SECURED_READ_SCOPE = "#oauth2.hasScope('openid')";
private static final String SECURED_WRITE_SCOPE = "#oauth2.hasScope('openid')";
private static final String SECURED_PATTERN = "/**";
@Override
public void configure(ResourceServerSecurityConfigurer resources) {
resources.resourceId(RESOURCE_ID);
}
@Override
public void configure(HttpSecurity http) throws Exception {
http.requestMatchers()
.antMatchers(SECURED_PATTERN).and().authorizeRequests()
.antMatchers(HttpMethod.POST, SECURED_PATTERN).access(SECURED_WRITE_SCOPE)
.anyRequest().access(SECURED_READ_SCOPE);
}
}
При вызове службы REST мой Angular UI получает HTTP-ответ 401 со следующим сообщением об ошибке:
DEBUG o.s.s.o.p.a.OAuth2AuthenticationProcessingFilter - Authentication request failed: error="invalid_token", error_description="Invalid access token: eyJraWQiOiIy.......
- Любая идея, почему я получаю invalid_token?
- Spring звонит в Cognito, чтобы проверить токен?
- Я НЕ храню токен в моем слое REST. Это обязательно?
- Я включил DEBUG, используя logging.level.root=DEBUG. Но я не вижу описательного сообщения в выводе. Как мне решить эту проблему?
Заранее спасибо за любую помощь в решении этой проблемы.
0 ответов
Приведенные ниже изменения сработали для меня
Удалить @EnableResourceServer
Добавьте ниже в свою конфигурацию безопасности Spring
http.authorizeRequests().antMatchers(HttpMethod.OPTIONS,"**").permitAll()
.anyRequest()
.authenticated()
.and().oauth2ResourceServer().jwt();
- добавление ниже 2 зависимости к pom.xml
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-oauth2-resource-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-oauth2-jose</artifactId>
</dependency>
- наконец, добавьте следующие свойства в свой application.yml
spring:
security:
oauth2:
resourceserver:
jwt:
issuer-uri: https://cognito-idp.us-east-1.amazonaws.com/{{userpoolid}}
com:
ixortalk:
security:
jwt:
aws:
userPoolId: {{userpoolid}}
region: "us-east-1"