為安全計(jì)窃这,請不要再使用md5

早在2010年城舞,美國軟件工程學(xué)會(SEI)就認(rèn)為MD5算法已被破解钧唐,不再適用忙灼。
"cryptographically broken and unsuitable for further use"
考慮到國內(nèi)依舊在廣泛使用MD5算法于安全領(lǐng)域,寫此為钝侠,希望引起大家對安全的重視该园。

MD5函數(shù)過去通常用于數(shù)據(jù)的完整性校驗(yàn)和用戶密碼的加密保存。

一 數(shù)據(jù)完整性校驗(yàn)

常見的應(yīng)用是

  1. 軟件完整性帅韧。通常軟件簽名不會對整個軟件簽名里初,而是對軟件的HASH值簽名。
    微軟早期的應(yīng)用軟件簽名就是使用的md5算法弱匪,還有人們在網(wǎng)絡(luò)上下載軟件青瀑,為確保軟件沒被修改,常常使用MD5值做校驗(yàn)完整性萧诫。
  2. 開放API, 為了防止用戶修改API請求的參數(shù)斥难,API提供商常常使用MD5值校驗(yàn)請求的完整性。
    以上應(yīng)用都是建立在MD5 函數(shù)不碰撞的基礎(chǔ)上帘饶,而這個基礎(chǔ)已不可靠哑诊,因?yàn)闃?gòu)造一個MD5碰撞已不難
    2005年山東大學(xué)的王小云教授發(fā)布算法可以輕易構(gòu)造MD5碰撞實(shí)例,此后2007年及刻,有國外學(xué)者在王小云教授算法的基礎(chǔ)上镀裤,提出了更進(jìn)一步的MD5前綴碰撞構(gòu)造算法“chosen prefix collision”,此后還有專家提供了MD5碰撞構(gòu)造的開源的庫缴饭。
    所以MD5碰撞很容易構(gòu)造暑劝,基于MD5來驗(yàn)證數(shù)據(jù)完整性已不可靠,考慮到近期谷歌已成功構(gòu)造了SHA1的碰撞實(shí)例颗搂,對于數(shù)據(jù)完整性担猛,應(yīng)使用SHA256或更強(qiáng)的算法代替。
    以下是簡單的MD5碰撞實(shí)例:
<?php

//md5 碰撞示范,數(shù)據(jù)不同傅联,md5值一樣

$a = <<< EOT
d131dd02c5e6eec4693d9a0698aff95c
2fcab58712467eab4004583eb8fb7f89
55ad340609f4b30283e488832571415a
085125e8f7cdc99fd91dbdf280373c5b
d8823e3156348f5bae6dacd436c919c6
dd53e2b487da03fd02396306d248cda0
e99f33420f577ee8ce54b67080a80d1e
c69821bcb6a8839396f9652b6ff72a70
EOT;

$b = <<< EOT
d131dd02c5e6eec4693d9a0698aff95c
2fcab50712467eab4004583eb8fb7f89
55ad340609f4b30283e4888325f1415a
085125e8f7cdc99fd91dbd7280373c5b
d8823e3156348f5bae6dacd436c919c6
dd53e23487da03fd02396306d248cda0
e99f33420f577ee8ce54b67080280d1e
c69821bcb6a8839396f965ab6ff72a70
EOT;


$a = str_replace("\n","",$a);
$a = hex2bin($a);

$b = str_replace("\n","",$b);
$b = hex2bin($b);

assert($a !=$b);

echo md5($a);
echo "\n";
echo md5($b);
echo "\n";

二 用戶密碼加密保存

用戶的登錄密碼先改,是很重要的一個安全環(huán)節(jié)。
如果明文保存在數(shù)據(jù)庫蒸走,一旦黑客入侵或是內(nèi)部員工盜竊仇奶,用戶密碼就會泄漏。
國內(nèi)外大網(wǎng)站都發(fā)生過因黑客或是內(nèi)部員工導(dǎo)致用戶數(shù)據(jù)的泄漏問題比驻,用戶密碼一旦泄漏對于電商網(wǎng)站或是支付網(wǎng)站的影響是難于估量的该溯。

為了保護(hù)用戶密碼,早期人們使用MD5算法把密碼加密后保存别惦,通常計(jì)算MD5值時(shí)會加一個”鹽值“(即一個固定的密串),這個鹽值可能是共用的朗伶,也可能是一個用戶一個鹽值。

MD5(密碼+鹽值)步咪,這樣形式的密碼儲存方案在早期基本上是密碼存儲的一個通行標(biāo)準(zhǔn),國內(nèi)多數(shù)網(wǎng)站(包括大型電商和支付網(wǎng)站)早期都采用的是這個辦法益楼,如果沒有更新的話猾漫,現(xiàn)在很多網(wǎng)站依舊是這個方案。

