表单验证之PHP代码框架

   我在上一篇文章中讲到使用javascript做集成表单验证的方法,对于客户端验证已经足够,但好的表单验证应同时在客户端和服务器端进行——这正是写本文的目的。

    如果采用一般的验证方法应该怎样写呢?

    if ($_POST['some'] 不满足 condition) {

             die("wrong");

    }

    类似于javascript的集成验证方法,在PHP中也可利用数组和eval语句实现表单验证(服务器端)框架。一般步骤:

    1、将用户提交的数据从$_GET或$_POST数组收集到自定义数组(可选),

    2、填充验证数组(包括变量名、条件及提示等),

    3、添加固定的验证代码。

    下面我来举例说明,假设你要从网页中收集用户姓名及年龄,并且在服务器端实现数据验证,那么你可能需要form.html和act.php。form.html中包含表单:

    <form method=post action=act.php>

        姓名:<input type=text name='name'><br>

        年龄:<inupt type=text name='uage' ><br>

        <input type=submit value="提交">

    </form>

    act.php中将实现表单的验证:

    $userinfo = array();                 // 步骤1

    $userinfo['name'] = isset($_POST['uname']) ? $_POST['uname'] : '';

    $userinfo['age'] = isset($_POST['uage']) ? (int)$_POST['uage'] : 0;

    $error_message = "";           // 错误信息

    // 步骤2

    $elems = array(
        array("\$userinfo['name']", 'strlen(#)<1', '姓名不能为空!'),

        // 若省略步骤1则按如下方式改写:

        // array("\$_POST['uname']", 'strlen(#)<1', '姓名不能为空!'),

        array("\$userinfo['age']", '#<=0', '年龄不正确!')

    );

    // 步骤3

    for($i = 0; $i < count($elems); $i++) {
        if(eval("if(".preg_replace("/[#]/", $elems[$i][0], $elems[$i][1]).") return false;") === false) {
        $error_message .= $elems[$i][2];

        }
    }

    这样,我们每次只须填充验证数组$elems就可完成表单验证。

    希望对你们有用,我也很想知道你们是怎么做的。

    这样,我们每次只须填充验证数组$elems就可完成表单验证。

    希望对你们有用,我也很想知道你们是怎么做的。

    这样,我们每次只须填充验证数组$elems就可完成表单验证。

    希望对你们有用,我也很想知道你们是怎么做的。

时间: 2024-10-31 17:41:32

表单验证之PHP代码框架的相关文章

表单验证正则表达式实例代码详解_javascript技巧

表单验证正则表达式具体内容如下所示: 首先给大家解释一些符号相关的意义      1.  /^$/ 这个是个通用的格式.          ^ 匹配输入字符串的开始位置:$匹配输入字符串的结束位置      2. 里面输入需要实现的功能.         * 匹配前面的子表达式零次或多次:        + 匹配前面的子表达式一次或多次:        ?匹配前面的子表达式零次或一次:        \d  匹配一个数字字符,等价于[0-9] 下面通过一段代码给大家分析表单验证正则表达式,具体代

JavaScript 使用正则表达式进行表单验证的示例代码

JavaScript 表单验证正则表达式大全 利用正则表达式判断是否是0-9的阿拉伯数字 复制代码 代码如下: function regIsDigit(fData) { var reg = new RegExp("^[0-9]$"); return (reg.test(fData)); } 利用这则表达式获取字符串的长度 复制代码 代码如下: function regDataLength(fData) { var valLength = fData.length; var reg =

Jquery插件easyUi表单验证提交(示例代码)_jquery

复制代码 代码如下: <form id="myForm" method="post">  <table align="center" style="width:400px;height:auto;margin-top: 20px">           <tr>                                           <td align="righ

一个即时表单验证的javascript代码_表单特效

女人沙龙注册步骤-注册社区ID >> 进入社区 注册登陆名: 3-20个合法字符(包括大小写字母.数字.下划线.中文),一旦注册成功用户名不能修改. 接受相关协议: 接受 不接受 相关协议 注册密码: 密码区分大小写,4-20个合法字符组成,请尽量使用英文字母加数字或符号的组合密码. 重复密码: 请再输入一遍您上面输入的密码. 电子邮件: E-mail非常重要!这是我们与您联系的首选方式,以及接收我们的服务和取回密码的途径,请务必填写真实,并确认是您最常用的电子邮件. 验 证 码:    请输

PHP Yii框架之表单验证规则大全_php实例

Yii是一个基于组件的高性能PHP框架,用于开发大型Web应用.Yii采用严格的OOP编写,并有着完善的库引用以及全面的教程. 废话不多说了,直接给大家贴代码了. <?php class ContactForm extends CFormModel { public $_id; public $contact;//联系人 public $tel;//电话 public $fax;//传真 public $zipcode;//邮编 public $addr;//地址 public $mobile;

JavaScript常用的正则表达式表单验证代码_正则表达式

常用的正则表达式如下: 复制代码 代码如下: "^-?[1-9]\\d*$", //整数 "^[1-9]\\d*$", //正整数 "^-[1-9]\\d*$", //负整数 "^([+-]?)\\d*\\.?\\d+$", //数字 "^[1-9]\\d*|0$", //正数(正整数 + 0) "^-[1-9]\\d*|0$", //负数(负整数 + 0) "^([+-]?)

JavaScript常用的正则表达式表单验证代码

常用的正则表达式如下: 复制代码 代码如下: "^-?[1-9]\\d*$", //整数 "^[1-9]\\d*$", //正整数 "^-[1-9]\\d*$", //负整数 "^([+-]?)\\d*\\.?\\d+$", //数字 "^[1-9]\\d*|0$", //正数(正整数 + 0) "^-[1-9]\\d*|0$", //负数(负整数 + 0) "^([+-]?)

jquery实现简单的表单验证_jquery

 jquery如何实现简单的表单验证,我们先跟大家分享一下实现思路. 大概思路: 先为每一个required添加必填的标记,用each()方法来实现. 在each()方法中先是创建一个元素,然后通过append()方法将创建的元素加入到父元素后面. 这里面的this用的很精髓,每一次的this都对应着相应的input元素,然后获取相应的父元素. 然后为input元素添加失去焦点事件.然后进行用户名.邮件的验证. 这里用了一个判断is(),如果是用户名,做相应的处理,如果是邮件做相应的验证. 在j

由浅入深剖析Angular表单验证_AngularJS

最近手上维护的组件剩下的BUG都是表单验证,而且公司的表单验证那块代码经历的几代人,里面的逻辑开始变得不清晰,而且代码结构不是很angular. 是很有必要深入了解表单验证. <body ng-controller="MainController"> <form name="form" novalidate="novalidate"> <input name="text" type="e