欢迎光临
未来你我一起携手

thinkphp实战,从0开始抄代码 做一个用户管理系统[第三节]

上一节整理了Model。主要讲了一些高级数据库的交互,这一节直接绕过模版日志之类的东西,开始看验证这一块,验证这一块主要是一个验证器。以及一些对应的验证操作。先看看如何新建一个验证器吧

关于thinkPHP的验证器,说明如下:

这是5.0推荐的验证方式,为具体的验证场景或者数据表定义好验证器类,直接调用验证类的check方法即可完成验证

那我们就开始新建一个验证器吧。官方给了一个独立验证器,我们先大致感受一下这个东西是什么样的

$validate = new Validate([
    'name'  => 'require|max:25',
    'email' => 'email'
]);
$data = [
    'name'  => 'thinkphp',
    'email' => 'thinkphp@qq.com'
];
if (!$validate->check($data)) {
    dump($validate->getError());
}

代码太多,稍稍来做一些删减好了。别忘了在头部加use think\Validate。

官方给的测试代码在原封不动的情况下是没有任何返回的。好了,我们简单的做一些修改。注意这一句if (!$validate->check($data)) 。根据官方给的说明,说使用check就可以验证,那这里的逻辑就是  加入匹配不成功,则获取错误信息。那我们这里不在这里做改动。我们改动上面的验证规则。当我尝试把’name’ => ‘require|max:25’改成了‘name’ => ‘require|max:1’,的时候。系统抛出一个错误提示。长度不能超过1。这就是一个很简单的验证的例子了。至于下面一个email。我们也试着做一些改动。我们把这个正确的email地址修改成不正确的email地址。同样也返回了一个string(17) “email格式不符”错误。果然还蛮好使的呢。我们接着看文档。接下来讲述的是如何新建一个验证器。依葫芦画瓢来整一个

我在app\index\validate\下新建了一个User.php。内容是官方给出的示例代码

	namespace app\index\validate;
	use think\Validate;
	class User extends Validate
	{
		protected $rule = [
			'name'  =>  'require|max:25',
			'email' =>  'email',
		];

	}

然后验证代码也做了一点小改动

public function yz()
	{
		$data = [
			'name'  => 'thinkphp',
			'email' => 'thinkphpqq.com'
		];
		$validate = Loader::validate('User');
		if(!$validate->check($data)){
			dump($validate->getError());
		}
	}

但是这里却提示Class ‘app\index\controller\Loader’ not found

在头部添加use think\Laoder即可。嘿嘿。这时候就可以正常验证啦。另外在接下来的一节里面涉及到了一些错误的定义,用到了诸如between啊之类的东西。下面请看这一段

protected $rule =   [
        'name'  => 'require|max:25',
        'age'   => 'number|between:1,120',
        'email' => 'email',    
    ];
    
    protected $message  =   [
        'name.require' => '名称必须',
        'name.max'     => '名称最多不能超过25个字符',
        'age.number'   => '年龄必须是数字',
        'age.between'  => '年龄只能在1-120之间',
        'email'        => '邮箱格式错误',    
    ];

这里定义了几个规则,并且在下方也有对应的错误提示。简单看一下。max就是最大咯,最大25字符。between咯,在1和120之间,然后前面是number。就是代表了数字。而|号就是在需要多个验证的时候来做分隔符的。比如说age的number和between1,120这里。就是 年龄必须是数字,并且在1和120之间咯。

另外对应的错误提示也有对应。比如什么age.number啦。不是数字的时候会提示年龄必须是数字。

在设定好规则和错误提示之后,你可以使用下面代码来进行验证了。

$data = [
    'name'  => 'thinkphp',
    'age'   => 10,
    'email' => 'thinkphp@qq.com',
];

$validate = new Validate($rule, $msg);
$result   = $validate->check($data);

如果需要批量验证,可以使用:

$validate = new Validate($rule, $msg);
$result   = $validate->batch()->check($data);

批量验证如果验证不通过,返回的是一个错误信息的数组。

如果你定义了User验证器类的话,可以使用下面的验证代码:

$data = [
    'name'  => 'thinkphp',
    'age'   => 10,
    'email' => 'thinkphp@qq.com',
];
$validate = Loader::validate('User');
if(!$validate->check($data)){
    dump($validate->getError());
}

闭包函数验证

可以对某个字段使用闭包验证,例如:

$validate = new \think\Validate([
    'name'  => function($value,$data) { 
        return 'thinkphp'==$value ? true : false;
    },
]);

第一个参数是当前字段的值,第二个参数是全部数据

自定义验证规则

系统内置了一些常用的规则,如果还不够用,可以自己扩展验证规则。

如果使用了验证器的话,可以直接在验证器类添加自己的验证方法,例如:

namespace app\index\validate;

use think\Validate;

class User extends Validate
{
    protected $rule = [
        'name'  =>  'checkName:thinkphp',
        'email' =>  'email',
    ];
    
    protected $message = [
        'name'  =>  '用户名必须',
        'email' =>  '邮箱格式错误',
    ];
    
    // 自定义验证规则
    protected function checkName($value,$rule,$data)
    {
        return $rule == $value ? true : '名称错误';
    }
}

验证方法可以传入的参数共有5个(后面三个根据情况选用),依次为:

  • 验证数据
  • 验证规则
  • 全部数据(数组)
  • 字段名
  • 字段描述

并且需要注意的是,自定义的验证规则方法名不能和已有的规则冲突。

接下来,就可以这样进行验证:

$validate = Loader::validate('User');
if(!$validate->check($data)){
    dump($validate->getError());
}

如果没有使用验证器类,则支持使用extend方法扩展验证规则,例如:

$validate = new Validate(['name' => 'checkName:1']);
$validate->extend('checkName', function ($value, $rule) {
    return $rule == $value ? true : '名称错误';
});
$data   = ['name' => 1];
$result = $validate->check($data);

支持批量注册验证规则,例如:

$validate = new Validate(['name' => 'checkName:1']);
$validate->extend([
    'checkName'=> function ($value, $rule) {
    return $rule == $value ? true : '名称错误';
},
    'checkStatus'=> [$this,'checkStatus']
]);
$data   = ['name' => 1];
$result = $validate->check($data);

设置字段信息

V5.0.4+版本开始,验证类的架构方法支持传入field参数批量设置字段的描述信息,例如:

$rule = [
    'name'  => 'require|max:25',
    'age'   => 'number|between:1,120',
    'email' => 'email',
];

$field = [
    'name'  => '名称',
    'age'   => '年龄',
    'email' => '邮箱',	
];

$data = [
    'name'  => 'thinkphp',
    'age'   => 10,
    'email' => 'thinkphp@qq.com',
];

$validate = new Validate($rule, [] , $field);
$result   = $validate->check($data);

具体的可以多看几遍文档。这里倒也不是很大的重点。另外,需要注意的是,有一个表单令牌的功能。可以生成一个token以防止某些问题发生。

public function view()
	{
		$this->assign("name","cc");
		return $this->fetch();
	}

html

<input type="text" name="__token__" value="{$Request.token}" />{$name}

可以配合验证器来验证这个令牌是否有效。

 

 

 

未经允许不得转载:卧栏听雨 » thinkphp实战,从0开始抄代码
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址