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/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : /www/wwwroot/0531yanglao.com/app/admin/validate/AdminMyValidate.php
<?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;
    }
}