thinkphp验证用户名是否重复


<?php /** * Created by PhpStorm. */ namespace Admin\Model; use Think\Model; class UserModel extends Model { //自动验证 
    protected $_validate=array( //array(验证字段,验证规则,错误提示,验证条件,附加规则,验证时间) 或者单独留给注册用,登陆单独写规则 
        array('user_name','','帐号名称已经存在!',0,'unique',1), 
        array('user_name','require','用户名不能为空',self::EXISTS_VALIDATE), 
        array('user_name', '5,20', '用户名长度5-20位!', self::EXISTS_VALIDATE,'length'), 
        array('password','require','密码不能为空',self::EXISTS_VALIDATE), 
        array('code','require','验证码不能为空',self::EXISTS_VALIDATE), 
        array('password', '5,30', '密码长度不合法!', self::EXISTS_VALIDATE,'length'), 
        array('repassword', 'password', '俩次输入密码不一致!', self::EXISTS_VALIDATE,'confirm'), 
        array('code', '4', '请输入4位验证码', self::EXISTS_VALIDATE,'length'), ); //使用create方法创建数据对象的时候,执行Add()方法时,不在$insertFields定义范围内的字段将直接丢弃即只允许新增定义内的字段 
    protected $insertFields = array('id','user_name','password','user_byname','reg_time','reg_ip','login_time','login_count','role_id','status','unqi_id'); //使用create方法更新数据对象的时候,执行sava()方法时,不在$updateFields定义范围内的字段将直接丢弃 
    protected $updateFields = array('id','user_name','password','user_byname','reg_time','reg_ip','login_time','login_count','role_id','status','unqi_id'); //自动完成 
    protected $_auto=array( array('password', 'sha1', self::MODEL_INSERT, 'function'), 
        array('login_time', 'time', self::MODEL_INSERT, 'function'), 
        array('reg_time','time',self::MODEL_INSERT,'function'), 
        array('reg_ip','get_client_ip',self::MODEL_INSERT,'function'), 
        array('login_ip','get_client_ip',self::MODEL_BOTH,'function'), 
        array('login_time','time',self::MODEL_BOTH,'function'), 
        array('login_count',0,self::MODEL_INSERT), 
        array('status',1,self::MODEL_INSERT), 
        array('password','',self::MODEL_UPDATE,'ignore'),//修改时空白则忽略 
 ); //检帐帐户是否存在或者停用状态 
    public function checkStatus($username){ $map=array(); $map['user_name']=$username; $map['status']=array('gt',0); return $authInfo=$this->where($map)->find(); } //验证登陆 
    public function checkLogin($username,$password,$code){ $data=array( 'user_name'=>$username, 
            'password'=>$password, 
            'code'=>$code, ); if(!$this->create($data)) return $this->getError(); //检测用户名是否存在或状态 
        if($authInfo=$this->checkStatus($username)){ return  $authInfo; } } //登陆后更新数据库登陆时间和次数级ip 
    public function update($user_id,$login_count){ $data = array( 'login_time'=>time(), 
            'login_ip'=>get_client_ip(), 
            'login_count'=>$login_count+1 ); return $this-> where('id='.$user_id )->setField($data); } //注册管理员 
    public function register($username,$re_name,$byname,$password){ $data=array( 're_name'=>$re_name, 
            'user_name'=>$username, 
            'user_byname'=>$byname, 
            'password'=>$password, ); if(!$this->create($data)){ return $this->getError(); }else{ P($data); echo  $this->add(); } } } 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM