Incorrect parameter count in the call to native function ‘aes_decrypt‘

背景

换了一个新的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

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值