php登陸頁的密碼處理方式分享
更新時間:2013年10月14日 15:05:23 作者:
這篇文章介紹了php登陸頁的密碼處理方式,有需要的朋友可以參考一下
控制器里面:elseif(!$model->validatePassword($data->password))
復(fù)制代碼 代碼如下:
<?php
class XBaseModel extends CActiveRecord
{
/**
* 檢測用戶密碼
*
* @return boolean
*/
public function validatePassword ($password)
{
return $this->hashPassword($this->password) === $password;
}
/**
* 密碼進(jìn)行加密
* @return string password
*/
public function hashPassword ($password)
{
return md5($password);
}
}
或是:
if ($user && $user->password == $user->hashPassword($this->password, $user->salt)) {
復(fù)制代碼 代碼如下:
public function validatePassword($password) {
return $this->hashPassword($password, $this->salt) === $this->password;
}
public function hashPassword($password, $salt) {
return md5(md5($password) . $salt);
}
public function generateSalt() {
$str = '1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
$len = strlen($str) - 1;
$string = '';
for ($i = 0; $i < 6; $i++) {
$string .= $str[mt_rand(0, $len)];
}
return $string;
}
或是:
復(fù)制代碼 代碼如下:
public function validatePassword($password) {
return $this->hashPassword($password,$this->salt)===$this->password;
}
public function hashPassword($password,$salt)
{
return md5($salt.$password);
}
protected function generateSalt()
{
return uniqid('',true);
}
注意:如果有salt,數(shù)據(jù)庫里面字段要有salt。。
您可能感興趣的文章:
相關(guān)文章
以實(shí)例全面講解PHP中多進(jìn)程編程的相關(guān)函數(shù)的使用
這篇文章主要介紹了以實(shí)例全面講解PHP中多進(jìn)程編程的相關(guān)函數(shù)的使用,包括對僵尸進(jìn)程的處理等方面,極力推薦!需要的朋友可以參考下2015-08-08
php生成二維碼不保存服務(wù)器還有下載功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了php生成二維碼不保存服務(wù)器還有下載功能的實(shí)現(xiàn)代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
2018-08-08
Laravel框架DB facade數(shù)據(jù)庫操作詳解
這篇文章主要介紹了Laravel框架DB facade數(shù)據(jù)庫操作,結(jié)合實(shí)例形式詳細(xì)分析了laravel數(shù)據(jù)庫基本創(chuàng)建、連接、增刪改查等操作技巧,需要的朋友可以參考下
2019-12-12 
