實例
計算字串 "Hello" 的 MD5 雜湊:
<?php $str = "Hello"; echo md5($str); ?>
定義和用法
md5() 函數計算字串的 MD5 雜湊。
md5() 函數使用 RSA 資料安全,包括 MD5 封包摘要演算法。
來自RFC 1321 的解釋- MD5 封包摘要演算法:MD5 封包摘要演算法將任意長度的資訊作為輸入值,並將其換算成一個128 位元長度的"指紋資訊"或"報文摘要"值來代表這個輸入值,並以換算後的值作為結果。 MD5 演算法主要是為數位簽章應用程式而設計的;在這個數位簽章應用程式中,較大的檔案將在加密(這裡的加密過程是透過在一個密碼系統下[如:RSA]的公開金鑰下設定私有金鑰而完成的)之前以安全的方式進行壓縮。
如需計算檔案的 MD5 雜湊,請使用 md5_file() 函數。
文法
md5(string,raw)
參數 說明
string 必要。規定要計算的字串。
raw 選購。規定十六進位或二進位輸出格式:
TRUE - 原始 16 字元二進位格式
預設值 SE 32 字元十六進位數
技術細部
傳回值: 若成功則傳回已計算的MD5 雜湊,如果失敗則返回FALSE。
PHP 版本: 4+
更新日誌: 在PHP
## 更新日誌: 在PHP## 中,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加密的字符串进行比较。这样,就可以做到在不知道用户确切密码的情况下完成密码的比对操作。
以上是php計算字串的MD5雜湊的詳細內容。更多資訊請關注PHP中文網其他相關文章!