php用戶密碼加密算法分析【Discuz加密算法】
本文實例講述了php用戶密碼加密算法。分享給大家供大家參考,具體如下:
今天在拿Discuz進(jìn)行二次開發(fā)時需要在代碼里驗證Discuz的用戶名密碼,結(jié)果不小心掉進(jìn)了坑里,因為Discuz的論壇有兩張表來存儲用戶數(shù)據(jù),一張在Discuz的數(shù)據(jù)庫ultrax里面的pre_common_member里面,另一個是存儲在了UCenter的數(shù)據(jù)庫ucenter的uc_members表里。花了很大功夫在研究ultrax庫里那張pre_common_member的數(shù)據(jù),研究它的密碼是如何生成的,結(jié)果搜了一下發(fā)現(xiàn)網(wǎng)上說是隨機生成的一個salt
心想這隨機生成的salt如何在登錄時進(jìn)行驗證呢?然后網(wǎng)上說其實Discuz壓根就沒用那個密碼,自己試驗了一下,果真如此,即使把pre_common_member里面的用戶密碼改掉,照樣能夠正常登錄,看來這個密碼壓根就沒用,害我繞了一個大圈子。
好了,進(jìn)入正題,Discuz的密碼加密算法其實就是兩次MD5加密,首先用明文進(jìn)行一次加密,之后隨機生成一個salt,再把第一次的密文后面添加salt作為明文再進(jìn)行一次MD5加密。salt保存在uc_members表里,可以通過用戶名進(jìn)行獲取。
像這樣:
MD5(MD5(明文)+salt)
下面是.net的實現(xiàn)代碼:
string GetDiscuzPWString(string sourceStr, string salt) { return GetMd5Hash(string.Concat(GetMd5Hash(sourceStr),salt)); } string GetMd5Hash(string input) { MD5 md5Hasher = MD5.Create(); byte[] data = md5Hasher.ComputeHash(Encoding.Default.GetBytes(input)); StringBuilder sBuilder = new StringBuilder(); for (int i = 0; i < data.Length; i++) { sBuilder.Append(data[i].ToString("x2")); } return sBuilder.ToString(); }
總結(jié)密碼判斷方式:
① 要安裝UC
② 打開數(shù)據(jù)庫找到uc_members 這表,尋找最后一個字段"salt ",復(fù)制里面的值
③ 偽代碼:
$s=md5(md5("密碼")."salt字段的值"); echo $s;
④ 用IF判斷
⑤ 再說一次!那個隨機是6位數(shù)!
PS:關(guān)于加密解密感興趣的朋友還可以參考本站在線工具:
密碼安全性在線檢測:
http://tools.jb51.net/password/my_password_safe
高強度密碼生成器:
http://tools.jb51.net/password/CreateStrongPassword
MD5在線加密工具:
http://tools.jb51.net/password/CreateMD5Password
迅雷、快車、旋風(fēng)URL加密/解密工具:
http://tools.jb51.net/password/urlrethunder
在線散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php加密方法總結(jié)》、《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《PHP數(shù)學(xué)運算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《php正則表達(dá)式用法總結(jié)》、及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
相關(guān)文章
PHP執(zhí)行外部命令的函數(shù):exec(), system(), passthru(), sh
system()輸出并返回最后一行shell結(jié)果。exec()不輸出結(jié)果,返回最后一行shell結(jié)果,所有結(jié)果可以保存到一個返回的數(shù)組里面。passthru()只調(diào)用命令,把命令的運行結(jié)果原樣地直接輸出到標(biāo)準(zhǔn)輸出設(shè)備上...2023-05-05php cookie 作用范圍–不要在當(dāng)前頁面使用你的cookie
這兩天在調(diào)試bug的時候遇到了一個問題,就是頁面莫名其妙的會跳轉(zhuǎn)到登陸頁面2009-03-03php使用SAE原生Mail類實現(xiàn)各種類型郵件發(fā)送的方法
這篇文章主要介紹了php使用SAE原生Mail類實現(xiàn)各種類型郵件發(fā)送的方法,結(jié)合實例形式分析了SAE平臺解決郵件發(fā)送問題的相關(guān)操作技巧,需要的朋友可以參考下2016-10-10PHP實戰(zhàn)之投票系統(tǒng)的實現(xiàn)
這篇文章主要為大家介紹了如何利用PHP制作一個投票系統(tǒng),文中的示例代碼講解詳細(xì),感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下2022-04-04