ThinkPHP6使用Validate验证表单字段唯一
ThinkPHP6使用Validate验证表单字段唯一
1.创建用户验证文件,如User
1.1 单应用创建验证文件
php think make:validate User
1.2 多应用创建验证文件,admin为应用名,
php think make:validate admin@User
创建成功后,应用内会生成一个validate文件夹,在validate文件夹里会生成User.php的验证文件
2.创建成功后代码
<?php
declare (strict_types = 1);
namespace app\base\validate;
use think\Validate;
class User extends Validate
{
/**
* 定义验证规则
* 格式:'字段名' => ['规则1','规则2'...]
*
* @var array
*/
protected $rule = [];
/**
* 定义错误信息
* 格式:'字段名.规则名' => '错误信息'
*
* @var array
*/
protected $message = [];
}
3.如验证用户名唯一
<?php
declare (strict_types = 1);
namespace app\base\validate;
use think\Validate;
class User extends Validate
{
/**
* 定义验证规则
* 格式:'字段名' => ['规则1','规则2'...]
*
* @var array
*/
protected $rule = [
'username' => 'require|unique:\app\model\User'
];
/**
* 定义错误信息
* 格式:'字段名.规则名' => '错误信息'
*
* @var array
*/
protected $message = [
'username.require' => '用户名必填',
'username.unique' => '用户名唯一'
];
}
\app\model\User为用户模型,用户模型可以通过模型文件设置文件的连接设置,数据表的名称等等相关的设置,可以解决数据表前缀与数据库默认设置前缀不一样的问题
<?php
declare (strict_types = 1);
namespace app\base\validate;
use think\Validate;
class User extends Validate
{
/**
* 定义验证规则
* 格式:'字段名' => ['规则1','规则2'...]
*
* @var array
*/
protected $rule = [
'username' => 'require|unique:user' // 指定验证表
];
/**
* 定义错误信息
* 格式:'字段名.规则名' => '错误信息'
*
* @var array
*/
protected $message = [
'username.require' => '用户名必填',
'username.unique' => '用户名唯一'
];
}
上面代码中的unique:user为验证指定表的唯一字段,user为表名,前缀为数据库默认设置的前缀,如果前缀不变的情况下,需要验证表字段唯一的则可以直接使用表名做验证