本文主要是介绍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为表名,前缀为数据库默认设置的前缀,如果前缀不变的情况下,需要验证表字段唯一的则可以直接使用表名做验证
这篇关于ThinkPHP6使用Validate验证表单字段唯一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!