在服务器端通过tp框架实现表单验证

用户名、密码、重复密码、邮箱、qq、手机号码、爱好、学历

具体步骤:

  1. 制作表单
  2. 表单form数据通过create()方法收集(验证功能要求我们必须通过create()方法收集数据)
  3. 自定义数据model模型类实现具体验证规则

自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证。

数据验证可以进行数据类型、业务规则、安全判断等方面的验证操作。

数据验证有两种方式:

  1. 静态方式:在模型类里面通过$_validate属性定义验证规则。
  2. 动态方式:使用模型类的validate方法动态创建自动验证规则。

无论是什么方式,验证规则的定义是统一的规则,定义格式为:

说明

验证字段 (必须)

需要验证的表单字段名称,这个字段不一定是数据库字段,也可以是表单的一些辅助字段,例如确认密码和验证码等等。有个别验证规则和字段无关的情况下,验证字段是可以随意设置的,例如expire有效期规则是和表单字段无关的。如果定义了字段映射的话,这里的验证字段名称应该是实际的数据表字段而不是表单字段。

验证规则 (必须)

要进行验证的规则,需要结合附加规则,如果在使用正则验证的附加规则情况下,系统还内置了一些常用正则验证的规则,可以直接作为验证规则使用,包括:require 字段必须、email 邮箱、url URL地址、currency 货币、number 数字。

提示信息 (必须)

用于验证失败后的提示信息定义

验证条件 (可选)

包含下面几种情况:

  • self::EXISTS_VALIDATE 或者0 存在字段就验证(默认)
  • self::MUST_VALIDATE 或者1 必须验证
  • self::VALUE_VALIDATE或者2 值不为空的时候验证
附加规则 (可选)

配合验证规则使用,包括下面一些规则:

验证时间(可选)
  • self::MODEL_INSERT或者1新增数据时候验证
  • self::MODEL_UPDATE或者2编辑数据时候验证
  • self::MODEL_BOTH或者3全部情况下验证(默认)

这里的验证时间需要注意,并非只有这三种情况,你可以根据业务需要增加其他的验证时间。

静态定义:

在模型类里面预先定义好该模型的自动验证规则,我们称为静态定义。

Home/Controller/ZhuCeController.class.php:

 <?php
namespace Home\Controller;
use Think\Controller;
class ZhuCeController extends Controller
{ function ZhuCe()
{
$cw="";
if(!empty($_GET))
{
$cw=$_GET["cw"];
}
if(empty($_POST))
{
$this->assign("error",$cw);
$this->display();
}
else
{
$model=new\Home\Model\TextModel();
//$model=D("Text");
if(!$model->create())//有返回值
{
$e=$model->getError();
$url="ZhuCe/cw/{$e}";
$this->error("注册失败!",$url,1);
}
else
{
$model->add(); } } }
}

Model/TextModel.class.php:

 <?php
namespace Home\Model;
use Think\Model;
class TextModel extends Model
{
protected $_validate=array(
array('uid','require','用户名不能为空!'),
array('pwd','require','密码不能为空!'),
array('pwd','pwd1','两次输入的密码不一致!',1,'confirm'),
array('age','18,50','年龄必须在18-50岁之间!',1,'between'),
array('email','email','邮箱格式不正确!'),
array('email','','邮箱已被注册!',1,'unique'),//unique可以验证非主键字段
);
}

View/Zhuce/ZhuCe.html:

 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>表单验证</title>
</head> <body>
<form action="__ACTION__" method="post">
<div>用户名:<input type="text" name="uid" /></div><br />
<div>密&nbsp;&nbsp;&nbsp;&nbsp;码:<input type="text" name="pwd" /></div>
<div>确认密码:<input type="text" name="pwd1" /></div><br />
<div>年龄:<input type="text" name="age" /></div><br />
<div>邮箱:<input type="text" name="email" /></div><br />
<div>姓名:<input type="text" name="name" /></div><br />
<!--显示错误信息 -->
<div style=" width:200px; height:30px; border:#F00 solid 2px; line-height:30px; vertical-align:middle; text-align:center;"><{$error}></div><br />
<div><input type="submit" value="注册" /></div>
</form>
</body>
</html>

运行结果:

结果1:

==>     

结果2:

           ==>      

 

在进行自动验证的时候,系统会对定义好的验证规则进行依次验证。如果某一条验证规则没有通过,则会报错,getError方法返回的错误信息(字符串)就是对应字段的验证规则里面的错误提示信息。

动态验证:

如果采用动态验证的方式,就比较灵活,可以根据不同的需要,在操作同一个模型的时候使用不同的验证规则

Home/Controller/ZhuCeController.class.php:

 <?php
namespace Home\Controller;
use Think\Controller;
class ZhuCeController extends Controller
{ function ZhuCe()
{
$cw="";
if(!empty($_GET))
{
$cw=$_GET["cw"];
}
if(empty($_POST))
{
$this->assign("error",$cw);
$this->display();
}
else
{
//动态验证:
$model=new \Home\Model\TestModel();
$rules=array(
array('uid','require','用户名不能为空!'),
array('pwd','require','密码不能为空!'),
array('pwd','pwd1','两次输入的密码不一致!',1,'confirm'),
array('age','18,50','年龄必须在18-50岁之间!',1,'between'),
array('email','email','邮箱格式不正确!'),
array('email','','邮箱已被注册!',1,'unique'),//unique可以验证非主键字段
); if(!$model->validate($rules)->create())
{
echo $model->getError();
}
else
{
$model->add(); }
} }
}

Model/TextModel.class.php:(空模型)

 <?php
