PEAR::HTML_QuickForm入门[4]--表单数据验证

原创 2004年09月04日 23:01:00

我们再次对这段代码进行改进,为其加入表单数据验证功能

使用户在登录时必须输入用户名和密码,并且用户名长度不能小于三位。

 

Form3.php

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> PEAR::HTML_QuickForm </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="Haohappy">
</HEAD>

<BODY>
<?
require_once("HTML/QuickForm.php");
$form = new HTML_QuickForm('frmTest', 'post');
$form->addElement('header', 'header', '请登录');
$form->addElement('text', 'name', '用户名:');
$form->addElement('password', 'password', '密码:');
$form->addElement('submit', '', '提交');

//加入三条验证规则
$form->addRule('name','用户名不能为空!', 'required');
$form->addRule('name','用户名必须为3位以上字母或数字', 'minlength',3);
$form->addRule('password','密码不能为空!', 'required');

if (
$form->validate()) {
    
$form->process('say_hello');
} else {
    
$form->display();
}

function
say_hello($data) {
    print
'Hello, ' . $data['name'];
    print
'<BR>';
    print
'Your password is '.$data['password'];
}

?>
    
</BODY>
</HTML>

 

输出效果如图:

 

 

 

 

可以看到我们仅用了以下三行简单的代码来实现数据验证功能,和我们平时所采取的方法相比方便得多。

//加入三条验证规则
$form->addRule('name','用户名不能为空!', 'required');
$form->addRule('name','用户名必须为3位以上字母或数字', 'minlength',3);
$form->addRule('password','密码不能为空!', 'required');

 

addRule()方法的四个参数分别表示规则应用的对象、提醒文字、验证规则的类型(required表示必须输入,不能为空)、验证规则的参数。

 

PEAR::HTML_QuickForm自带的验证规则如下:

规则名称

参数

规则描述

required

 

必须输入,不能为空

maxlength

$length

最大字符长度

minlength

$length

最小字符长度

rangelength

$min,$max

字符长度的范围

regex

$rx

输入的数据必须匹配给定的正则表达式

email

true
(forDNS heck)

验证email地址的格式(有个可选的选项还可以查看域名是否有效)

lettersonly

 

只能是英文字母

alphanumeric

 

只能是英文字母或数字

numeric

 

只能是数字

nopunctuation

 

不能包含以下特殊字符: ( ) . / * ^ ? # ! @ $ % + = , " ' > < ~ [ ] { }.

nonzero

 

不能为零

compare

 

两次输入必须相同

uploadedfile

 

表单元素必须包含正确上传文件

maxfilesize

$size

上传文件的最大容量

mimetype

$mime

上传文件的类型,$mime可以是数组,则上传文件的类型必须为其中一种

filename

$file_rx

上传的文件的名称必须满足给定的正则表达式

 

 

 

 

其中compare规则有点特殊,它是指两个表单的输入数据必须相同(如密码确认时)。它的用法如下:

$form->addElement('password','password_1','Enter your password:');
$form->addElement('password','password_2','Enter your password (again):');
$form->addRule(array('password_1','password_2'),
               
"Passwords don't match!",'compare');

 

compare也可以用来比较两个表单中输入的数据的大小,如:

$form->addElement('text','min_age','Minimum Age:');
$form->addElement('text','max_age','Maximum Age:');
$form->addRule(array('min_age','max_age'),
               
"Minimum Age must be less than Maximum Age",
               
'compare','<');

 

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

Validform使用入门(form表单验证)

1、引入css 请查看下载文件中的style.css,把里面Validform必须部分复制到你的css中(文件里这个注释 "/*==========以下部分是Validform必须的========...
  • zhangxiaomaphp
  • zhangxiaomaphp
  • 2015年08月06日 21:37
  • 2586

django表单处理(二)--数据验证

上一篇讲到最简单的表单处理,就将输入的字符串输出了。 这么简单的表单处理可不行,接下来我们以一个用户注册的例子说明怎么验证数据。 验证数据要用到django.forms模块。 首先我们在temp...
  • whoami021
  • whoami021
  • 2014年03月10日 00:28
  • 2092

yii2的表单验证与数据库操作

表单验证的每个具体参数:       可以查阅 网址:http://www.yiiframework.com/doc-2.0/yii-validators-validator.html        ...
  • panjican
  • panjican
  • 2016年02月29日 21:48
  • 1696

html对应的文件中 将form 表单数据 转化为json 格式

  • 2017年06月10日 10:28
  • 784B
  • 下载

SpringMVC4+thymeleaf3的一个简单实例(篇四:form表单数据验证)

springMVC和thymeleaf整合后的页面数据验证。
  • asd_op
  • asd_op
  • 2016年11月19日 16:58
  • 9033

常用表单数据验证JS

  • 2009年02月11日 21:18
  • 2KB
  • 下载

BootStrap验证表单数据

  • 2015年04月16日 18:55
  • 243KB
  • 下载

OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据

OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据 我们这片博文就来聊聊这个反响很不错的OkHttp了,标题是我恶搞的,本篇将着重...
  • xiaoqiang_0719
  • xiaoqiang_0719
  • 2016年08月26日 09:48
  • 507

Asp.Net MVC2 实用入门系列:第四篇:传递表单数据

摘要       本文将完成我们“MVC公告发布系统”的公告发布功能,以此展示在ASP.NET MVC中如何传递处理表单的数据。 前言       通过前几篇文章,我们已经能比较自如的使用A...
  • moon66sun
  • moon66sun
  • 2012年10月08日 16:38
  • 507

php表单,HTML表单提交后,返回,保留表单数据

php表单在提交之后再后退,表单的内容默认是被清空的(使用session_start的时候),  解决方法是在session_start() 之后,字符输出之前写上  复制代码代码如下: ...
  • forest_fire
  • forest_fire
  • 2017年06月14日 17:51
  • 159
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PEAR::HTML_QuickForm入门[4]--表单数据验证
举报原因:
原因补充:

(最多只允许输入30个字)