控制器里面:elseif(!$model->validatePassword($data->password))
代码如下:{ /** * 检测用户密码 * * @return boolean */ public function validatePassword ($password) { return $this->hashPassword($this->password) === $password; } /** * 密码进行加密 * @return string password */ 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 function generateSalt() { $str = '1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'; $len = strlen($str) - 1; $string = ''; for ($i = 0; $i < 6; $i++) { $string .= $str[mt_rand(0,$len)]; } return $string; }
或是:
代码如下: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,数据库里面字段要有salt。。 (编辑:安卓应用网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|