PHP 5.5 創(chuàng)建和驗(yàn)證哈希最簡單的方法詳解
更新時間:2013年11月07日 11:52:49 作者:
最近 PHP 5.5.0 發(fā)布了,并帶來了一份完整的全新特性與函數(shù)的列表。全新API之一就是Password Hashing API.它包含4個函數(shù):password_get_info(), password_hash(), password_needs_rehash(),和password_verify().讓我們分步來了解每個函數(shù)
我們首先討論password_hash()函數(shù)。這將用作創(chuàng)建一個新的密碼的哈希值。它包含三個參數(shù):密碼、哈希算法、選項(xiàng)。前兩項(xiàng)為必須的。你可以根據(jù)下面的例子來使用這個函數(shù):
$password = 'foo';
$hash = password_hash($password,PASSWORD_BCRYPT);
//$2y$10$uOegXJ09qznQsKvPfxr61uWjpJBxVDH2KGJQVnodzjnglhs2WTwHu
你將注意到我們并沒有給這個哈希加任何選項(xiàng)。現(xiàn)在可用的選項(xiàng)被限定為兩個: cost 和salt。妖添加選項(xiàng)你需要創(chuàng)建一個關(guān)聯(lián)數(shù)組。
$options = [ 'cost' => 10,
'salt' => mcrypt_create_iv(22, MCRYPT_DEV_URANDOM) ];
將選項(xiàng)添加到 password_hash() 函數(shù)后,我們的哈希值變了,這樣更加安全。
$hash = password_hash($password,PASSWORD_BCRYPT,$options);
//$2y$10$JDJ5JDEwJDhsTHV6SGVIQuprRHZnGQsUEtlk8Iem0okH6HPyCoo22
現(xiàn)在哈希創(chuàng)建完畢了,我們可以通過 password_get_info() 查看新建哈希值得相關(guān)信息。password_get_info() 需要一個參數(shù)——哈希值——并返回一個包含算法(所用哈希算法的整數(shù)代表形式)、算法名(所用哈希算法的可讀名稱)以及選項(xiàng)(我們用于創(chuàng)建哈希值得選項(xiàng))的關(guān)聯(lián)數(shù)組。
var_dump(password_get_info($hash));
/*
array(3) {
["algo"]=>
int(1)
["algoName"]=>
string(6) "bcrypt"
["options"]=>
array(1) {
["cost"]=>
int(10)
}
}
*/
先一個被添加到 Password Hashing API 的是 password_needs_rehash(),它接受三個參數(shù),hash、hash 算法以及選項(xiàng),前兩個是必填項(xiàng)。 password_needs_rehash()用來檢查一個hash值是否是使用特定算法及選項(xiàng)創(chuàng)建的。這在你的數(shù)據(jù)庫受損需要調(diào)整hash時非常有用。通過利用 password_needs_rehash() 檢查每個hash值,我們可以看到已存的hash 值是否匹配新的參數(shù), 僅影響那些使用舊參數(shù)創(chuàng)建的值。
最后,我們已經(jīng)創(chuàng)建了我們的hash值,查閱了它如何被創(chuàng)建,查閱了它是否需要被重新hash,現(xiàn)在我們需要驗(yàn)證它。要驗(yàn)證純文本到其hash值,我們必須使用 password_verify(),它需要兩個參數(shù),密碼及hash值,并將返回 TRUE 或 FALSE。讓我們檢查一次我們獲得的 hashed 看看是否正確。
$authenticate = password_verify('foo','$2y$10$JDJ5JDEwJDhsTHV6SGVIQuprRHZnGQsUEtlk8Iem0okH6HPyCoo22');
//TRUE
$authenticate = password_verify('bar','$2y$10$JDJ5JDEwJDhsTHV6SGVIQuprRHZnGQsUEtlk8Iem0okH6HPyCoo22');
//FALSE
復(fù)制代碼 代碼如下:
$password = 'foo';
$hash = password_hash($password,PASSWORD_BCRYPT);
//$2y$10$uOegXJ09qznQsKvPfxr61uWjpJBxVDH2KGJQVnodzjnglhs2WTwHu
你將注意到我們并沒有給這個哈希加任何選項(xiàng)。現(xiàn)在可用的選項(xiàng)被限定為兩個: cost 和salt。妖添加選項(xiàng)你需要創(chuàng)建一個關(guān)聯(lián)數(shù)組。
復(fù)制代碼 代碼如下:
$options = [ 'cost' => 10,
'salt' => mcrypt_create_iv(22, MCRYPT_DEV_URANDOM) ];
將選項(xiàng)添加到 password_hash() 函數(shù)后,我們的哈希值變了,這樣更加安全。
復(fù)制代碼 代碼如下:
$hash = password_hash($password,PASSWORD_BCRYPT,$options);
//$2y$10$JDJ5JDEwJDhsTHV6SGVIQuprRHZnGQsUEtlk8Iem0okH6HPyCoo22
現(xiàn)在哈希創(chuàng)建完畢了,我們可以通過 password_get_info() 查看新建哈希值得相關(guān)信息。password_get_info() 需要一個參數(shù)——哈希值——并返回一個包含算法(所用哈希算法的整數(shù)代表形式)、算法名(所用哈希算法的可讀名稱)以及選項(xiàng)(我們用于創(chuàng)建哈希值得選項(xiàng))的關(guān)聯(lián)數(shù)組。
復(fù)制代碼 代碼如下:
var_dump(password_get_info($hash));
/*
array(3) {
["algo"]=>
int(1)
["algoName"]=>
string(6) "bcrypt"
["options"]=>
array(1) {
["cost"]=>
int(10)
}
}
*/
先一個被添加到 Password Hashing API 的是 password_needs_rehash(),它接受三個參數(shù),hash、hash 算法以及選項(xiàng),前兩個是必填項(xiàng)。 password_needs_rehash()用來檢查一個hash值是否是使用特定算法及選項(xiàng)創(chuàng)建的。這在你的數(shù)據(jù)庫受損需要調(diào)整hash時非常有用。通過利用 password_needs_rehash() 檢查每個hash值,我們可以看到已存的hash 值是否匹配新的參數(shù), 僅影響那些使用舊參數(shù)創(chuàng)建的值。
最后,我們已經(jīng)創(chuàng)建了我們的hash值,查閱了它如何被創(chuàng)建,查閱了它是否需要被重新hash,現(xiàn)在我們需要驗(yàn)證它。要驗(yàn)證純文本到其hash值,我們必須使用 password_verify(),它需要兩個參數(shù),密碼及hash值,并將返回 TRUE 或 FALSE。讓我們檢查一次我們獲得的 hashed 看看是否正確。
復(fù)制代碼 代碼如下:
$authenticate = password_verify('foo','$2y$10$JDJ5JDEwJDhsTHV6SGVIQuprRHZnGQsUEtlk8Iem0okH6HPyCoo22');
//TRUE
$authenticate = password_verify('bar','$2y$10$JDJ5JDEwJDhsTHV6SGVIQuprRHZnGQsUEtlk8Iem0okH6HPyCoo22');
//FALSE
相關(guān)文章
php strlen mb_strlen計(jì)算中英文混排字符串長度
在php中常見的計(jì)算字符串長度的函數(shù)有:strlen和mb_strlen,下面是對這兩個函數(shù)的比較說明(編碼方式UTF8)2009-07-07
Trying to clone an uncloneable object of class Imagic的解決方法
使用網(wǎng)上流傳的一個程序?qū)崿F(xiàn)pdf截圖為png,需要使用Imagic擴(kuò)展2012-01-01
PHP中關(guān)鍵字interface和implements詳解
PHP 類是單繼承,也就是不支持多繼承,當(dāng)一個類需要多個類的功能時,繼承就無能為力了,為此 PHP 引入了類的接口技術(shù)。下面這篇文章主要跟大家介紹了關(guān)于PHP中關(guān)鍵字interface和implements的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-06-06
php中g(shù)lobal和$GLOBALS[]的分析之一
PHP 的全局變量和 C 語言有一點(diǎn)點(diǎn)不同,在 C 語言中,全局變量在函數(shù)中自動生效,除非被局部變量覆蓋2012-02-02
php從右向左/從左向右截取字符串的實(shí)現(xiàn)方法
我先學(xué)的的asp,asp里截取字符串的函數(shù)很簡單,也容易理解:left和right而php里從左向右截取和從右向左截取都是一個函數(shù):substr2011-11-11
解析dedeCMS驗(yàn)證碼的實(shí)現(xiàn)代碼
本篇文章是對dedeCMS驗(yàn)證碼的實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
實(shí)測在class的function中include的文件中非php的global全局環(huán)境
正如標(biāo)題所言經(jīng)測試的結(jié)果為:在class中include后,被include文件變量域已經(jīng)變成func中了,非全局.但是可以通過global提升,感興趣的朋友可以參考下哈,希望對大家有所幫助2013-07-07
php獲取服務(wù)器端mac和客戶端mac的地址支持WIN/LINUX
這篇文章主要介紹了php獲取服務(wù)器端mac和客戶端mac地址的方法,需要的朋友可以參考下2014-05-05

