執行個體
計算字串 "Hello" 的 MD5 散列:
<?php$str = "Hello";echo md5($str);?>
定義和用法
md5() Function Compute字串的 MD5 散列。
md5() 函數使用 RSA 資料安全,包括 MD5 報文摘要演算法。
來自 RFC 1321 的解釋 - MD5 報文摘要演算法:MD5 報文摘要演算法將任意長度的資訊作為輸入值,並將其換算成一個 128 位長度的"指紋資訊"或"報文摘要"值來代表這個輸入值,並以換算後的值作為結果。MD5 演算法主要是為數位簽章應用程式而設計的;在這個數位簽章應用程式中,較大的檔案將在加密(這裡的加密過程是通過在一個密碼系統下[如:RSA]的公開密鑰下設定私人密鑰而完成的)之前以一種安全的方式進行壓縮。
如需計算檔案的 MD5 散列,請使用 md5_file() 函數。
文法
md5(string,raw)
參數 描述
string 必需。規定要計算的字串。
raw 可選。規定十六進位或二進位輸出格式:
TRUE - 原始 16 字元二進位格式
FALSE - 預設。32 字元十六進位數
技術細節
傳回值: 如果成功則返回已計算的 MD5 散列,如果失敗則返回 FALSE。
PHP 版本: 4+
更新日誌: 在 PHP 5.0 中,raw 參數變成可選的。
更多執行個體
執行個體 1
輸出 md5() 的結果:
<?php $str = "Hello"; echo "The string: ".$str."<br>"; echo "TRUE - Raw 16 character binary format: ".md5($str, TRUE)."<br>"; echo "FALSE - 32 character hex number: ".md5($str)."<br>"; ?>
執行個體 2
輸出 md5() 的結果並對它進行測試:
<?php$str = "Hello";echo md5($str);if (md5($str) == "8b1a9953c4611296a827abf8c47804d7"){echo "<br>Hello world!";exit;}?>
一般來說,一個提供會員註冊的網站必定需要採集使用者的密碼,如何儲存使用者密碼就是個問題。我們當然不能將密碼以明文的方式儲存在資料庫中,因為這樣的話,一般的管理員就可以查看到使用者密碼,顯然對使用者來說是件相當危險的事情。
那如何解決這個問題呢,我們可以採取這樣的策略。
首先介紹一下PHP中MD5函數的使用方法:
<?php $pswd1=md5("cenusdesign"); echo $pswd1; //運行結果為:fc60ec37d1c08d5b0fb67a8cd934d5ba $pswd2=md5("Cenusdesign"); echo $pswd2; //運行結果為:067577d9fc109c80538c81d6f02bd293 ?>
顯然,經過md5加密後,原本“cenusdesign”轉變成了一組32位的字串,而且,即使是一個字母的大小寫變化,這組字串就會發生巨大的變化。
Cenus Design建議把使用者註冊時,將密碼首先經過MD5轉換,然後將轉換加密後的資料庫。在使用者登陸時,也將密碼先進行MD5轉化,再和資料庫中那組經過MD5加密的字串進行比較。這樣,就可以做到在不知道使用者確切密碼的情況下完成密碼的比對操作。