11 验证器《ThinkPHP6 入门到电商实战》

注:示例来源于官方手册

一、验证器定义

验证器用于对数据进行验证,你可以理解为一个“层”,在传入数据时可以使用这个层对数据进行验证,这样就可以不用频繁的在方法中编写代码去验证,只需要编写一个验证层即可,此操作需要自己编写对应的代码,本节只是介绍验证器的使用。

此时我们在 app 目录下新建一个 validate 文件夹,在其中新建一个 User.php 假设用于用户传入的用户信息进行验证。

在这里插入图片描述
随后在 User.php 中编写如下代码:

<?php
namespace app\validate;
use think\Validate;class User extends Validate
{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'        => '邮箱格式错误',    ];}

以上代码中可以看到,当前 User 类继承至验证器 Validate 类,其中 protected 的属性 rule 是表示验证规则,为一个数组;name 表示这个字段名 require 表示为必须,并且 max 最大字符不能超过 25个;age 是 number 类型数据,在 1-120 之间,同一个字段多个不同的规则使用 | 进行分隔,若只有一个规则就如同 email 字段的规则是 email 表示是邮件字段。

在此还发现了 message 属性,其中指定了每个规则验证不通过时的提示信息。

二、验证器使用方法

以下是一个最简单的验证器使用方法:

public function userValidate(){try {validate(User::class)->check(['name'  => 'thinkphp','email' => 'thinkphpcom',]);} catch (ValidateException $e) {// 验证失败 输出错误信息dump($e->getError());}
}

当验证器验证错误将会抛出异常,并且会中断验证,使用验证器很简单,use 之后直接使用 validate(User::class)指定验证器后使用 check 方法即可。在 check 方法中需要传入一个数组,数组值为需要验证字段的信息,在以上示例中我的 email 是错误的邮箱编写格式,此时将会抛出异常:
在这里插入图片描述

三、设置批量验证

在以上一点中已经说过,验证是会中断的,若有多个错误信息时,需要批量验证的话可以设置 batch 为 true 即可,如下示例:

public function userValidate(){try {validate(User::class)->batch(true)->check(['name'  => 'thinkphp','age'  => 130,'email' => 'thinkphpcom',]);} catch (ValidateException $e) {// 验证失败 输出错误信息dump($e->getError());}
}

以上实例中,我的 age 值明显大于了本身规则的限定在 120 以内,所以此时将会抛出两个提示:
在这里插入图片描述

四、自定义验证规则

验证器还支持自定义的验证规则,例如以下示例,首先是 user 验证器中:

class User extends Validate
{protected $rule =   ['name'  => 'require|checkName:敏感字,','age'   => 'number|between:1,120','email' => 'email',    ];protected $message  =   ['name.require' => '名称必须','name.max'     => '名称最多不能超过25个字符','age.number'   => '年龄必须是数字','age.between'  => '年龄只能在1-120之间','email'        => '邮箱格式错误',    ];// 自定义验证规则protected function checkName($value, $rule, $data=[]){return $rule == $value ? true : '敏感字符';}}

此时修改了 rule 的验证规则 name,其中有一个 checkName 规则是我们自定义的方法,二冒号后面的敏感字是该方法的参数,随后我们可以查看方法 checkName,其中 value 是需要验证的字符,rule 是敏感字,data 是所有需要验证的信息数组;接着我们传入对应的变量:

try {validate(User::class)->batch(true)->check(['name'  => '敏感字','age'  => 110,'email' => '123@163.com',]);
} catch (ValidateException $e) {// 验证失败 输出错误信息dump($e->getError());
}

此时将会抛出异常:

在这里插入图片描述

五、手动使用验证器

验证器还支持自己手动编写规则,自行调用,如下示例:

public function userValidate(){$validate = \think\facade\Validate::rule('age', 'number|between:1,120')->rule(['name'  => 'require|max:25','email' => 'email']);$data = ['name'  => 'thinkphp','email' => 'thinkphp'];if (!$validate->check($data)) {dump($validate->getError());}
}

手动调用方式大致相同,初始化规则创建验证器对象后,在使用check 时进行check 即可。

更多验证规则可以查看手册:https://www.kancloud.cn/manual/thinkphp6_0/1037629
且官方还提供了路由验证、令牌、注解验证 等验证,可以自行查看官方手册,本专栏只介绍一般方法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/285948.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nginx+php

nginxphp基础架构 生产实践 nginx配置文件: 主配置文件 123456789101112131415161718192021222324252627282930313233[rootlinux-node1 conf.d]# cat /etc/nginx/nginx.conf user nginx;worker_processes auto;error_log /var/log/nginx/error.log; pid /run/nginx.pid; # Load…

【ArcGIS风暴】ArcGIS10.8中栅格数据金字塔的来龙去脉,你知道吗?

如下图所示,通常情况下,当将没有金字塔的栅格数据集添加至 ArcGIS时,系统将提示您构建金字塔。金字塔指不同比例下分辨率降低的数据概视图。金字塔十分有用,因为金字塔提升了分辨率低于其全分辨率的栅格数据集的绘制速度。建议构建用于大型栅格数据集的金字塔。 点击【是】…

斯坦福大学Andrew Ng - 机器学习笔记(8) -- 推荐系统 大规模机器学习 图片文字识别...

大概用了一个月&#xff0c;Andrew Ng老师的机器学习视频断断续续看完了&#xff0c;以下是个人学习笔记&#xff0c;入门级别&#xff0c;权当总结。笔记难免有遗漏和误解&#xff0c;欢迎讨论。 鸣谢&#xff1a;中国海洋大学黄海广博士提供课程视频和个人笔记&#xff0c;在…

【CSS动效实战(纯CSS与JS动效)】02 flex 布局实战(仿 JD 及 gitCode 布局)及 media 自适应初探 下

二、flex 仿 gitCode 布局 及 自适应 首先查看我们的页面&#xff1a; 这个时候直接顶部一个块&#xff0c;下面分为左中右三个块&#xff0c;然后就解决了&#xff0c;是不是很简单&#xff1f;相比刚刚那么这个简单多了。那就来做吧。 2.1 基本布局 首先给一个 style 价格…

C语言按行和列求平均成绩代码(指针,二维数组)

如下所示成绩表,如何按行(每个人)或按列(每门课)的平均成绩? 结果: 文章目录 1. 自定义行平均函数2. 自定义列平均函数3. main()函数调用平均函数1. 自定义行平均函数 float save(float **PA,int M,int

架构师必须知道的架构设计原则

目录 一、前言 二、软件设计原则 GRASP通用职责分配软件模式 1. 信息专家(Information Expert) 2. 创建者(Creator) 3. 低耦合(Low Coupling) 4. 高内聚(High Cohesion) 5.控制器(Controller) 6. 多态(Polymorphism) 7. 纯虚构(Pure Fabrication) 8. 间接(Indirectio…

百度:病种类贴吧全面停止商业合作

新浪科技讯 1月12日上午消息&#xff0c; 百度今日就热门疾病被出卖一事向新浪科技发布对外公告&#xff1a;病种类贴吧全面停止商业合作 只对权威公益组织开放。百度方面在公告中表示&#xff0c;为了规范具有明显商业属性贴吧的运营管理&#xff0c;并提升贴吧的内容质量和用…

【CSS动效实战(纯CSS与JS动效)】02 flex 布局实战(仿 JD 及 gitCode 布局)及 media 自适应初探

一、flex 仿 JD 布局 首先&#xff0c;我们在编辑器中&#xff0c;写上基础代码&#xff0c;当然要在 style 中加上一个 flex 类&#xff0c;用于 flex 布局的定义&#xff0c;这个是必然需要的&#xff0c;在此一定得加上。 <!DOCTYPE html> <html lang"en&qu…

C语言sin()函数绘制正弦曲线代码(0-2π)

本文实现y=sin(x)正弦曲线在0-2π范围内的曲线图形,如下图所示: 完整C语言代码: #include<stdio.h> #include<math.h> main() {double y; int x,m,i; printf

MAUI模板项目闪退问题

MAUI模板项目闪退问题在MAUI最初发布的时候就曾创建过几个模板项目进行体验过&#xff0c;没遇到什么坑。由于最近需要开发针对餐饮行业的收银机&#xff08;安卓系统&#xff09;开发一款应用&#xff0c;这种收银机一般配置不咋滴&#xff0c;系统版本和性能也肯定比不上我们…

真正CSDN博客文章一键转载插件(含源码)

插件地址&#xff1a;https://greasyfork.org/zh-CN/scripts/381053-csdn%E5%8D%9A%E5%AE%A2%E6%96%87%E7%AB%A0%E8%BD%AC%E8%BD%BD%E6%8F%92%E4%BB%B6 插件安装使用说明请参阅&#xff1a;https://greasyfork.org/zh-CN 文章阅读界面 文章发布页面 源代码 // UserScript //…

微软欲闭源VS Code的C#扩展惹众怒

VS Code 是一个非常棒的代码编辑器&#xff0c;轻量&#xff0c;免费&#xff0c;跨平台。并且凭其丰富且强大的扩展功能受到众多开发者的青睐&#xff0c;你可以在上面愉快的进行各种语言的开发工作。就在前两天&#xff0c;微软的 .NET 和 Visual Studio 的项目经理 Tim Heue…

Python3.6学习笔记(三)

面向对象编程 面向对象编程 Object Oriented Programming 简称 OOP&#xff0c;是一种程序设计思想。OOP把对象作为程序的基本单元&#xff0c;一个对象包含了数据和操作数据的函数。 面向过程的程序设计把计算机程序视为一系列的命令集合&#xff0c;即一组函数的顺序执行。为…

EnumMap

什么是EnumMap Map接口的实现&#xff0c;其key-value映射中的key是Enum类型&#xff1b; 补充说明 其原理就是一个对象数组&#xff0c;数组的下标索引就是根据Map中的key直接获取&#xff0c;即枚举中的ordinal值&#xff1b; 效率比HashMap高&#xff0c;可以直接获取数组下…

【CSS动效实战(纯CSS与JS动效)】03 精美手风琴侧边栏完整示例教程 示例1

本节示例演示&#xff1a; 一、基本布局 一般来说&#xff0c;侧边栏的位置是在左侧&#xff0c;咱们为了更好的展现侧边栏的效果&#xff0c;并且在本节中不涉及过多的内容&#xff0c;我们只需要直接给一个 div 宽度为 15即可&#xff0c;接着再到这个 div 中编写对应的侧…

Windows 服务 同时启动多个服务

Windows 服务 同时启动多个服务独立观察员 2019.02.26最近需要开发 Windows Service 程序&#xff0c;之前没有接触过&#xff0c;所以把了解到的一些东西记录下来。Windows 服务程序可以简单理解为需要长时间在后台运行&#xff0c; 而又不需要界面显示的程序&#xff0c;在计…

一、基本remix环境及HelloWord contract《2022 solidity8.+ 版本教程到实战》

这个系列是 solidity8.版本的教程&#xff0c;既然学习了 solidity 就应该明白智能合约是啥&#xff0c;在此系列文章中将不赘述基础概念&#xff0c;只讲解对应的语法&#xff0c;希望读者理解。 环境 solidity 版本&#xff1a;8.(2022年9月8日 最新版本) IDE&#xff1a;h…

遥感空间尺度转换技术(升尺度和降尺度)

遥感图像的一个基本特征是空间分辨率。目前已经可以有效获取大量不同空间分辨率遥感数据。 尺度和尺度转换已经成为遥感的核心问题之一,人们已经从不同角度提出了这一问题。尺度转换分为两种: 升尺度:从高分辨率到低分辨率的转换;降尺度:从低分辨率到高分辨率的转换。文章…

three.js插件实现立体动感视频播放效果

2019独角兽企业重金招聘Python工程师标准>>> three.js插件实现立体动感视频播放效果 效果描述&#xff1a; 立体式视频播放效果 大家使用的时候可得注意了&#xff0c;它并不支持低版本浏览器 使用方法&#xff1a; 1、将body中的代码部分拷贝到你需要的地方,将视频…

Python3.6学习笔记(五)

网络编程 网络程序出现的比互联网要早很多&#xff0c;实现方式主要依靠网络上不同主机间进程的通信&#xff0c;通信协议最重要的是TCP/IP协议。在这两个协议基础上还有很多更高级的协议&#xff0c;包括HTTP、SMTP等。要进行两个主机间的网络通信&#xff0c;必须四个元素&a…