emlog使用PHP5.5自带password_hash()函数

php.png

PHP5.5之后新加了两个密码相关的函数:password_hash(加密)和password_verify(验证)。

string password_hash ( string $password , integer $algo [, array $options ] )

boolean password_verify ( string $password , string $hash )

想到emlog使用的是passwordhash类来实现加密和解密的,正好使用这2个新函数来改造emlog程序。(该修改仅用于测试)


修改方法如下:

1、在include/lib/function.base.php添加加密函数

function HashPassword($password) { return password_hash(md5($password), PASSWORD_DEFAULT);}
2、修改admin/user.php,有2次,大概在50~51和126~130行
 $PHPASS = new PasswordHash(8, true); $password = $PHPASS->HashPassword($password);改为 $password = HashPassword($password);
 if (!empty($password)) { $PHPASS = new PasswordHash(8, true); $password = $PHPASS->HashPassword($password); $userData['password'] = $password; }改为 if (!empty($password)) { $password = HashPassword($password); $userData['password'] = $password; }
3、修改admin/blogger.php,大概在54~58行
 if (!empty($newpass)) { $PHPASS = new PasswordHash(8, true); $newpass = $PHPASS->HashPassword($newpass); $User_Model->updateUser(array('password'=>$newpass), UID); }改为 if (!empty($newpass)) { $newpass = HashPassword($newpass); $User_Model->updateUser(array('password'=>$newpass), UID); }
4、修改include/lib/loginauth.php,大概在119~126行
 public static function checkPassword($password, $hash) { global $em_hasher; if (empty($em_hasher)) { $em_hasher = new PasswordHash(8, true); } $check = $em_hasher->CheckPassword($password, $hash); return $check; }改为 public static function checkPassword($password, $hash) { return password_verify(md5($password),$hash); }

5、删除include/lib/passwordhash.php

由于加密方式改变,需要需改数据库里面用户的密码,因为使用了PASSWORD_DEFAULT最好把varchar的长度改为255. 

PASSWORD_DEFAULT - 使用 bcrypt 算法 (PHP 5.5.0 默认)。 注意,该常量会随着 PHP 加入更新更高强度的算法而改变。 所以,使用此常量生成结果的长度将在未来有变化。 因此,数据库里储存结果的列可超过60个字符(最好是255个字符)。

X
赞助一下:
    支付宝    微信    QQ红包

打开支付宝扫一扫
emlog使用PHP5.5自带password_hash()函数
版权声明:若无特殊注明,本文皆为“懒人的小窝”原创,转载请保留文章出处。
本文链接:http://suppore.cn/246.html    百度已收录
正文到此结束

点击下方支持本站

点击支持下贵站吧
点击支持下贵站吧

热门推荐

发表吐槽

你肿么看?

你还可以输入 250 / 250 个字

微笑可爱憨笑鼓掌白眼发呆撇嘴色得意吐抠鼻可怜呲牙惊讶冷汗流泪大哭发怒抚摸傲慢惊恐鄙视疑问奸笑抓狂偷笑流汗擦汗晕委屈吓衰糗大了威武给力牛逼

评论信息框

火箭正在发射中...


既然没有吐槽,那就赶紧抢沙发吧!