摘要:作为前端程序员,对于验证这块有着切身的体会,虽然逐渐得心应手,但始终没有一个内置的功能拿来就能用。thinkPHP5恰好提供了validate用来校验前端数据的合法性。
作为前端程序员,对于验证这块有着切身的体会,虽然逐渐得心应手,但始终没有一个内置的功能拿来就能用。thinkPHP5恰好提供了validate用来校验前端数据的合法性。
下面就通过代码来实现。
在Index模块化下index控制器同级目录创建一个validate文件,里面一个Vdate.php验证文件,这个文件也可以放在common目录下面,只要namespace正确就可。代码如下:
<?php namespace app\index\validate; use think\Validate; class Vdate extends Validate{ //每个字段对应一个规则,这是第一层 protected $rule=[ ["name","require|max:10","不能为空|分类名不能超过10个字符"], ["parent_id","number","必须为数字"], /* ["id","number","必须是数字"], ["status","number|in:1,0,-1","必须是数字|必须是是0,-1,1"],*/ ]; //应用的场景,这是第二层 protected $scene=[ "save"=>["name","parent_id"], ]; }
可以写多个字段,一个字段一个数组,里面包含了校验规则
["status","number|in:1,0,-1","必须是数字|必须是是0,-1,1"]
然后前端页面代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>验证数据</title> </head> <body> <form action="{:url('index/validateF')}" method="GET"> <input type="text" name="name"> <input type="submit" value="提交"> </form> </body> </html>
后端控制器index下面对应的validateF:
public function validateF() { $data=input("get."); print_r($data); $validate=validate("Vdate"); //使用验证 //scene("save")->check($data)内置方法 if(!$validate->scene("save")->check($data)){ $this->error($validate->getError());//内置错误返回 } //剩下操作 $res=model("category")->add($data); if($res){ $this->success('新增成功'); }else{ $this->error("新增失败!"); } }
这样就可以了。关于每个字段的规则,在官方手册中提供了validate很多校验规则,当然如果觉得官方给的不够用或者不符合自己的需求,也可以自定义校验规则。
validate校验前端数据的效果: