01、故事背景
在实际的软件系统开发过程中,由于业务的需求,在代码层面实现数据的脱敏还是远远不够的,往往还需要在数据库层面针对某些关键性的敏感信息,例如:身份证号、银行卡号、手机号、工资等信息进行加密存储,实现真正意义的数据混淆脱敏,以满足信息安全的需要。
那在实际的业务开发过程中,我们如何快速实现呢?
今天通过这篇文章,我们一起来了解一下如何在 Spring Boot 中快速实现数据的加解密功能。废话不多说了,直接撸代码!
02、方案实践
在 Spring Boot 生态中,有一个非常厉害的开源框架:Apache ShardingSphere。
它是一款分布式 SQL 事务和查询引擎,可通过数据分片、弹性伸缩、加密等能力对任意数据库进行增强。我们可以利用它的数据脱敏模块,快速实现 SQL 字段的加解密操作。
如果当前项目是采用 Spring Boot 开发的,可以实现无缝集成,对原系统的改造会非常少。
下面以用户表为例,一起了解一下ShardingSphere的数据加解密的实现过程!
2.1、创建用户表
首先,在数据库中创建一张用户表,示例脚本如下!
2.2、创建 springboot 项目并添加依赖包
接着,创建一个 Spring Boot 项目,并添加相关的依赖包,示例如下:
2.3、添加相关配置
在application.properties文件中,添加shardingsphere相关配置,即可实现针对某个表进行脱敏
其中有几个的配置信息比较重要,spring.shardingsphere.encrypt.tables是指要脱敏的表,user是表名,salary表示user表中的真实列,其中plainColumn指的是明文列,cipherColumn指的是脱敏列,如果是新工程,只需要配置脱敏列即可!
配置示例如下!
2.4、编写数据持久层
然后,编写一个数据持久层,用于数据的存储和查询操作。
2.5、单元测试
最后,我们编写一个单元测试,验证一下代码的正确性。
编写启用服务程序
编写单元测试
插入数据后,如下图,数据库存储的数据已被加密!
我们继续来看看,运行查询服务,结果如下图,数据被成功解密!
采用配置方式,最大的好处就是直接通过配置脱敏列就可以完成对某些数据表字段的脱敏,非常方便。
三、小结
当需要对某些数据表字段进行脱敏处理的时候,可以采用 Apache ShardingSphere 框架快速实现。
但是有个细节很容易遗漏,那就是字段类型,例如salary字段,根据常规,很容易想到使用数字类型,但是却不是,要知道加密之后的数据都是一串乱码,数字类型肯定是无法存储字符串的,因此在定义的时候,这个要留心一下。
希望以上的案例,能帮助到大家!
想要获取项目源代码的小伙伴,可以通过如下地址获取!