在服务器端经过tp框架实现表单验证php
用户名、密码、重复密码、邮箱、qq、手机号码、爱好、学历html
具体步骤:数据库
自动验证是ThinkPHP模型层提供的一种数据验证方法,能够在使用create建立数据对象的时候自动进行数据验证。安全
数据验证能够进行数据类型、业务规则、安全判断等方面的验证操做。服务器
数据验证有两种方式:框架
不管是什么方式,验证规则的定义是统一的规则,定义格式为:ide
说明post
须要验证的表单字段名称,这个字段不必定是数据库字段,也能够是表单的一些辅助字段,例如确认密码和验证码等等。有个别验证规则和字段无关的状况下,验证字段是能够随意设置的,例如expire有效期规则是和表单字段无关的。若是定义了字段映射的话,这里的验证字段名称应该是实际的数据表字段而不是表单字段。ui
要进行验证的规则,须要结合附加规则,若是在使用正则验证的附加规则状况下,系统还内置了一些经常使用正则验证的规则,能够直接做为验证规则使用,包括:require 字段必须、email 邮箱、url URL地址、currency 货币、number 数字。this
用于验证失败后的提示信息定义
包含下面几种状况:
配合验证规则使用,包括下面一些规则:
这里的验证时间须要注意,并不是只有这三种状况,你能够根据业务须要增长其余的验证时间。
在模型类里面预先定义好该模型的自动验证规则,咱们称为静态定义。
1 <?php 2 namespace Home\Controller; 3 use Think\Controller; 4 class ZhuCeController extends Controller 5 { 6 7 function ZhuCe() 8 { 9 $cw=""; 10 if(!empty($_GET)) 11 { 12 $cw=$_GET["cw"]; 13 } 14 if(empty($_POST)) 15 { 16 $this->assign("error",$cw); 17 $this->display(); 18 } 19 else 20 { 21 $model=new\Home\Model\TextModel(); 22 //$model=D("Text"); 23 if(!$model->create())//有返回值 24 { 25 $e=$model->getError(); 26 $url="ZhuCe/cw/{$e}"; 27 $this->error("注册失败!",$url,1); 28 } 29 else 30 { 31 $model->add(); 32 33 } 34 35 } 36 37 } 38 }
1 <?php 2 namespace Home\Model; 3 use Think\Model; 4 class TextModel extends Model 5 { 6 protected $_validate=array( 7 array('uid','require','用户名不能为空!'), 8 array('pwd','require','密码不能为空!'), 9 array('pwd','pwd1','两次输入的密码不一致!',1,'confirm'), 10 array('age','18,50','年龄必须在18-50岁之间!',1,'between'), 11 array('email','email','邮箱格式不正确!'), 12 array('email','','邮箱已被注册!',1,'unique'),//unique能够验证非主键字段 13 ); 14 }
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://www.w3.org/1999/xhtml"> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 5 <title>表单验证</title> 6 </head> 7 8 <body> 9 <form action="__ACTION__" method="post"> 10 <div>用户名:<input type="text" name="uid" /></div><br /> 11 <div>密 码:<input type="text" name="pwd" /></div> 12 <div>确认密码:<input type="text" name="pwd1" /></div><br /> 13 <div>年龄:<input type="text" name="age" /></div><br /> 14 <div>邮箱:<input type="text" name="email" /></div><br /> 15 <div>姓名:<input type="text" name="name" /></div><br /> 16 <!--显示错误信息 --> 17 <div style=" width:200px; height:30px; border:#F00 solid 2px; line-height:30px; vertical-align:middle; text-align:center;"><{$error}></div><br /> 18 <div><input type="submit" value="注册" /></div> 19 </form> 20 </body> 21 </html>
==>
==>
在进行自动验证的时候,系统会对定义好的验证规则进行依次验证。若是某一条验证规则没有经过,则会报错,getError方法返回的错误信息(字符串)就是对应字段的验证规则里面的错误提示信息。
若是采用动态验证的方式,就比较灵活,能够根据不一样的须要,在操做同一个模型的时候使用不一样的验证规则
1 <?php 2 namespace Home\Controller; 3 use Think\Controller; 4 class ZhuCeController extends Controller 5 { 6 7 function ZhuCe() 8 { 9 $cw=""; 10 if(!empty($_GET)) 11 { 12 $cw=$_GET["cw"]; 13 } 14 if(empty($_POST)) 15 { 16 $this->assign("error",$cw); 17 $this->display(); 18 } 19 else 20 { 21 //动态验证: 22 $model=new \Home\Model\TestModel(); 23 $rules=array( 24 array('uid','require','用户名不能为空!'), 25 array('pwd','require','密码不能为空!'), 26 array('pwd','pwd1','两次输入的密码不一致!',1,'confirm'), 27 array('age','18,50','年龄必须在18-50岁之间!',1,'between'), 28 array('email','email','邮箱格式不正确!'), 29 array('email','','邮箱已被注册!',1,'unique'),//unique能够验证非主键字段 30 ); 31 32 if(!$model->validate($rules)->create()) 33 { 34 echo $model->getError(); 35 } 36 else 37 { 38 $model->add(); 39 40 } 41 } 42 43 } 44 }
1 <?php 2 namespace Home\Model; 3 use Think\Model; 4 class TextModel extends Model 5 { 6 7 }
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://www.w3.org/1999/xhtml"> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 5 <title>表单验证</title> 6 </head> 7 8 <body> 9 <form action="__ACTION__" method="post"> 10 <div>用户名:<input type="text" name="uid" /></div><br /> 11 <div>密 码:<input type="text" name="pwd" /></div> 12 <div>确认密码:<input type="text" name="pwd1" /></div><br /> 13 <div>年龄:<input type="text" name="age" /></div><br /> 14 <div>邮箱:<input type="text" name="email" /></div><br /> 15 <div>姓名:<input type="text" name="name" /></div><br /> 16 <!--显示错误信息 --> 17 <div style=" width:200px; height:30px; border:#F00 solid 2px; line-height:30px; vertical-align:middle; text-align:center;"><{$error}></div><br /> 18 <div><input type="submit" value="注册" /></div> 19 </form> 20 </body> 21 </html>