并发(个人收集)SpringBoot-Security学习

SpringBootSecurity学习(17)前后端分离版之

2019-10-09  本文已影响0人  郭艺宾

自动批准授权码

前面我们授权的流程中,第一步获取授权码的时候,都会经历一个授权是否同意页面:

file

这个流程就像第三方登录成功后,提问是否允许获取昵称和头像信息的页面一样,这个过程其实是可以自动同意的,需要在客户端配置中,增加一个自动批准:

file

这样我们申请授权码直接就可以得到:

file

在流程需要自动完成的时候,需要这样配置,如果需要用户点击同意,那么这里需要设置为false,不写默认也是false。

客户端信息整理

上面的自动批准只是客户端配置中一个小的配置,下面我们来系统整理一下客户端所有可配置的内容。首先来看现在已经配置的6个字段:

file

上面的6个字段是我们最常用的也是不可或缺的客户端信息。不过客户端的配置还有很多其它的字段,我们来整体看一下:

file

上面的11个字段基本上包括了所有的第三方客户端的配置内容。下面来一个个详细讲解:

下面我们在数据库中新建一张表,定义这是十一个字段,表名为 oauth_client_details:

file

注意,这里表名必须是 oauth_client_details 是 oauth规定的表名,也是默认的jdbc操作中的表名。我们来增加一条记录:

file

相比前面的例子,这里多了一个resource_ids的字段值,其它的都和前面的配置一样。注意secret存储的是加密后的密文,加密前是secret。

授权服务多了一个resource_id,资源服务也得配置自己的id:

file

默认的jdbc管理客户端

将配置死的客户端信息改为jdbc从客户端查询的方式很简单,首先引入数据库依赖:

file

然后配置数据源:

file

最后修改授权配置类的客户端配置:

file

可以看到修改后的客户端配置很简单,只需要在客户端配置一个jdbc数据源即可,查询方法是自动实现的。关于实现,可以参考源码:

里面有写好的sql语句和增删改查逻辑:

file

其中有个更新秘钥的方法,是需要加密方式的:

file

所以我们可以在jdbc方法后面配置加密方式:

file

测试

上面的除了数据库,其它的配置修改很简单,下面来测试一下:

file

访问结果:

file

具体流程和前面一样。

代码地址: https://gitee.com/blueses/spring-boot-security 19 20

上一篇下一篇

猜你喜欢

热点阅读