ThinkPHP框架表单验证
对注册到test表的表单进行验证
在注册之前要对表单进行验证:
用户名非空验证,两次输入密码必须一致即相等验证,年龄在18~50之间即范围验证,邮箱格式正则验证。
自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证。
数据验证可以进行数据类型、业务规则、安全判断等方面的验证操作。
数据验证有两种方式:
- 静态方式:在模型类里面通过$_validate属性定义验证规则。
- 动态方式:使用模型类的validate方法动态创建自动验证规则。
无论是什么方式,验证规则的定义是统一的规则,定义格式为:
array(
array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]),
array(验证字段2,验证规则,错误提示,[验证条件,附加规则,验证时间]),
......
);
验证字段 (必须)
需要验证的表单字段名称,这个字段不一定是数据库字段,也可以是表单的一些辅助字段,例如确认密码和验证码等等。有个别验证规则和字段无关的情况下,验证字段是可以随意设置的,例如expire有效期规则是和表单字段无关的。如果定义了字段映射的话,这里的验证字段名称应该是实际的数据表字段而不是表单字段。
验证规则 (必须)
要进行验证的规则,需要结合附加规则,如果在使用正则验证的附加规则情况下,系统还内置了一些常用正则验证的规则,可以直接作为验证规则使用,包括:require 字段必须、email 邮箱、url URL地址、currency 货币、number 数字。
提示信息 (必须)
用于验证失败后的提示信息定义
验证条件 (可选)
包含下面几种情况:
- self::EXISTS_VALIDATE 或者0 存在字段就验证(默认)
- self::MUST_VALIDATE 或者1 必须验证
- self::VALUE_VALIDATE或者2 值不为空的时候验证
附加规则 (可选)
配合验证规则使用,包括下面一些规则:
规则 | 说明 |
---|---|
regex | 正则验证,定义的验证规则是一个正则表达式(默认) |
function | 函数验证,定义的验证规则是一个函数名 |
callback | 方法验证,定义的验证规则是当前模型类的一个方法 |
confirm | 验证表单中的两个字段是否相同,定义的验证规则是一个字段名 |
equal | 验证是否等于某个值,该值由前面的验证规则定义 |
notequal | 验证是否不等于某个值,该值由前面的验证规则定义(3.1.2版本新增) |
in | 验证是否在某个范围内,定义的验证规则可以是一个数组或者逗号分割的字符串 |
notin | 验证是否不在某个范围内,定义的验证规则可以是一个数组或者逗号分割的字符串(3.1.2版本新增) |
length | 验证长度,定义的验证规则可以是一个数字(表示固定长度)或者数字范围(例如3,12 表示长度从3到12的范围) |
between | 验证范围,定义的验证规则表示范围,可以使用字符串或者数组,例如1,31或者array(1,31) |
notbetween | 验证不在某个范围,定义的验证规则表示范围,可以使用字符串或者数组(3.1.2版本新增) |
expire | 验证是否在有效期,定义的验证规则表示时间范围,可以到时间,例如可以使用 2012-1-15,2013-1-15 表示当前提交有效期在2012-1-15到2013-1-15之间,也可以使用时间戳定义 |
ip_allow | 验证IP是否允许,定义的验证规则表示允许的IP地址列表,用逗号分隔,例如201.12.2.5,201.12.2.6 |
ip_deny | 验证IP是否禁止,定义的验证规则表示禁止的ip地址列表,用逗号分隔,例如201.12.2.5,201.12.2.6 |
unique | 验证是否唯一,系统会根据字段目前的值查询数据库来判断是否存在相同的值,当表单数据中包含主键字段时unique不可用于判断主键字段本身 |
验证时间(可选)
- self::MODEL_INSERT或者1新增数据时候验证
- self::MODEL_UPDATE或者2编辑数据时候验证
- self::MODEL_BOTH或者3全部情况下验证(默认)
这里的验证时间需要注意,并非只有这三种情况,你可以根据业务需要增加其他的验证时间。
验证有两种方式:静态验证与动态验证。
一、静态验证
在模型类里面预先定义好该模型的自动验证规则,我们称为静态定义。
验证时要在test表的Model里面加验证条件:新建testModel.class.php,在模型类里面定义了$_validate
属性如下:
- <?php
- namespace Home\Model;
- use Think\Model;
- class testModel extends Model
- {
- //静态验证
- protected $_validate = array(
- array('uid','require','用户名不能为空'),
- array('pwd','require','密码不能为空'),
- array('repwd','pwd','确认密码不正确',1,'confirm'),
- array('age','18,50','年龄必须在18-50岁之间',1,'between'),
- array('email','email','邮箱格式不正确'),
- );
- }
定义好验证规则后,就可以在使用create方法创建数据对象的时候自动调用:
- <?php
- namespace Home\Controller;
- use Home\Controller\CheckController;
- class ZhuCeController extends CheckController
- {
- function ZhuCe()
- {
- //静态验证,不能在后面直接显示,必须全部通过验证才能注册
- $cw = "";
- if(!empty($_GET))
- {
- $cw = $_GET["cw"];
- }
- if(empty($_POST))
- {
- $this->assign("error",$cw);
- $this->display();
- }
- else
- {
- $model = new \Home\Model\testModel();
- //$model = D("test"); //动态验证可以用D方法
- if(!$model->create())
- {
- $e = $model->getError();
- $url = "ZhuCe/cw/{$e}";
- $this->error("注册失败!",$url,1);
- }
- else
- {
- $model->add();
- }
模板ZhuCe.html:
- <body>
- <form action="__ACTION__" method="post">
- <div>用户名:<input type="text" name="uid" id="uid" /> </div><br />
- <div>密码:<input type="text" name="pwd" id="pwd" /></div><br />
- <div>确认密码:<input type="text" name="repwd" id="repwd" /> </div><br />
- <div>年龄:<input type="text" name="age" id="age" /> </div><br />
- <div>邮箱:<input type="text" name="email" id="email" /> </div><br />
- <div>姓名:<input type="text" name="name" /></div><br />
- <div><{$error}></div> <!--显示错误信息-->
- <input type="submit" value="注册" />
- </form>
请求ZhuCe方法:
二、动态验证
如果采用动态验证的方式,就比较灵活,可以根据不同的需要,在操作同一个模型的时候使用不同的验证规则,例如上面的静态验证方式可以改为:
- <?php
- namespace Home\Controller;
- use Home\Controller\CheckController;
- class ZhuCeController extends CheckController
- {
- function ZhuCe()
- {
- if(empty($_POST))
- {
- $this->display();
- }
- else
- {
- //$model = new \Home\Model\testModel();
- $model = D("test"); //动态验证可以用D方法
- //动态验证
- $rules = array(
- array('uid','require','用户名不能为空')
- );
- //调用validate()加入验证规则
- $r = $model->validate($rules)->create();//若验证失败返回false,成功返回注册的test表数组信息
- //var_dump($r);
- if(!$r)
- {
- echo $model->getError(); //若验证失败则输出错误信息
- }
- else
- {
- $model->add();
- }
- }
- }
我们还可以在表单后面直接显示错误提示,这就要用到ajax。以验证用户名非空为例:
在模板ZhuCe.html中:
- <script src="../../../../../jquery-1.11.2.min.js"></script>
- </head>
- <body>
- <form action="__ACTION__" method="post">
- <div>用户名: <input type="text" name="uid" id="uid" /> <span id="ts"></span></div><br />
- <div>密码: <input type="text" name="pwd" id="pwd" /> <span id="pts"></span></div><br />
- <div>确认密码:<input type="text" name="repwd" id="repwd" /> <span id="rpts"></span></div><br />
- <div>年龄: <input type="text" name="age" id="age" /> <span id="nts"></span></div><br />
- <div>邮箱: <input type="text" name="email" id="email" /> <span id="ets"></span></div><br />
- <div>姓名: <input type="text" name="name" /></div><br />
- <!--<div><{$error}></div> --> <!--显示错误信息-->
- <input type="submit" value="注册" />
- </form>
- </body>
- </html>
- <script type="text/javascript">
- $(document).ready(function(e) {
- $("#uid").blur(function(){
- var uid = $(this).val();
- $.ajax({
- url:"__CONTROLLER__/Yhm", <!--提交到方法,而不是页面-->
- data:{uid:uid}, <!--因为做的是表单验证,所以提交时要与表单name值一致,相当于提交表单 -->
- type:"POST",
- dataType:"TEXT", <!--返回数据类型要与ajaxReturn中的参数对应,TEXT对应eval-->
- success: function(data){
- //alert(data);
- var str = "";
- if(data.trim()=="OK")
- {
- str = "<span style='color:green'>"+data+"</span>";
- }
- else
- {
- str = "<span style='color:red'>"+data+"</span>";
- }
- $("#ts").html(str);
- }
- });
- })
在ZhuCe控制器中再做一个Yhm方法:
- //验证用户名非空
- function Yhm()
- {
- $model = D("test");
- $rules = array(
- array('uid','require','用户名不能为空')
- );
- if(!$model->validate($rules)->create())
- {
- $fh = $model->getError();
- $this->ajaxReturn($fh,'eval'); //ajax返回数据,默认返回json格式,eval返回字符串,因为dataType是TEXT,所以用eval格式
- }
- else
- {
- $fh = "OK";
- $this->ajaxReturn($fh,'eval');
- }
- }
请求ZhuCe方法:
其他验证也是类似的方法,提交相应数据到对应方法,使用相应的验证规则。
ThinkPHP框架表单验证的更多相关文章
- ThinkPHP框架表单验证AJAX
验证有两种方式:静态验证与动态验证. 一.静态验证 在模型类里面预先定义好该模型的自动验证规则,我们称为静态定义. 验证时要在test表的Model里面加验证条件:新建testModel.class. ...
- tp框架表单验证
之前的表单验证都是用js写的,这里也可以使用tp框架的验证.但是两者比较而言还是js验证比较好,因为tp框架验证会运行后台代码,这样运行速度和效率就会下降. 自动验证是ThinkPHP模型层提供的一种 ...
- tp框架表单验证 及ajax
之前的表单验证都是用js写的,这里也可以使用tp框架的验证.但是两者比较而言还是js验证比较好,因为tp框架验证会运行后台代码,这样运行速度和效率就会下降. 自动验证是ThinkPHP模型层提供的一种 ...
- php--yii框架表单验证
在视图层利用表单小部件生成表单时,field只能是数据库中存在的, 例如: use yii\helpers\Html; use yii\widgets\ActiveForm; use yii\capt ...
- thinkphp 隐藏表单验证原理
function savetoken() //创建session('hash') ,然后在魔板中表单中加入隐藏域 getsession('hash'),提交表单验证值是否一样,如果一样验证通过,同时重 ...
- Yii 框架表单验证---实例
- laravel框架——表单验证
创建路由 Route::get('test','VerController@index'); Route::post('tosubmit','VerController@tosubmit'); 在控制 ...
- Thinkphp框架 表单自动验证登录注册 ajax自动验证登录注册
说明:这里没练习静态自动验证:如果用到静态验证首先自定义一个控制器,再在Model文件夹里创建一个NiHaoModel.php 类 NiHao是自定义的,前缀可以随意,但是一定要用驼峰法(首字母大写 ...
- ThinkPHP框架 表单传值自动验证!!
如果有多个字段都包含错误,默认只显示一个错误.如果想显示全部错误,可以设置属 性: //批量验证 d protected $patchValidate = true; 如果是直接 POST 过来的,直 ...
随机推荐
- Build to win!——获得小黄衫的感想
UPDATE: 应栋哥要求,上传了无遮挡的正面照(我的内心其实是拒绝的!(ㄒoㄒ)) 一.前言&背景 从大一上C++课程开始,栋哥就开始安利他大三的软工实践课. 时间过得飞快,大学转眼就过去一 ...
- C#网络编程基础知识
C#网络编程基础知识一 1.IPAddress类 用于表示一个IP地址.IPAddress默认构造函数 public IPAddress(long address);一般不用 其中Parse()方法最 ...
- primefaces p:dataExporter filename 支持中文 utf8
p:fileDownload and p:dataExporter : for p:fileDownload, the Content-Disposition header should be set ...
- 关于vs生成app错误提示,提醒Execution failed for task ':transformClassesWithDexForDebug'.
昨天将vs和android SDK更新之后生成app之后发现app生成出错,报错如下: FAILURE: Build failed with an exception. * What went wro ...
- base64 convert to file
var fs= require('fs') var imageFile = dataUrl.replace(/^data:image\/\w+;base64,/, ""); var ...
- ubuntu下增加中文编码
在Ubuntu中,利用命令:locale,来查看系统的语言环境 参考:http://blog.chinaunix.net/uid-94449-id-2002589.html Windows的默认编码为 ...
- Java类集
类集就是一个动态的对象数组,是对一些实现好的数据结构进行了包装,这样在使用时就会非常方便,最重要的是类集框架本身不受对象数组长度的限制. 类集框架的主要接口
- JSP 入门 HTML嵌套Java脚步 显示时间
<%@ page import="java.util.Date"%> <%@ page language="java" contentType ...
- ecshop分页
php代码 $page = $_GET['page']; //当前是第几页 $count = grab_promote_goods_count(); // 一个有多少条 $size= '; ){ $p ...
- xcode 不显示占用内存
解决办法: Scheme设置中,将 Enable Zombie Objects 勾选去掉.