我最近为我的OAuth2提供程序实现了client_credentials授权,该授权基于Spring安全性OAuth2。
比我移动到客户端实现那里的机制。
我添加了@EnableOAuth2Client
注释并设置了以下配置:
spring:
oauth2:
client:
id: myResource
clientId: myClientId
clientSecret: myClientSecret
accessTokenUri: http://localhost:8080/oauth/token
grantType: client_credentials
我不清楚我为什么需要添加ID设置。根据错误消息,提供者管理器需要支持它。 这是我得到的错误:
无法为资源' myResource'获取新的访问令牌。提供程序管理器未配置为支持它。
在网上搜索了一段时间后,我发现我需要添加DelegatingFilterProxy的全局servlet,该servlet委托给名为" oauth2ClientContextFilter"
的bean。我找到了一些关于如何做的实现,但他们都使用XML而不是注释来设置他们的配置。
<filter>
<filter-name>myFilter</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
<filter-name>myFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
总之:
提前致谢
答案 0 :(得分:1)
所以我设法解决了我的问题 把它搁置一段时间后,我再试一次 我的OAuth2RestTemplate似乎使用了错误的ResourceDetails类 所以更换
AuthorizationCodeResourceDetails resource = new AuthorizationCodeResourceDetails();
带
ClientCredentialsResourceDetails resource = new ClientCredentialsResourceDetails();
修复了问题。