Server : nginx/1.20.1 System : Linux iZ2ze9ojcl78uluczwag69Z 4.18.0-240.22.1.el8_3.x86_64 #1 SMP Thu Apr 8 19:01:30 UTC 2021 x86_64 User : www ( 1000) PHP Version : 7.3.28 Disable Function : passthru,exec,system,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv Directory : /www/wwwroot/0531yanglao.com/app/admin/validate/ |
<?php /* * @Description : 个人中心验证器 * @Author : https://github.com/skyselang * @Date : 2020-05-05 * @LastEditTime : 2021-03-20 */ namespace app\admin\validate; use think\Validate; use think\facade\Db; use app\admin\service\AdminUserService; class AdminMyValidate extends Validate { // 验证规则 protected $rule = [ 'admin_user_id' => ['require', 'checkAdminUser'], 'username' => ['require', 'checkUsername', 'length' => '2,32'], 'nickname' => ['require', 'checkNickname', 'length' => '1,32'], 'password_old' => ['require'], 'password_new' => ['require', 'length' => '6,18'], 'email' => ['email', 'checkEmail'], 'avatar' => ['require', 'file', 'image', 'fileExt' => 'jpg,png,gif', 'fileSize' => '51200'], ]; // 错误信息 protected $message = [ 'admin_user_id.require' => '缺少参数:管理员id', 'username.require' => '请输入账号', 'username.length' => '账号长度为2至32个字符', 'nickname.require' => '请输入昵称', 'nickname.length' => '昵称长度为1至32个字符', 'password_old.require' => '请输入旧密码', 'password_new.require' => '请输入新密码', 'password_new.length' => '新密码长度为6至18个字符', 'email.email' => '请输入正确的邮箱地址', 'avatar.require' => '请选择图片', 'avatar.file' => '请选择图片文件', 'avatar.image' => '请选择图片格式文件', 'avatar.fileExt' => '请选择jpg、png、gif格式图片', 'avatar.fileSize' => '请选择大小小于50kb图片', ]; // 验证场景 protected $scene = [ 'user_id' => ['admin_user_id'], 'my_edit' => ['admin_user_id', 'username', 'nickname', 'email'], 'my_pwd' => ['admin_user_id', 'password_old', 'password_new'], 'my_avatar' => ['admin_user_id', 'avatar'], ]; // 自定义验证规则:管理员是否存在 protected function checkAdminUser($value, $rule, $data = []) { $admin_user_id = $value; $admin_user = AdminUserService::info($admin_user_id); if ($admin_user['is_delete'] == 1) { return '管理员已被删除:' . $admin_user_id; } return true; } // 自定义验证规则:账号是否已存在 protected function checkUsername($value, $rule, $data = []) { $admin_user_id = $data['admin_user_id']; $username = $data['username']; $admin_user = Db::name('admin_user') ->field('admin_user_id') ->where('admin_user_id', '<>', $admin_user_id) ->where('username', '=', $username) ->where('is_delete', '=', 0) ->find(); if ($admin_user) { return '账号已存在:' . $username; } return true; } // 自定义验证规则:昵称是否已存在 protected function checkNickname($value, $rule, $data = []) { $admin_user_id = $data['admin_user_id']; $nickname = $data['nickname']; $admin_user = Db::name('admin_user') ->field('admin_user_id') ->where('admin_user_id', '<>', $admin_user_id) ->where('nickname', '=', $nickname) ->where('is_delete', '=', 0) ->find(); if ($admin_user) { return '昵称已存在:' . $nickname; } return true; } // 自定义验证规则:邮箱是否已存在 protected function checkEmail($value, $rule, $data = []) { $admin_user_id = $data['admin_user_id']; $email = $data['email']; $admin_user = Db::name('admin_user') ->field('admin_user_id') ->where('admin_user_id', '<>', $admin_user_id) ->where('email', '=', $email) ->where('is_delete', '=', 0) ->find(); if ($admin_user) { return '邮箱已存在:' . $email; } return true; } }