mysql加密解密函数

mysql下的加密函数有如下几个

1、PASSWORD():创建一个经过加密的密码字符串,适合于插入到MySQL的安全系
统。该加密过程不可逆,和unix密码加密过程使用不同的算法。主要用于MySQL的认证系统。
 
2、ENCRYPT(,):使用UNIX crypt()系统加密字符串,ENCRYPT()函数接收要加密的字符串和(可选的)用于加密过程的salt(一个可以唯一确定口令的字符串,就像钥匙一样),注意,windows上不支持

3、ENCODE(,)   DECODE(,):加密解密字符串。该函数有两个参数:被加密或解密的字符串和作为加密或解密基础的密钥。Encode结果是一个二进制字符串,以BLOB类型存储。加密程度相对比较弱

加密 INSERT INTO users (username, password) VALUES ('joe', ENCODE('guessme', 'abracadabra'));

解密 SELECT DECODE(password, 'abracadabra') FROM users WHERE username='joe';


4、MD5():计算字符串的MD5校验和(128位)

SHA5():计算字符串的SHA5校验和(160位)

以上两个函数返回的校验和是16进制的,适合与认证系统中使用的口令。


5、AES_ENCRYPT AES_DECRYPT示例

insert into users(test) values(AES_ENCRYPT('teststr','salt'));

select AES_DECRYPT(test,'salt') from users;

ps:需要Linux 且 AES_ENCRYPT 加密结果最好也以BLOB类型存储

加密 select   aes_encrypt(name, 'password ');
解密 select   aes_decrypt(aes_encrypt(name, 'password '), 'password '); 

posted @ 2014-02-21 14:19  魔豆  阅读(10622)  评论(0编辑  收藏  举报