1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- <?php
- namespace app\validate\admin\user;
- use app\model\admin\User;
- use think\Validate;
- class Edit extends Validate
- {
- //数组顺序就是检测的顺序
- protected $rule = [
- 'id' => 'require|checkId:',
- 'username' => 'require|length:2,30|checkUsername:',
- 'nickname' => 'require|length:2,30',
- 'password' => 'length:6,30|confirm:re_password',
- 'is_super_manager' => 'require',
- 'status' => 'require',
- ];
- //定义内置方法检验失败后返回的字符
- protected $message = [
- 'username.require' => '用户名不能为空',
- 'username.length' => '用户名长度2-30',
- 'nickname.require' => '昵称不能为空',
- 'nickname.length' => '昵称长度2-30',
- 'password.length' => '密码长度6-30',
- 'password.confirm' => '两次密码输入不相同',
- 'is_super_manager.require' => '请设置用户是否为超级管理员',
- 'status.require' => '请设置账号的状态',
- ];
- public function checkId($id, $rule, $data)
- {
- if ($id == 1) {
- if ($data['is_super_manager'] == 2) {
- return '不允许将初始化用户编辑成非超级管理员';
- }
- if ($data['status'] == 2) {
- return '不允许禁用初始化用户';
- }
- }
- return true;
- }
- //验证用户名的唯一性
- protected function checkUsername($username, $rule, $data){
- $userId = User::getFieldByUsername($username,'id');
- if($userId && $userId != $data['id']){
- return '用户名已存在';
- }
- return true;
- }
- }
|