标签:username 验证 check require scene thinkphp6 validate email
创建验证器基类 app/validate/BaseValidate.php
<?php namespace app\validate; use think\Validate; use app\lib\exception\BaseException; class BaseValidate extends Validate { public function goCheck($scene = false) { $params = request()->param();//获取所有参数 // 开始验证 $check = $scene ? $this->scene($scene)->check($params) : $this->check($params); if (!$this->check($params)) { throw new BaseException([ 'msg' => $this->getError(), 'code' => 400, 'statusCode' => 400, ]); } return true; } }
创建自定义验证器 app/validate/CeshiValidate.php
<?php declare (strict_types = 1); namespace app\validate; class CeshiValidate extends BaseValidate { /** * 定义验证规则 * 格式:'字段名' => ['规则1','规则2'...] * * @var array */ protected $rule = [ 'username' => 'require', 'email' => 'require|email', ]; /** * 定义错误信息 * 格式:'字段名.规则名' => '错误信息' * * @var array */ protected $message = [ 'username.require' => '用户名不能为空', 'email.require' => '邮箱不能为空', 'email.email' => '邮箱格式不正确', ]; protected $scene = [ 'username' => ['username'], 'email' => ['email'], ]; }
控制器中使用验证器 app/index/controller/Index.php
<?php namespace app\index\controller; use app\BaseController; use think\facade\Request; use app\lib\exception\BaseException; use app\validate\CeshiValidate; class Index extends BaseController { public function index() { // throw (new BaseException(['code'=>400,'statusCode'=>404,'msg'=>'异常'])); // return '111'; $scene = ''; $scene1 = 'username'; $scene2 = 'email'; (new CeshiValidate())->goCheck($scene2); } }
标签:username,验证,check,require,scene,thinkphp6,validate,email 来源: https://www.cnblogs.com/twilight-sparkle/p/14898445.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。