美文网首页Java 核心技术Java
那些年我们一起优化的SQL

那些年我们一起优化的SQL

作者: 一只程序猿哟 | 来源:发表于2022-04-02 13:56 被阅读0次

这篇文章介绍下网关层如何集成RBAC权限模型进行认证鉴权,文章目录如下:

什么是RBAC权限模型?

RBAC(Role-Based Access Control)基于角色访问控制,目前使用最为广泛的权限模型。

相信大家对这种权限模型已经比较了解了。此模型有三个用户角色权限,在传统的权限模型用户直接关联加了角色层,解耦了用户和权限,使得权限系统有了更清晰的职责划分和更高的灵活度。

以上五张表的SQL就不再详细贴出来了,都会放在案例源码的doc目录下,如下图:

设计思路

RBAC权限模型是基于角色的,因此在Spring Security中的权限就是角色,具体的认证授权流程如下:

用户登录申请令牌

通过UserDetailService查询、加载用户信息、比如密码、权限(角色)....封装到UserDetails

令牌申请成功,携带令牌访问资源

网关层面比较访问的URL所需要的权限(Redis中)是否与当前令牌具备的权限有交集。有交集则表示具备访问该URL的权限。

具备权限则访问,否则拒绝

上述只是大致的流程,其中还有一些细节有待商榷,如下:

1、URL对应的权限如何维护?

这个就比较容易实现了,涉及到RBAC权限模式的三张表,分别为权限表角色表权限角色对应关系表。具体实现流程如下:

项目启动时将权限(URL)和角色的对应关系加载到Redis中。

对于管理界面涉及到URL相应关系的变动要实时的变更到Redis。

比如权限中有这么一条数据,如下:

其中的 /order/info 这个URL就是一个权限,管理员可以对其分配给指定的角色。

2、如何实现Restful风格的权限控制?

restful风格的接口URL是相同的,不同的只是请求方式,因此要想做到权限的精细控制还需要保留请求方式,比如POST,GET,PUT,DELETE....

可以在权限表中的url字段放置一个method标识,比如POST,此时的完整URL为:POST:/order/info

当然*:/order/info中的星号表示一切请求方式都满足。

3、这样能实现动态权限控制吗?

权限的控制方式有很多种,比如Security自身的注解、方法拦截,其实扩展Spring Security也是可以实现动态权限控制的,这个在后面的文章中会单独介绍!

陈某此篇文章是将权限、角色对应关系存入Redis中,因此想要实现动态权限控制只需要在Redis中维护这种关系即可。Redis中的数据如下:

案例实现

涉及到的更改目录如下图:

1、从数据库加载URL<->角色对应关系到Redis

在项目启动之初直接读取数据库中的权限加载到Redis中,当然方法有很多种,自己根据情况选择。代码如下:

此处代码在oauth2-cloud-auth-server模块下。

2、实现UserDetailsService加载权限

UserDetailsService相信大家都已经很熟悉了,主要作用就是根据用户名从数据库中加载用户的详细信息。

代码如下:

处的代码是将通过JPA从数据库中查询用户信息并且组装角色,必须是以 ROLE_ 开头。

处的代码是将获取的角色封装进入authorities向下传递。

此处代码在oauth2-cloud-auth-server模块下。

3、鉴权管理器中校验权限

在上篇文章中实战干货!Spring Cloud Gateway 整合 OAuth2.0 实现分布式统一认证授权!详细介绍了鉴权管理器的作用,这里就不再细说了。代码如下:

处的代码是将请求URL组装成restful风格的,比如POST:/order/info

处的代码是从Redis中取出URL和角色对应关系遍历,通过AntPathMatcher进行比对,获取当前请求URL的所需的角色。

处的代码就是比较当前URL所需的角色和当前用户的角色,分为两步:

如果是超级管理员,则直接放行,不必比较权限

不是超级管理员就需要比较角色,有交集才能放行

此处的代码在oauth2-cloud-gateway模块中。

附加的更改

这篇文章中顺带将客户端信息也放在了数据库中,前面的文章都是放在内存中。

