【Spring Security OAuth2】客户端授权模式(client credentials)~授权服务配置

本文以最简配置搭建一个授权服务,让大家初步了解授权服务及相关表。
token 存于数据库中
例子基于Spring Boot 2.1.7.RELEASE ,使用mysql数据库

参考资源: Authorization Server Configuration

  • 添加一个实现了AuthorizationServerConfigurer接口的实现类且使用@EnableAuthorizationServer注解进行标注

AuthorizationServerConfigurer接口的实现类是AuthorizationServerConfigurerAdapter ,这里我们继承AuthorizationServerConfigurerAdapter

/**
 * Created by liuquan on 2019/8/11.
 */
@Configuration
@EnableAuthorizationServer
public class CustomAuthorizationServerConfigurer extends AuthorizationServerConfigurerAdapter {
   

    @Override
    public void configure(AuthorizationServerSecurityConfigurer security) throws Exception {
   
    
    }

    @Override
    public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
   

    }

    @Override
    public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {
   

    }
}

@EnableAuthorizationServer注解会导入两个配置类AuthorizationServerEndpointsConfigurationAuthorizationServerSecurityConfiguration

  • 我们来看看AuthorizationServerEndpointsConfiguration这个配置类在这里插入图片描述
    init()会调用AuthorizationServerConfigurer接口中的configure(AuthorizationServerEndpointsConfigurer endpoints)方法,稍后我们将重写该方法
    在这里插入图片描述
    这里可以看出,如果我们没有为AuthorizationServerEndpointsConfigurer设置tokenService属性,则默认使用DefaultTokenServices
    在这里插入图片描述
    从上图可以看到DefaultTokenServices中设置了TokenStore对象,那TokenStore是做什么用的呢?

Persistence interface for OAuth2 tokens.

从代码中的注释可以知道TokenStore是:OAuth2 令牌的持久化接口。其实现类有多个,如下图:
在这里插入图片描述
在这里插入图片描述
如果没有为AuthorizationServerEndpointsConfigurer对象设置tokenStore属性,则默认采用JwtTokenStoreInMemoryTokenStore,本例子采用数据库存储token,故重写AuthorizationServerConfigurer接口中的configure(AuthorizationServerEndpointsConfigurer endpoints)方法设置tokenStore

@Configuration
@EnableAuthorizationServer
public class CustomAuthorizationServerConfigurer extends AuthorizationServerConfigurerAdapter {
   

    @Autowired
  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值