制御器里面:elseif(!$model->validatePassword($data->password))
复制代码代码如下:
class XBaseModel extends CActiveRecord
{
/**
* ユーザーパスワードの検出
*
* @return boolean*/
public function validatePassword )
{
$を返すthis->hashPassword($this->password) === $password;
}
/**
* 暗号化用のパスワード
* @return 文字列パスワード
*/
public function hashPassword ($password)
{
return md5($password);
}
}
またはである:
if ($user && $user->password == $user->hashPassword($this->password, $user->salt)) {
复制代码代码如下:
public function validatePassword($password) {
return $this->hashPassword($password, $this->salt) === $this->password ;
}
public function hashPassword($password, $salt) {
return md5(md5($password) . $salt);
}
public functiongenerateSalt() {
$str = '1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
$len = strlen($str) - 1;
$string = '';
for ($i = 0; $i <6; $i++) {
$string .= $str[mt_rand(0, $len)];
}
$string を返します。
}
またはである:
复制代码代码如下:
public function validatePassword($password) {
return $this->hashPassword($password,$this->salt)===$this->パスワード;
}
public function hashPassword($password,$salt)
{
return md5($salt.$password);
}
protected functiongenerateSalt()
{
return uniqid('',true);
}
注意: 塩分が含まれている場合、データベースのフィールドには塩分が必要です。
http://www.bkjia.com/PHPjc/824853.html
www.bkjia.comtruehttp://www.bkjia.com/PHPjc/824853.html技術記事制御器里面:elseif(!$model-validatePassword($data-password)) 复制代码如下: ?php class XBaseModel extends CActiveRecord { /** * 检测用户密码 * * @return boo...