mysql数据字段加密

PASSWORD():创建一个经过加密的密码字符串,适合于插入到MySQL的安全系统。该加密过程不可逆,和unix密码加密过程使用不同的算法。主要用于MySQL的认证系统。
ENCRYPT(,)  AES_DECRYPT( , ):使用UNIX crypt()系统加密字符串,ENCRYPT()函数接收要加密的字符串和(可选的)用于加密过程的salt(一个可以唯一确定口令的字符串,就像钥匙一样)。加密程度比ENCODE较强。注意,windows上不支持。
ENCODE(,)   DECODE(,):加密解密字符串。该函数有两个参数:被加密或解密的字符串和作为加密或解密基础的密钥。Encode结果是一个二进制字符串,以BLOB类型存储。加密成度相对比较弱。
MD5():计算字符串的MD5校验和(128位),SHA5():计算字符串的SHA5校验和(160位),这两个函数返回的校验和是16进制的,适合与认证系统中使用的口令。

1、建测试表
CREATE TABLE `tab_col_encrypt` (
  `id` int(11) DEFAULT NULL,
  `user_name` varchar(10) DEFAULT NULL,
  `passwd_aes_encrypt` blob,
  `passwd_encode` blob
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2、插入测试数据
insert into tab_col_encrypt(id,user_name,passwd_aes_encrypt,passwd_encode)
values(1,'jingsp',aes_encrypt('123456','kitty'),ENCODE('123456','kitty'));

3、查看加密数据
select id,user_name,aes_decrypt(passwd_aes_encrypt,'kitty') passwd_aes_encrypt,passwd_aes_encrypt passwd_aes_encrypt_blob,decode(passwd_encode,'kitty') passwd_encode,passwd_encode passwd_encode_blob  from tab_col_encrypt;
select id,user_name,aes_decrypt(passwd_aes_encrypt,'kitty1') passwd_aes_encrypt,decode(passwd_encode,'kitty1') passwd_encode  from tab_col_encrypt;

4、其他
show full columns from tab_col_encrypt;  
select  old_password('111111');
select password('111111');
SELECT MD5('pa55word');

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值