我正在开发Cake
PHP 3.0,我想将数据库密码与“更改密码”功能中表单中输入的旧密码进行比较.但是我无法这样做,因为即使我们使用相同的密码,密码也经过哈希处理,并且哈希密码每次都不同.
请帮帮我.
提前致谢,
乱斗
解决方法
我会在你的UsersTable的验证器中执行此操作.
SRC /型号/表/ UsersTable.PHP
$validator ->notEmpty('current_password') ->add('current_password','custom',[ 'rule' => function($value,$context) { $query = $this->find() ->where([ 'id' => $context['data']['id'] ]) ->first(); $data = $query->toArray(); return (new DefaultPasswordHasher)->check($value,$data['password']); },'message' => 'Current password is incorrect!' ]);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。