discuz注册时,会把密码按一个规则加密。
比如我的密码是123456
代码如下:
echo md5("123456");
会输出:
代码如下:
e10adc3949ba59abbe56e057f20f883e
而数据库的值却为:
代码如下:
7839dc9437013b5c11a5d86e9b8350e9
注意到:
有个叫salt的字段,其值为:d82a35
其实这是一个随机的字符串。
第一次md5后的值再加上盐值(salt)再进行md5,就是要得到的值了。
试一下
代码如下:
echo md5(md5('123456').'d82a35');
这回结果是:7839dc9437013b5c11a5d86e9b8350e9,是对的。
在php5.5之前的版本,并没有很好的加密机制。这是个不错的方式。已经大大地加强了密码的安全性了。
而php5.5中有更为可靠和方便的加密方式。喜欢钻研的朋友可以了解一下:
password_hash()
http://www.php.net/manual/zh/function.password-hash.php
您可能感兴趣的文章:php用户密码加密算法分析【Discuz加密算法】discuz程序的PHP加密函数原理分析discuz authcode 经典php加密解密函数解析Discuz论坛密码与密保加密规则discuz加密解密函数使用方法和中文注释2个比较经典的PHP加密解密函数分享PHP实现加密的几种方式介绍PHP中加密解密函数与DES加密解密实例php中AES加密解密的例子小结php中base64_decode与base64_encode加密解密函数实例PHP可逆加密/解密函数分享PHP 加密解密内部算法php加密之discuz内容经典加密方式实例详解