|
<?php
echo substr(md5("admin"),8,16); // 16位MD5加密
echo "<hr>";
echo md5("admin"); // 32位MD5加密
?>
16位的MD5加密用substr函數截取了字符得到實現....
不想深入研究了 :) 要把腦力放到其他關鍵的地方~~
今天做了個php鏈接mssql數據庫,數據庫中的表中字段使用MD5十六加密的。但是php中的MD5默認是32位,導致登錄程序沒辦法使用md5加密跟表中字段匹配,在網上一搜也有不少人有這方面的困惑,后來找到一個解決辦法,是正確的,就記錄下來。
使用substr函數截取:
substr(md5("admin"),8,16); // 16位MD5加密
md5("admin"); // 32位MD5加密
經過腳本之家測試結果如下:
我們以ASP的幾個md5后的結果比較
附:如果遇到MD5加密文件,而又不知道的密碼的,請在數據庫中換上這組加密的數據。
admin---16位加密---7a57a5a743894a0e
admin---32位加密---21232f297a57a5a743894a0e4a801fc3
admin---40位加密---7a57a5a743894a0e4a801fc343894a0e4a801fc3
substr(md5("admin"),8,16); // 16位MD5加密 正是上面的32為從第8個字符開始的16個字符。所以大家不用考慮唯一性的問題。本身就是正確的。網上有人說php5支持
復制代碼 代碼如下:
echo md5("admin",true);//返回16位,不過這是在php5里才有。
經測試輸出的結果是亂碼,如果大家有什么好的代碼,可以分享下。
php技術:php md5下16位和32位的實現代碼,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。