Spring-security-oauth2 与 Spring-
spring security 认证流程:
data:image/s3,"s3://crabby-images/56fbc/56fbc82f3c7ecf85d216e09859af5f6ffa7a9fe4" alt=""
spring security 权限校验流程:
data:image/s3,"s3://crabby-images/0c4cd/0c4cd343f9d09d96940d1fb3011e78252f5a7b73" alt=""
以上流程图源自:
http://www.spring4all.com/article/439
http://www.spring4all.com/article/458
关键的类和接口介绍:
AbstractAuthenticationProcessingFilter 类:在不同maven包下的展现形式:
spring-boot-starter-security包下:
data:image/s3,"s3://crabby-images/e1f83/e1f8329ee3a34cc772f2eac6162d14ed13c7a5d5" alt=""
spring-security-oauth2包下:
data:image/s3,"s3://crabby-images/f539b/f539b3eeea82cc4dafcf8e68c97ba58242d934c1" alt=""
data:image/s3,"s3://crabby-images/cd7fe/cd7fe628dd53c97e036825f50d9801b25005d8d0" alt=""
可以看出多了一个OAuth2ClientAuthenticationProcessingFilter和ClientCredentialsTokenEndpointFilter;
当使用Oauth2认证时,主要走的两个Filter;
AuthenticationManager 接口:认证时主要是PrividerManager 实现类去做认证;
data:image/s3,"s3://crabby-images/95b1a/95b1a442382043f98b2967631bb76149ca7cafad" alt=""
PrividerManager 实现类中主要的方法和属性介绍:
认证器集合:providers
data:image/s3,"s3://crabby-images/887f9/887f9adeaf07da132b13657a846aca9ce4eaadab" alt=""
authenticate 方法:
data:image/s3,"s3://crabby-images/8b3b7/8b3b7a59d631cf34bdd7510d3a833ad528e43720" alt=""
1. 遍历认证器.
2.判断认证器是否支持token的认证
3.如果支持,进行具体的认证逻辑
AuthenticationProvider 接口:
data:image/s3,"s3://crabby-images/8542c/8542c9106703fb7d7c36ad1d247b8c86a641ae17" alt=""
AbstractUserDetailsAuthenticationProvider 抽象类:
authenticate 方法:
data:image/s3,"s3://crabby-images/48c5b/48c5ba2d77589eda47c5dd1b902067fe57c01531" alt=""
子类实现retrieveUser 方法,通过不同的方式获取UserDetails;
DaoAuthenticationProvider 实现类(去实现retrieveUser ):
retrieveUser方法:
data:image/s3,"s3://crabby-images/57c5b/57c5bbf3b88282314357ec32d5411898720620d5" alt=""
通过UserDetailsService 对象获取UserDetails对象;
UserDetailsService 属性:
data:image/s3,"s3://crabby-images/a8991/a899174230ece90f5da56223f55fbb8f47484d35" alt=""
UserDetailsService 接口:
spring-boot-starter-security包下:
data:image/s3,"s3://crabby-images/614ce/614ce9f99621c03b10de49f003286b8964e3f8be" alt=""
spring-security-oauth2包下:
data:image/s3,"s3://crabby-images/a6d0a/a6d0ab85d2c17ed87442db43002fd7fefeae6866" alt=""
可以看出在spring-security-oauth2包下多一个ClientDetailsUserDetailsService类,这个也就是spring security实现Oauth2的主要认证类;