namespace Home\Model;
use Think\Model;
class TextModel extends Model
{ }

View/Zhuce/ZhuCe.html:(同静态验证)

 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>表单验证</title>
</head> <body>
<form action="__ACTION__" method="post">
<div>用户名:<input type="text" name="uid" /></div><br />
<div>密&nbsp;&nbsp;&nbsp;&nbsp;码:<input type="text" name="pwd" /></div>
<div>确认密码:<input type="text" name="pwd1" /></div><br />
<div>年龄:<input type="text" name="age" /></div><br />
<div>邮箱:<input type="text" name="email" /></div><br />
<div>姓名:<input type="text" name="name" /></div><br />
<!--显示错误信息 -->
<div style=" width:200px; height:30px; border:#F00 solid 2px; line-height:30px; vertical-align:middle; text-align:center;"><{$error}></div><br />
<div><input type="submit" value="注册" /></div>
</form>
</body>
</html>

Thinkphp 表单验证的更多相关文章

  1. thinkphp表单验证

    之前的表单验证都是用js写的,这里也可以使用tp框架的验证.但是两者比较而言还是js验证比较好,因为tp框架验证会运行后台代码,这样运行速度和效率就会下降. 自动验证是ThinkPHP模型层提供的一种 ...

  2. TP框架---thinkphp表单验证

    自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证.验证的代码要写在模型层即Model里面. 数据验证有两种方式: 静态方式:在模型类里面 ...

  3. ThinkPHP框架下的表单验证

    之前的表单验证都是用js写的,这里也可以使用tp框架的验证.但是两者比较而言还是js验证比较好,因为tp框架验证会运行后台代码,这样运行速度和效率就会下降. 自动验证是ThinkPHP模型层提供的一种 ...

  4. thinkphp表单自动验证

    ThinkPHP框架表单验证 对注册到test表的表单进行验证 在注册之前要对表单进行验证: 用户名非空验证,两次输入密码必须一致即相等验证,年龄在18~50之间即范围验证,邮箱格式正则验证. 自动验 ...

  5. ThinkPHP框架表单验证

    对注册到test表的表单进行验证 在注册之前要对表单进行验证: 用户名非空验证,两次输入密码必须一致即相等验证,年龄在18~50之间即范围验证,邮箱格式正则验证. 自动验证是ThinkPHP模型层提供 ...

  6. ThinkPHP表单令牌验证功能详细介绍

    注:TP版本为3.1.3 在ThinkPHP框架下,两次提交同一个表单,比如提交信息后在浏览器点击后退退回上次的页面,重新点击提交按钮,就会提示“表单令牌错误”的信息. ThinkPHP新版内置了表单 ...

  7. ThinkPhp框架:父类及表单验证

    这个知识点,就可以通过"登录"和"注册"的页面来学习这个知识点了首先先做一个"登录"功能一.登录功能(父类)(1)登录的控制器在我的控制器文 ...

  8. thinkphp图片上传+validate表单验证+图片木马检测+缩略图生成

    目录 1.案例 1.1图片上传  1.2进行图片木马检测   1.3缩略图生成   1.4控制器中调用缩略图生成方法 1.案例 前言:在thinkphp框架的Thinkphp/Library/Thin ...

  9. thinkphp 隐藏表单验证原理

    function savetoken() //创建session('hash') ,然后在魔板中表单中加入隐藏域 getsession('hash'),提交表单验证值是否一样,如果一样验证通过,同时重 ...

随机推荐

  1. 动态规划——C编辑最短距离

    C - 编辑距离 时间限制: 1000女士 内存限制: 65536KB 64位输入输出格式: %I64d & %I64u 提交 状态 描述 Let x and y be two strings ...

  2. CentOS6.5 mini开启网络

    1.编辑network配置 vim /etc/sysconfig/network-scripts/ifcfg-eth0 1 2 3 4 5 6 7 DEVICE=eth0 HWADDR=00:0C:2 ...

  3. cat-mvc 一个nodejs mvc 框架

    不多说,自己看,哈哈哈 https://www.npmjs.com/package/cat-mvc

  4. HDU 4287 Intelligent IME

    Intelligent IME Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  5. 合肥三洋股份,惠而浦家电携四大品牌-Take ,所有的市场

        大家都知道,数家电企业的日子并不好过.一方面,产品同质化竞争越发激烈.家电市场已进入了恶性价格战时代.还有一方面,消费者对家电产品的需求越发多元化.个性化.这意味着无法满足消费者需求的产品非常 ...

  6. “too many open files" ----增大打开的文件数

     http://www.cnblogs.com/ibook360/archive/2012/05/11/2495405.html [root@localhost ~]# ab -n -c http:/ ...

  7. [转] linux新的API signalfd、timerfd、eventfd使用说明

    http://blog.csdn.net/gdutliuyun827/article/details/8460417 三种新的fd加入linux内核的的版本: signalfd:2.6.22 time ...

  8. iOS 开发-单元测试

    前言 维基百科对单元测试的定义如下: 在计算机编程中,单元测试(英语:Unit Testing)又称为模块测试, 是针对程序模块(软件设计的最小单位)来进行正确性检验的测试工作.程序单元是应用的最小可 ...

  9. linux 之 yum 介绍 <转>

    原文在这里  http://doophp.sinaapp.com/archives/linux/yum-setting-parameter.html 因为是程序员出身,平时虽然经常接触服务器,偶尔也会 ...

  10. python-Pickle序列化

    [Python之旅]第三篇(二):Pickle序列化   python 序列化 pickle 摘要: 说明:关于Pickle的说明     作如下说明: 1 2 3 4 5 6 7 序列化的概念很简单 ...