网站首页 > 技术文章 正文
之前在对数据库加密的需求中遇到一些坑,拿出来分享一下。
加密的方案是:将数据使用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架构学习视频、大厂实战知识点、大厂内部面试题,如果你需要的话,欢迎私信我!
如果对文章有任何问题,欢迎在留言区和我交流~
猜你喜欢
- 2025-04-29 MySQL与SQLite:如何通过DESCRIBE命令查看表结构并解决常见问题
- 2025-04-29 PowerDesigner最基础的使用方法入门学习
- 2025-04-29 详解MySQL|一招实现从Oracle到MySQL的平滑数据迁移-爱可生
- 2025-04-29 MySQL批量生成建表语句
- 2025-04-29 SQL 语句大全
- 2025-04-29 2万字,深度解析SQL性能优化,值得收藏
- 2025-04-29 别再说你精通数据库,MySQL的设计和列类型选取真的很有讲究
- 2025-04-29 怎么让呼叫中心支持高并发
- 2025-04-29 【分享】千万级的大表性能调优解决方案
- 2025-04-29 面试官常问的varchar和char区别
- 06-13C++之类和对象(c++中类和对象的区别)
- 06-13C语言进阶教程:数据结构 - 哈希表的基本原理与实现
- 06-13C语言实现见缝插圆游戏!零基础代码思路+源码分享
- 06-13Windows 10下使用编译并使用openCV
- 06-13C语言进阶教程:栈和队列的实现与应用
- 06-13C语言这些常见标准文件该如何使用?很基础也很重要
- 06-13C语言 vs C++:谁才是编程界的“全能王者”?
- 06-13C语言无锁编程指南(c语言锁机代码)
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)