背景
换了一个新的MySQL数据库,需要对原有的加密字段做解密操作,然后按照原来使用的解密函数做解密操作,但是一直提示上面的错误。因为MySQL数据库是8.0的版本,看了官方手册,说是需要在后面加一个init_vector
参数,之前用的是5.7的MySQL,以为是数据库版本的问题,然后让管理员换了一个5.7低版本的数据库,但是仍然存在上面的问题
问题原因
产生上面问题的原因就是标题所述,调用aes_decrypt函数时传入的参数个数与需要传入的参数的个数不符。
解决办法
查询新数据库的@@session.block_encryption_mode
select @@session.block_encryption_mode;
如果结果为aes-128-cbc,则需要改为aes-128-ecb,这个参数需要用数据库管理员身份修改,改完后需要重启数据库。
新的数据库在初始化创建时,上面的参数默认是aes-128-cbc,如果用到了加密函数,需要init_vector
参数才能使用,如果不想用
init_vector
参数,可以参考上面的方式来调整。
小结
上面的问题国内网站上资料不多,可以参考下面的说明:
MySQL 5.6.17 – now with better encryption | Todd's MySQL Blog
MySQL :: MySQL 8.0 Reference Manual :: 12.14 Encryption and Compression Functions
MySQL :: MySQL 5.7 Reference Manual :: 12.14 Encryption and Compression Functions