相關(guān)關(guān)鍵詞
關(guān)于我們
最新文章
- PHP中opcode緩存簡(jiǎn)單用法分析
- thinkPHP控制器變量在模板中的顯示方法示例
- PHP move_uploaded_file() 函數(shù)(將上傳的文件移動(dòng)到新位置)
- dirname(__FILE__)的含義和應(yīng)用說(shuō)明
- thinkPHP5框架實(shí)現(xiàn)分頁(yè)查詢功能的方法示例
- PHP中單雙號(hào)與變量
- PHP獲得當(dāng)日零點(diǎn)時(shí)間戳的方法分析
- Laravel ORM對(duì)Model::find方法進(jìn)行緩存示例詳解
- PHP讀寫文件高并發(fā)處理操作實(shí)例詳解
- 【CLI】利用Curl下載文件實(shí)時(shí)進(jìn)度條顯示的實(shí)現(xiàn)
PHP更安全的密碼加密機(jī)制Bcrypt詳解
前言
我們常常為了避免在服務(wù)器受到攻擊,數(shù)據(jù)庫(kù)被拖庫(kù)時(shí),用戶的明文密碼不被泄露,一般會(huì)對(duì)密碼進(jìn)行單向不可逆加密——哈希。
常見的方式是:
哈希方式 | 加密密碼 |
md5(‘123456') | e10adc3949ba59abbe56e057f20f883e |
md5(‘123456' . ($salt = ‘salt')) | 207acd61a3c1bd506d7e9a4535359f8a |
sha1(‘123456') | 40位密文 |
hash(‘sha256', ‘123456') | 64位密文 |
hash(‘sha512', ‘123456') | 128位密文 |
密文越長(zhǎng),在相同機(jī)器上,進(jìn)行撞庫(kù)消耗的時(shí)間越長(zhǎng),相對(duì)越安全。
比較常見的哈希方式是 md5 + 鹽,避免用戶設(shè)置簡(jiǎn)單密碼,被輕松破解。
password_hash
但是,現(xiàn)在要推薦的是 password_hash()
函數(shù),可以輕松對(duì)密碼實(shí)現(xiàn)加鹽加密,而且?guī)缀醪荒芷平狻?/p>
$password = '123456'; var_dump(password_hash($password, PASSWORD_DEFAULT)); var_dump(password_hash($password, PASSWORD_DEFAULT));