editSelfValidate.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeadmin快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
  8. // | github下载:https://github.com/likeshop-github/likeadmin
  9. // | 访问官网:https://www.likeadmin.cn
  10. // | likeadmin团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: likeadminTeam
  13. // +----------------------------------------------------------------------
  14. namespace app\adminapi\validate\auth;
  15. use app\common\validate\BaseValidate;
  16. use app\common\model\auth\Admin;
  17. use think\facade\Config;
  18. /**
  19. * 编辑超级管理员验证
  20. * Class editSelfValidate
  21. * @package app\adminapi\validate\auth
  22. */
  23. class editSelfValidate extends BaseValidate
  24. {
  25. protected $rule = [
  26. 'name' => 'require|length:1,16',
  27. 'avatar' => 'require',
  28. 'password' => 'length:6,32|checkPassword',
  29. 'password_confirm' => 'requireWith:password|confirm',
  30. ];
  31. protected $message = [
  32. 'name.require' => '请填写名称',
  33. 'name.length' => '名称须在1-16位字符',
  34. 'avatar.require' => '请选择头像',
  35. 'password_now.length' => '密码长度须在6-32位字符',
  36. 'password_confirm.requireWith' => '确认密码不能为空',
  37. 'password_confirm.confirm' => '两次输入的密码不一致',
  38. ];
  39. /**
  40. * @notes 校验密码
  41. * @param $value
  42. * @param $rule
  43. * @param $data
  44. * @return bool|string
  45. * @author 段誉
  46. * @date 2022/4/8 17:40
  47. */
  48. public function checkPassword($value, $rule, $data)
  49. {
  50. if (empty($data['password_old'])) {
  51. return '请填写当前密码';
  52. }
  53. $admin = Admin::findOrEmpty($data['admin_id']);
  54. $passwordSalt = Config::get('project.unique_identification');
  55. $oldPassword = create_password($data['password_old'], $passwordSalt);
  56. if ($admin['password'] != $oldPassword) {
  57. return '当前密码错误';
  58. }
  59. return true;
  60. }
  61. }