這樣的方案什么不對感凤?
1,對于黑客入侵或是內(nèi)部員工悯周,能拿到用戶數(shù)據(jù)的人,很容易就拿到鹽值
2,雖然黑客不能反解密碼陪竿,密碼通常有一定的規(guī)則禽翼,諸如大小寫數(shù)字六位數(shù)以上等,黑客可通過排列組合一個一個的試族跛,暴力破解闰挡,因?yàn)镸D5值的計(jì)算速度很快,對于六位數(shù)密碼礁哄,很容易攻克长酗。
注意:這個暴力破解是離線運(yùn)行的,在線的暴力破解很容易阻擋桐绒。
被攻擊的網(wǎng)站沒有感覺夺脾,如果用比特幣挖礦的礦機(jī),這樣的破解輕而易舉茉继,沒挑戰(zhàn)咧叭。

你會說,MD5不行烁竭,SHA1也被谷歌破解了菲茬,SHA256 密碼加鹽值這樣可靠了吧?
SHA256 密碼加鹽值也不安全。
因?yàn)樯琈D5听想,SHA1,SHA256就不是用來保存密碼用的马胧, 是用來校驗(yàn)數(shù)據(jù)完整性用的汉买,三個算法的計(jì)算速度都很快,試想一下佩脊,校驗(yàn)一個4G的ISO鏡像文件蛙粘,必須要有高效的計(jì)算速度。

因?yàn)樗惴ㄐ矢咄茫俣瓤斐瞿粒簿徒档土吮┝ζ平獾碾y度。

正確的做法是使用bcrypt算法歇盼,bcrypt算法的優(yōu)點(diǎn)是計(jì)算速度慢舔痕,沒錯計(jì)算速度慢,
還可以通過參數(shù)調(diào)節(jié)速度豹缀,要多慢有多慢伯复。

<?php

$options  =  ["cost" => 10 ]; //調(diào)速參數(shù),越大越慢
$password = "password here";
$hash = password_hash($password, PASSWORD_BCRYPT, $options);
echo "$hash\n";

// 校驗(yàn)
assert(password_verify($password,$hash) == true);

普通的電腦每秒可運(yùn)行數(shù)萬次SHA256計(jì)算邢笙,bcypt算法通過參數(shù)設(shè)置可以調(diào)整為計(jì)算一次耗時(shí)1秒啸如。
這樣大幅提高了暴力破解的門檻,增強(qiáng)了安全性氮惯。

這里有個比特幣礦機(jī)配置叮雳,供參考, 以便提高安全意識:
型號:HashFast Sierra Batch 2
價(jià)格:7080美元
功率: 780瓦
性能: 1200 GH/s (每秒可運(yùn)行1.2萬億次SHA256計(jì)算)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末妇汗,一起剝皮案震驚了整個濱河市帘不,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌杨箭,老刑警劉巖厌均,帶你破解...
    沈念sama閱讀 221,888評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異告唆,居然都是意外死亡棺弊,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評論 3 399
  • 文/潘曉璐 我一進(jìn)店門擒悬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來模她,“玉大人,你說我怎么就攤上這事懂牧〕蘧唬” “怎么了尊勿?”我有些...
    開封第一講書人閱讀 168,386評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長畜侦。 經(jīng)常有香客問我元扔,道長,這世上最難降的妖魔是什么旋膳? 我笑而不...
    開封第一講書人閱讀 59,726評論 1 297
  • 正文 為了忘掉前任澎语,我火速辦了婚禮,結(jié)果婚禮上验懊,老公的妹妹穿的比我還像新娘擅羞。我一直安慰自己,他們只是感情好义图,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評論 6 397
  • 文/花漫 我一把揭開白布减俏。 她就那樣靜靜地躺著,像睡著了一般碱工。 火紅的嫁衣襯著肌膚如雪娃承。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,337評論 1 310
  • 那天怕篷,我揣著相機(jī)與錄音,去河邊找鬼匙头。 笑死立哑,一個胖子當(dāng)著我的面吹牛恩沽,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播借杰,決...
    沈念sama閱讀 40,902評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼碟婆,長吁一口氣:“原來是場噩夢啊……” “哼电抚!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起竖共,我...
    開封第一講書人閱讀 39,807評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蝙叛,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后公给,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體借帘,經(jīng)...
    沈念sama閱讀 46,349評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評論 3 340
  • 正文 我和宋清朗相戀三年淌铐,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了肺然。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,567評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡腿准,死狀恐怖际起,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤街望,帶...
    沈念sama閱讀 36,242評論 5 350
  • 正文 年R本政府宣布校翔,位于F島的核電站,受9級特大地震影響灾前,放射性物質(zhì)發(fā)生泄漏防症。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評論 3 334
  • 文/蒙蒙 一豫柬、第九天 我趴在偏房一處隱蔽的房頂上張望告希。 院中可真熱鬧烧给,春花似錦础嫡、人聲如沸指么。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽伯诬。三九已至,卻和暖如春巫财,著一層夾襖步出監(jiān)牢的瞬間盗似,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評論 1 272
  • 我被黑心中介騙來泰國打工平项, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留赫舒,地道東北人。 一個月前我還...
    沈念sama閱讀 48,995評論 3 377
  • 正文 我出身青樓闽瓢,卻偏偏與公主長得像接癌,于是被迫代替她去往敵國和親扣讼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評論 2 359

推薦閱讀更多精彩內(nèi)容