数据库中新建一张表,SQL如下:

CREATETABLE`oauth_client_details`(`client_id`varchar(48)NOTNULLCOMMENT'客户端id',`resource_ids`varchar(256)DEFAULTNULLCOMMENT'资源的id,多个用逗号分隔',`client_secret`varchar(256)DEFAULTNULLCOMMENT'客户端的秘钥',`scope`varchar(256)DEFAULTNULLCOMMENT'客户端的权限,多个用逗号分隔',`authorized_grant_types`varchar(256)DEFAULTNULLCOMMENT'授权类型,五种,多个用逗号分隔',`web_server_redirect_uri`varchar(256)DEFAULTNULLCOMMENT'授权码模式的跳转uri',`authorities`varchar(256)DEFAULTNULLCOMMENT'权限,多个用逗号分隔',`access_token_validity`int(11)DEFAULTNULLCOMMENT'access_token的过期时间,单位毫秒,覆盖掉硬编码',`refresh_token_validity`int(11)DEFAULTNULLCOMMENT'refresh_token的过期时间,单位毫秒,覆盖掉硬编码',`additional_information`varchar(4096)DEFAULTNULLCOMMENT'扩展字段,JSON',`autoapprove`varchar(256)DEFAULTNULLCOMMENT'默认false,是否自动授权',  PRIMARYKEY(`client_id`))ENGINE=InnoDBDEFAULTCHARSET=utf8;

认证服务中的OAuth2.0的配置文件中将客户端的信息从数据库中加载,该实现类为JdbcClientDetailsService,关键代码如下:

@Overridepublicvoidconfigure(ClientDetailsServiceConfigurer clients)throwsException{//使用JdbcClientDetailsService,从数据库中加载客户端的信息clients.withClientDetails(newJdbcClientDetailsService(dataSource));    }

总结

本篇文章介绍了网关集成RBAC权限模型进行认证鉴权,核心思想就是将权限信息加载Redis缓存中,在网关层面的鉴权管理器中进行权限的校验,其中还整合了Restful风格的URL。

相关文章

  • 那些年我们一起优化的SQL

    一、背景 随着业务不断迭代,系统中出现了较多的SQL慢查。慢查虽不致命,但会让商家感知到系统较慢,影响使用体验。在...

  • 那些年我们一起优化的SQL

    这篇文章介绍下网关层如何集成RBAC权限模型进行认证鉴权,文章目录如下: 什么是RBAC权限模型? RBAC(Ro...

  • MySQl优化学习笔记(七)SQL优化简介

    一、SQL优化简介 1、我们平时说的SQL优化就是优化SQl语句和索引(通俗说就是使用什么样的SQL语句能够让索引...

  • 常用sql优化2019-09-27

    sql优化 sql优化.................................................

  • MySQL执行计划

    1. 是什么? 它是一个关键字。我们知道我们写的SQL,执行之前要经过优化器的优化,所以我们写的SQL经过SQL优...

  • mysql数据库优化

    1. Mysql优化介绍 1.1 sql优化 a. sql优化分析b. 索引优化c. 常用sql优化d. 常用优化...

  • Mysql 优化

    1.Sql优化 1)sql优化分析2)索引优化3)sql语句优化4)一些常用的技巧优化 (正则、函数) 2.优化数...

  • SQL优化分享

    SQL优化分享 最近公司部门内部进行了一次分享,是总工给我们进行的一次关于SQL优化的内容。相信关于SQL的优化也...

  • MySQL学习笔记-SQL优化万能公式:5 大步骤 + 10 个

    SQL优化一般步骤 步骤1、通过慢查日志等定位那些执行效率较低的SQL语句 步骤2、explain 分析SQL的执...

  • SQL优化器原理 - 查询优化器综述

    这是MaxCompute有关SQL优化器原理的系列文章之一。我们会陆续推出SQL优化器有关优化规则和框架的其他文章...

网友评论

    本文标题:那些年我们一起优化的SQL

    本文链接:https://www.haomeiwen.com/subject/jqsajrtx.html