那些年我在数据库加密的大坑坑坑坑

createh51周前 (03-27)技术教程6

之前在对数据库加密的需求中遇到一些坑,拿出来分享一下。

加密的方案是:将数据使用AES加密再经过base64编码。

最近整理了一些Java架构学习视频和大厂项目底层知识点,需要的同学欢迎私信我【Java】发给你~

坑一: AES+base64加密后的长度

AES算法加密后的长度应当是:不小于原始长度的16的最小倍数。例如:

  • 15字节加密后变成16字节
  • 16字节加密后变成32字节 这是第一个坑

后面base64编码后的长度即变成4/3倍。


坑二: 数据库的编码对varchar类型的影响

varchar(n) 这个类型其实是指能容纳 n个字符,即如果数据库的编码是utf8,即每个字符可能占3个字节,那么在极限情况下,有可能 3*n 个字节。

然而经过base64以后,这些字节都将对应于一个字符。因此,在n不是16整数倍的情况下,加密以后varchar的长度应当变为4*n (如果n是16整数倍,则存在->坑一)


坑三: 加密后数据库模糊匹配的问题

即无法使用 like 语法,必须完全匹配。

目前没有一个好的解决方案,针对数量级特别小的加密表,忽略模糊匹配的字段查询,解密后再过滤也可以; 量级稍大一点点 并且不需要频繁修改的,将明文结果缓存也可以。


坑四: MySql的字符串比较大小写问题

MySql的字符串匹配默认是大小写不敏感的,也就是说之前系统里能匹配到的加密后就无法匹配了。

这里还涉及到统一认证系统URS的一个问题,该系统返回给我们的账户名有时大写有时小写。。

这是MySql的一个特性,sqlite则默认大小写敏感


坑五: MyBatis缓存

由于MyBatis的缓存,在dao操作里对select出来的对象直接解密,可能会对下一次同一个dao操作有影响。详见:mybatis 的缓存坑


来源:网易工程师-郁利涛

看到这里的小伙伴,如果你喜欢这篇文章的话,别忘了转发、收藏、留言互动!

最近我新整理了一些Java资料,包含个人精选的Java架构学习视频、大厂实战知识点、大厂内部面试题,如果你需要的话,欢迎私信我

如果对文章有任何问题,欢迎在留言区和我交流~

相关文章

Java中字符串的长度值

我第一次知道:在 UTF - 8 编码中,英文字符和空格占 1 个字节,中文字符通常占 3 个字节。在 GBK 编码中,英文字符和空格占 1 个字节,中文字符占 2 个字节。上代码,看图: publi...

吊打面试官(十)--Java语言中字符串相关处理一文全掌握

导读在Java中,`String`、`StringBuilder`和`StringBuffer`是处理字符串的三个常用类。它们各有特点,适用于不同的场景。下面详细介绍它们的使用场景、区别、实现原理、使...

如何解决java老开源系统登录密码在浏览器开发工具里暴露的问题

网上找的若依开源框架,拿来登录密码直接暴露在浏览器开发工具里面,拿这个东西直接给甲方需求方,肯定过不了关的。甲方假如哪天发现了这个问题,肯定会要求退工程款,拿来主义没问题,但是得优化。包括另一个开源项...

javascript超长知识归纳总结

基本概念javascript简称js,是一种脚本语言,用来操作HTML中的节点,产生动态效果。包括三大模块。ECMAScript:是javascript核心语法;json是其中一种轻量级的数据交换格式...

Java 8之后的那些新特性(二):文本块 Text Blocks

继续聊Java 8之后的新特性,这周我讲下Text Blocks这个特性。Text Blocks最开始是个JDK 14引进的,当时为预览版功能,在JDK 15中被正式确定。这意味着如果你想使用这个功能...