Laravel5.1之表单验证
一.生成一个验证类
1.生成
artisan make:request TestRequest
2.生成的文件在项目Http下的Requests文件夹下
3.默认生成的文件如下
class TestRequest extends Request
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return false;
} /**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return [
//
];
}
}
二.添加自定义验证逻辑
*在代码中将说明
<?php namespace Test\Http\Requests; use Illuminate\Support\Facades\Response; class TestRequest extends Request
{
//验证规则,exists下面将会有说明
protected $rules = [
'mid' => ['required', 'integer', 'exists:articles, id, is_active, 1, is_end, 1'],
'page' => ['required', 'integer'],
'content' => ['required','min:5']
]; //验证错误信息指定,否则默认是英文
protected $messages = [
'mid.required' => '参数错误',
'mid.integer' => '参数错误',
'mid.exists' => '数据不存在,或未审核通过!',
'page.required' => '参数错误',
'page.integer' => '参数错误',
'content.required' => '内容必须填写',
'content.min' => '内容不能少于:min个字',
]; /**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
} /**
*验证权限失败时的相应
*/
public function forbiddenResponse()
{
if ($this->ajax()) {
return response()->json(['data' => null, 'info' => '没有权限', 'status' => 0]);
} else {
return abort(403);
}
} /**
* 验证参数失败时的响应,如果验证指定的规则未通过,response将被调用,因为errors是个数组,保存所有的验证出错信息,这儿我们取出第一条显示,比较符合我们的使用习惯
* @param array $errors
* @return \Illuminate\Http\JsonResponse
*/
public function response(array $errors)
{
if ($this->ajax()) {
$firstErrors = array_shift($errors);
$error = $firstErrors[0];
return response()->json(['data' => null, 'info' => $error, 'status' => 0]);
} else {
return abort(404);
}
} /**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return $this->rules;
} /**
* @return array
*/
public function messages()
{
return $this->messages;
}
}
验证规则的exits说明
基本:
exists:table,column
这将从数据库查询,来确定是否通过
exists:articles,id,is_active,1,is_end,1
最终形成的SQL语句将是
select count(*) as aggregate from `articles` where ` id` = mid的值 and `is_active` = 1 and `is_end` = 1
如果查到数据,验证将通过,否则验证失败;需要注意的是exists中的各个值之间不要加空格,否则会形成如` is_active`这样子,导致数据库列不存在;
控制器中只要依赖注入这个验证类就可以了;这将在请求到来后,自动验证;
如果你不用验证类,也可以在控制器中写验证规则;
三.自定义验证规则
如果现有的验证规则不能满足我们的需求,我们可以自定义一个规则.
1.新建文件夹Validate,建立一个文件TestValidate.php
use Illuminate\Validation\Validator; class TestValidator extends Validator
{
/**
* 注意该方法必须要以Validate开头,后面的是验证规则名称
* 验证评论是否发表过快
* @param $attribute
* @param $value
* @return bool
*/
public function ValidateQuick($attribute, $value)
{
$userId = Auth::id();
/**
* 验证blog评论
*/
if ($attribute === 'mid') {
$mid = $value;
$lastComment = app(PostRepository::class)->find($mid, $userId); if ($lastComment && $lastComment->time > time()-60*30) {
return false;
}
return true;
}
}
}
2.在AppServiceProvider的boot方法中注册该验证规则
public function boot()
{
/**
* 验证评论是否发布过快
*/
Validator::resolver(function($translator, $data, $rules, $messages) {
return new TestValidator($translator, $data, $rules, $messages);
});
}
3.使用
...........
'mid' => ['quick'],
..........
Laravel5.1之表单验证的更多相关文章
- laravel5.7 表单验证
laravel5.7 表单验证 一.创建表单请求 1.找到 larave5.7 文档 验证 中的创建表单请求,这里就要用到命令:php artisan make:request BrandReques ...
- laravel5表单验证
学习laravel框架有一段时间了,觉得它自带的表单验证特别好用,和大家分享分享 对于一些验证规则手册上都有,相信大家看了就会,我简单的说下怎么使用自定义正则验证: 验证手机号:'tel' => ...
- jQuery学习之路(8)- 表单验证插件-Validation
▓▓▓▓▓▓ 大致介绍 jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆绑了一套有用的验证方法,包括 ...
- 玩转spring boot——AOP与表单验证
AOP在大多数的情况下的应用场景是:日志和验证.至于AOP的理论知识我就不做赘述.而AOP的通知类型有好几种,今天的例子我只选一个有代表意义的“环绕通知”来演示. 一.AOP入门 修改“pom.xml ...
- form表单验证-Javascript
Form表单验证: js基础考试内容,form表单验证,正则表达式,blur事件,自动获取数组,以及css布局样式,动态清除等.完整代码如下: <!DOCTYPE html PUBLIC &qu ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(33)-MVC 表单验证
系列目录 注:本节阅读需要有MVC 自定义验证的基础,否则比较吃力 一直以来表单的验证都是不可或缺的,微软的东西还是做得比较人性化的,从webform到MVC,都做到了双向验证 单单的用js实现的前端 ...
- 实现跨浏览器html5表单验证
div:nth-of-type(odd){ float: left; clear: left; } .origin-effect > div:nth-of-type(even){ float: ...
- jQuery Validate 表单验证 — 用户注册简单应用
相信很多coder在表单验证这块都是自己写验证规则的,今天我们用jQuery Validate这款前端验证利器来写一个简单的应用. 可以先把我写的这个小demo运行试下,先睹为快.猛戳链接--> ...
- jquery validate表单验证插件-推荐
1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家. 1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素 3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...
随机推荐
- Html5学习进阶四 表单元素和表单属性
HTML5 的新的表单元素: HTML5 拥有若干涉及表单的元素和属性. 本章介绍以下新的表单元素: datalist keygen output 浏览器支持 Input type IE Firefo ...
- 行为型设计模式之解释器模式(Interpreter)
结构 意图 给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子. 适用性 当有一个语言需要解释执行, 并且你可将该语言中的句子表示为一个抽象语法树时,可使用 ...
- [ CodeVS冲杯之路 ] P3117
不充钱,你怎么AC? 题目:http://codevs.cn/problem/3117/ 啊啊啊,基础的高精度乘法被我写得又臭又长,以后再来优化代码(DP着哪天能够把加减乘除全部写一边贴上来,哦对还有 ...
- 关于 cgdb & gdbtui 的输入scanf()问题
使用cgdb 和 gdbtui 调试程序时, 遇到scanf函数时 it seems to enter into an infinite loop According to the info page ...
- VS2013的Release模式 和 debug 模式
在有的情况下,我们可能不能直接利用Debug模式进行程序调试,那么如何在Release模式下进行程序调试呢? 一.将项目属性设置为Release,生成--->配置管理器: 二.按Alt+F7,弹 ...
- Visual Studio Code 好用的 source code editor
short cut https://code.visualstudio.com/shortcuts/keyboard-shortcuts-linux.pdf go to definition : F1 ...
- 左侧菜单栏右侧内容(改进,有js效果)
(如有错敬请指点,以下是我工作中遇到并且解决的问题)上一篇文章是简洁版 这是上一篇文章的改进. 上一篇文章的左侧菜单是没有子目录的. 这是效果图: 左侧菜单代码: <div class=&quo ...
- AC日记——Vicious Keyboard codeforces 801a
801A - Vicious Keyboard 思路: 水题: 来,上代码: #include <cstdio> #include <cstring> #include < ...
- 本地添加maven支持
第一步:添加maven支持,去Apache maven官网下载maven, 解压 在conf文件夹里有个settings.xml,这个是需要自己配置的,不然的话也会有默认,只是那样的话会在C盘了,不喜 ...
- js百度地图-简单的1个坐标点
要学习百度地图,最好的地方就是去看百度地图API: 案例: <!DOCTYPE html> <html> <head> <meta http-equiv=&q ...