上一篇我们已经用最简单的方式,搭建了一个授权方式是 client_credentials 的 Oauth2 的流程。那么现在,在此基础上,我们就再往前迈一步,我们把 client 信息和 token 存储到数据库当中,方便我们管理。并且密码需要保证安全,那么就需要加密。目标很明确,那我们开始吧!
client&token存储到数据库
步骤:
- 数据库准备:只创建我们需要用到的表
- 添加数据库相关依赖:使用 mysql 数据库
- Oauth 存储配置的设置
- 验证
数据库准备
在本地数据库,创建两张表:
- 一张表存储 client 相关信息
- 另一张表存储 token
之后,我们需要添加自定义 client 信息。本次演示添加的 client 信息如下(依旧本着尽量能不配置就不配置的原则):
说明
- 在官方给出的源码当中,是有对应的 schema.sql 文件,这里只创建涉及我们示例中需要的表
- 对两张表的操作,我们可以去看这两个类:JdbcClientDetailsService & JdbcTokenStore
- 此外本示例,添加了 resource_ids ,注意在配置
ResourceServerSecurityConfigurer
中对应
Pom
认证服务器代码修改
上述代码只显示改动的部分,修改 client 的配置和 tokenStore 的配置,都进行添加数据源即可
请求 token
下面的请求是在 postman 中进行的。 base_url 为设置的全局变量,实际为 http://127.0.0.1:8080
获取资源
观察数据库
由于 token 在数据库是存储的是二进制形式,但是我们通过 client_id 数据,可以看出是我们刚刚请求的 client。
到此为止我们已经是实现了,把 client 及 token 信息存储到数据库了,这样更便于我们对 client 及 token 数据的管理。但是数据库存储明文密码是不安全,那么接下来,我们对 client_secret 进行加密。
client_secret 加密
配置 passwordEncoder
SpringBoot Oauth 本身支持的加密算法有很多种,详细信息可以看类 PasswordEncoderFactories
,包括我们最常用的 MD5、SHA 等,我们使用 bcrypt 加密算法, 那么直接配置支持全部算法的 passwordEncoder ,即 DelegatingPasswordEncoder
。
加密 client_secret
既然我们这次使用 bcrypt 加密, 直接可以找到 BCryptPasswordEncoder
,通过它可以给我们的密码进行加密,并把密码存储于数据库当中。
原密码:123456
加密后密码:{bcrypt}$2a$10$NPxtsEUMmBGTlzVXlT.scubSCXNEDlBAq2r2t7iQFB/.RaNBlh0nO
注意:加密密码的前缀 大括号 {xxx}
,是指定算法名称。因为框架支持多种算法,那么必须需要带有算法前缀。
请求获取 token
下面的请求是在 postman 中进行的。 base_url 为设置的全局变量,实际为 http://127.0.0.1:8080
请求资源
小结
本文主要是以 client_credentials 的授权方式,把 client 和 token 信息存储在数据库当中,来方便我们管理。同时,为了保证密码的安全,我们把 client_secret 用 bcrypt 算法进行了加密操作,并存储到数据库当中。有了上一篇基础,这篇整体挺简单的吧,那同学们动起来,实现一下吧!
个人水平有限,欢迎大家指正,一起交流哦~~~
demo:https://github.com/goldpumpkin/learn-demo/tree/master/springboot-oauth
Reference:
- spring-oauth-server 数据库表说明