问题:
用户名没有做严格的限制,类似“111”,“123456”,“_____111”这样的的用户名都是被允许的,那么如何限制用户输入我们所希望的用户名呢?
一般的注册,都有重复输入密码的input框,是为了让用户再次确认自己输入的密码,如何添加呢?
为了提高注册用户的质量,防止批量注册,添加验证码是不错的选择,如何加?
如何在不修改逻辑代码的情况下完美解决以上三个问题?看了下面的教程,一目了然!
以高级版2.0.6为例,打开/frontend/models/signupform.php
, ['username', 'required'], ['username', 'unique', 'targetclass' => 'commonmodelsuser', 'message' => 'this username has already been taken.'], ['username', 'string', 'min' => 2, 'max' => 255], ['email', 'filter', 'filter' => 'trim'], ['email', 'required'], ['email', 'email'], ['email', 'string', 'max' => 255], ['email', 'unique', 'targetclass' => 'commonmodelsuser', 'message' => 'this email address has already been taken.'], ['password', 'required'], ['password', 'string', 'min' => 6], ]; } 只需修改rules规则即可完美实现 a.添加用户字符限制,6-16位 ['username', 'string', 'min' => 6, 'max' => 16], 输入限制:用户名由字母,汉字,数字,下划线组成,且不能以数字和下划线开头。 ['username', 'match','pattern'=>'/^[(x{4e00}-x{9fa5})a-za-z]+[(x{4e00}-x{9fa5})a-za-z_d]*$/u', 'message'=>'用户名由字母,汉字,数字,下划线组成,且不能以数字和下划线开头。'], b.添加重复密码字段 public $repassword; 一般重复密码与密码的字段验证基本上是一致的,所以可以在password中添加repassword,并添加两次输入一致的限制 [['password','repassword'], 'required'], [['password','repassword'], 'string', 'min' => 6], ['repassword', 'compare', 'compareattribute' => 'password','message'=>'两次输入的密码不一致!'], c.添加验证码字段 public $verifycode; 验证码有自带的扩展,只需添加以下代码即可 ['verifycode', 'captcha'], 本例为sitecontroller中添加[/b] public function actions() { return [ 'captcha' => [ 'class' => 'yiicaptchacaptchaaction', 'fixedverifycode' => yii_env_test ? 'testme' : null, ], ]; }
修改之后的规则
class signupform extends model { public $username; public $email; public $password; public $repassword; public $verifycode; public function rules() { return [ ['username', 'filter', 'filter' => 'trim'], ['username', 'required'], ['username', 'unique', 'targetclass' => 'commonmodelsuser', 'message' => '该用户名已被使用!'], ['username', 'string', 'min' => 6, 'max' => 16], ['username', 'match','pattern'=>'/^[(x{4e00}-x{9fa5})a-za-z]+[(x{4e00}-x{9fa5})a-za-z_d]*$/u', 'message'=>'用户名由字母,汉字,数字,下划线组成,且不能以数字和下划线开头。'], ['email', 'filter', 'filter' => 'trim'], ['email', 'required'], ['email', 'email'], ['email', 'string', 'max' => 255], ['email', 'unique', 'targetclass' => 'commonmodelsuser', 'message' => '该邮箱已经被注册!'], [['password','repassword'], 'required'], [['password','repassword'], 'string', 'min' => 6], ['repassword', 'compare', 'compareattribute' => 'password','message'=>'两次输入的密码不一致!'], ['verifycode', 'captcha'], ]; } ....
验证一下效果
以上就是yii2.0 模型rules验证详解的内容。
