## 验证器
MixPHP 的验证器结合了多个框架的优点,如下:
- 支持场景控制。
- 验证成功后字段将赋值为验证类的属性,文件则直接实例化为文件对象。
- 更细粒度的错误消息设置。
- 支持在 WebSocket 开发中使用。
## 验证器定义
我们定义一个 `\apps\index\models\UserForm` 验证器类用于 `User` 控制器的验证。
~~~
<?php
namespace apps\index\models;
use mix\validators\Validator;
class UserForm extends Validator
{
public $name;
public $age;
public $email;
// 规则
public function rules()
{
return [
'name' => ['string', 'maxLength' => 25, 'filter' => ['trim']],
'age' => ['integer', 'unsigned' => true, 'min' => 1, 'max' => 120],
'email' => ['email'],
];
}
// 场景
public function scenarios()
{
return [
'create' => ['required' => ['name'], 'optional' => ['email', 'age']],
];
}
// 消息
public function messages()
{
return [
'name.required' => '名称不能为空.',
'name.maxLength' => '名称最多不能超过25个字符.',
'age.integer' => '年龄必须是数字.',
'age.unsigned' => '年龄不能为负数.',
'age.min' => '年龄不能小于1.',
'age.max' => '年龄不能大于120.',
'email' => '邮箱格式错误.',
];
}
}
~~~
>[danger] 如果没有定义错误提示信息,则使用系统默认的提示信息
## 数据验证
在需要进行 `User` 验证的控制器方法中,添加如下代码即可:
~~~
<?php
namespace apps\index\controllers;
use apps\index\models\UserForm;
use mix\facades\Request;
use mix\http\Controller;
class UserController extends Controller
{
public function actionCreate()
{
app()->response->format = \mix\http\Response::FORMAT_JSON;
// 使用模型
$model = new UserForm();
$model->attributes = Request::get() + Request::post();
$model->setScenario('create');
if (!$model->validate()) {
return ['code' => 1, 'message' => 'FAILED', 'data' => $model->getErrors()];
}
// 执行保存数据库
// ...
// 响应
return ['code' => 0, 'message' => 'OK'];
}
}
~~~
## 验证失败
验证失败可以通过以下方法获取错误消息:
- $model->getErrors() :获取全部错误信息,返回数组。
- $model->getError() :获取单条错误信息,返回字符串。
## 验证成功
验证成功后,验证规则中通过验证的字段,将会赋值到同名的验证类的属性中,未通过的字段则为 `null`。
这个功能有什么用?
>[success] 有了这个功能,我们就只需要把真个验证类的对象传入模型,就可以在模型里安全的使用这些属性操作数据库。
- 欢迎使用 MixPHP
- 安装说明
- 常规安装
- 只安装命令行
- Apache/PHP-FPM安装
- 开发与调试
- 开发注意事项
- 调试与错误
- 基础架构
- 目录结构
- 目录设计
- URL访问
- 命名空间
- 自动加载
- 入口文件
- 框架核心
- Application
- 配置
- 对象
- 组件
- 门面
- 系统服务
- 中间件
- 验证器
- 验证器定义
- 验证规则
- 静态调用
- 模型
- 日志
- 命令行
- 简介
- 命令行开发常识
- 创建命令
- 执行与选项
- 控制台程序
- 守护程序
- HTTP 服务
- 简介
- 服务器
- 路由
- 请求
- 响应
- 控制器
- 视图
- Token
- Session
- Cookie
- 文件上传
- 图片处理
- 分页
- 验证码
- WebSocket 服务
- 简介
- 回调函数
- 消息处理器
- 客户端测试
- nginx代理
- 60s无消息断线
- 多进程
- ProcessPoolTaskExecutor
- 流水线模式
- 推送模式
- 在 Supervisor 中使用
- 协程
- 简介
- 如何开启协程
- HTTP 协程开发
- 命令行协程开发
- 客户端
- MySQL
- PDO
- PDOPersistent
- PDOMasterSlave
- PDOCoroutine
- Redis
- Redis
- RedisPersistent
- RedisCoroutine
- 外部工具库
- 简介
- think-orm
- psr-log
- 安全建议
- 常见问题
- 启动多个 HTTP 服务器
- 连接多个数据库
- 如何设置跨域
- mix-httpd service stop 无效
- No such file or directory
- 错误级别配置不生效
- 推进计划
- 文档历史