php用戶密碼加密算法分析【Discuz加密算法】
本文實(shí)例講述了php用戶密碼加密算法。分享給大家供大家參考,具體如下:
今天在拿Discuz進(jìn)行二次開(kāi)發(fā)時(shí)需要在代碼里驗(yàn)證Discuz的用戶名密碼,結(jié)果不小心掉進(jìn)了坑里,因?yàn)镈iscuz的論壇有兩張表來(lái)存儲(chǔ)用戶數(shù)據(jù),一張?jiān)贒iscuz的數(shù)據(jù)庫(kù)ultrax里面的pre_common_member里面,另一個(gè)是存儲(chǔ)在了UCenter的數(shù)據(jù)庫(kù)ucenter的uc_members表里?;撕艽蠊Ψ蛟谘芯縰ltrax庫(kù)里那張pre_common_member的數(shù)據(jù),研究它的密碼是如何生成的,結(jié)果搜了一下發(fā)現(xiàn)網(wǎng)上說(shuō)是隨機(jī)生成的一個(gè)salt
心想這隨機(jī)生成的salt如何在登錄時(shí)進(jìn)行驗(yàn)證呢?然后網(wǎng)上說(shuō)其實(shí)Discuz壓根就沒(méi)用那個(gè)密碼,自己試驗(yàn)了一下,果真如此,即使把pre_common_member里面的用戶密碼改掉,照樣能夠正常登錄,看來(lái)這個(gè)密碼壓根就沒(méi)用,害我繞了一個(gè)大圈子。
好了,進(jìn)入正題,Discuz的密碼加密算法其實(shí)就是兩次MD5加密,首先用明文進(jìn)行一次加密,之后隨機(jī)生成一個(gè)salt,再把第一次的密文后面添加salt作為明文再進(jìn)行一次MD5加密。salt保存在uc_members表里,可以通過(guò)用戶名進(jìn)行獲取。
像這樣:
MD5(MD5(明文)+salt)
下面是.net的實(shí)現(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
② 打開(kāi)數(shù)據(jù)庫(kù)找到uc_members 這表,尋找最后一個(gè)字段"salt ",復(fù)制里面的值
③ 偽代碼:
$s=md5(md5("密碼")."salt字段的值"); echo $s;
④ 用IF判斷
⑤ 再說(shuō)一次!那個(gè)隨機(jī)是6位數(shù)!
PS:關(guān)于加密解密感興趣的朋友還可以參考本站在線工具:
密碼安全性在線檢測(cè):
http://tools.jb51.net/password/my_password_safe
高強(qiáng)度密碼生成器:
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è)計(jì)入門(mén)教程》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php正則表達(dá)式用法總結(jié)》、及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP執(zhí)行外部命令的函數(shù):exec(), system(), passthru(), sh
system()輸出并返回最后一行shell結(jié)果。exec()不輸出結(jié)果,返回最后一行shell結(jié)果,所有結(jié)果可以保存到一個(gè)返回的數(shù)組里面。passthru()只調(diào)用命令,把命令的運(yùn)行結(jié)果原樣地直接輸出到標(biāo)準(zhǔn)輸出設(shè)備上...2023-05-05php cookie 作用范圍–不要在當(dāng)前頁(yè)面使用你的cookie
這兩天在調(diào)試bug的時(shí)候遇到了一個(gè)問(wèn)題,就是頁(yè)面莫名其妙的會(huì)跳轉(zhuǎn)到登陸頁(yè)面2009-03-03php中10個(gè)不同等級(jí)壓縮優(yōu)化圖片操作示例
這篇文章主要介紹了php中10個(gè)不同等級(jí)壓縮優(yōu)化圖片操作方法,結(jié)合實(shí)例形式分析了php中imagepng函數(shù)進(jìn)行圖片壓縮操作過(guò)程中不同壓縮等級(jí)的使用技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-11-11PHP大文件及斷點(diǎn)續(xù)傳下載實(shí)現(xiàn)代碼
這篇文章主要介紹了PHP大文件及斷點(diǎn)續(xù)傳下載實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08php $_SESSION會(huì)員登錄實(shí)例分享
這篇文章主要為大家詳細(xì)介紹了php $_SESSION會(huì)員登錄實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03php使用SAE原生Mail類實(shí)現(xiàn)各種類型郵件發(fā)送的方法
這篇文章主要介紹了php使用SAE原生Mail類實(shí)現(xiàn)各種類型郵件發(fā)送的方法,結(jié)合實(shí)例形式分析了SAE平臺(tái)解決郵件發(fā)送問(wèn)題的相關(guān)操作技巧,需要的朋友可以參考下2016-10-10PHP常見(jiàn)錯(cuò)誤提示含義解釋(實(shí)用!值得收藏)
這篇文章主要介紹了PHP常見(jiàn)錯(cuò)誤提示含義解釋,包含了各種常見(jiàn)的PHP錯(cuò)誤提示及具體含義,便于查詢參考,需要的朋友可以參考下2016-04-04PHP實(shí)戰(zhàn)之投票系統(tǒng)的實(shí)現(xiàn)
這篇文章主要為大家介紹了如何利用PHP制作一個(gè)投票系統(tǒng),文中的示例代碼講解詳細(xì),感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下2022-04-04