您的位置:首页 > 编程语言 > PHP开发

php登陆页的密码处理方式分享

2013-10-15 14:50 465 查看
控制器里面:elseif(!$model->validatePassword($data->password))

代码如下:

<?php

class XBaseModel extends CActiveRecord
{
/**
* 检测用户密码
*
* @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;
}
unity3d http://www.unitymanual.com 或是:

代码如下:

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。。
本文出自 “unity3d学习者” 博客,请务必保留此出处http://unity3d168.blog.51cto.com/4361353/1309183
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: