【php】用filter_var实现的简单参数验证

filter_var是在php5.2.0中开始提供的。详细说明见:

http://www.php.net/manual/zh/book.filter.php

先看看代码:

<?php
class Utils {
    /**
     * 主要是调用filter_var_array验证,再扩充一个required字段来表示必填项。
     * http://www.php.net/manual/zh/book.filter.php
     * 注意: (可以不传,但不能传错)
     *  1.先验证格式,有失败的抛异常。
     *  2.未传的参数,有default的(不管是否required=1),则设置为default值。
     * 示例:
     *      $filterArr = array(
     *          "pn" =>array(
     *              "required"  => 1,
     *              "filter"    => FILTER_VALIDATE_INT,
     *              "options"   => array(
     *                  "default"   =>1,
     *                  "min_range" =>1,
     *              )
     *          )
     *      )
     */
public static function filter_param($paramArr, $filterArr){
        $res = filter_var_array($paramArr, $filterArr);     //参数不合法-flase, 没传参数-null
        foreach($res as $key=>$val){
            //如果有验证失败的,抛出异常。
            if(false === $val){
                throw new Exception( "Utils::filter_param: failed, key=$key ");
            }
            //再判断未传的参数。
            if( is_null($val)){
                //1.如果是必填项
                if($filterArr[$key][‘required‘] ){
                    if(isset($filterArr[$key][‘options‘][‘default‘])){
                        //1.1如果有default值,则设置为default值。
                        $res[$key] = $filterArr[$key][‘options‘][‘default‘];
                    }else{
                        //1.2如果没有default值,抛出异常。
                        throw new Exception( "Utils::filter_param: Do not have required param, key=$key" );
                    }
                }else{
                    //$res[$key]=‘‘;      //这里是默认把null值改为空值。是否有必要?
                }
            }
        }
        return $res;
}
};

        //每个model里,都写个checkParam函数,用来配置验证的规则。
    function checkParam($arrInput){
        //1.先检查catId
        $filter = array(
                //数字类型的,必填。只允许 0-1。
            "catId" => array(
                "required"=>1,
                "filter"=>FILTER_VALIDATE_INT,
                "options"=>array(
                    "min_range" =>0,
                    "max_range" =>1,
                )
            ),
                //字符串类型的,必填。长度大于1。
            "title" => array(
                "required"=>1,
                "filter"=>FILTER_VALIDATE_REGEXP,
                "options"=>array(
                    "regexp" =>"/^.+/",
                )
            ),
                //字符串类型的,非必填。但要是填了的话,则格式必须为email。
            "email" => array(
                "filter"=>FILTER_VALIDATE_EMAIL,
            ),
        );
        $_res = Utils::filter_param($arrInput, $filter) ;
    }
    
        //比如这个是输入的参数。可以试着修改这里看看效果。
    $arrInput=array(
        ‘catId‘=>1,
        ‘title‘=>‘xx‘,
        ‘email‘=>‘xxxxxx.com‘,
    );
    try{
        $res=checkParam($arrInput);
        echo "验证通过,继续其它代码...\n";
    }catch(Exception $e){
        echo ‘Caught exception: ‘,  $e->getMessage(), "\n";
    }
?>

上面的代码,可直接运行。

使用方法:

  1. 建议把filter_param放到公共函数库中。
  2. 建议在每个model里都有个checkParam函数,专门配置验证规则。

【php】用filter_var实现的简单参数验证,布布扣,bubuko.com

时间: 2024-10-26 07:18:40

【php】用filter_var实现的简单参数验证的相关文章

Java和C#下的参数验证

参数的输入和验证问题是开发时经常遇到的,一般的验证方法如下: public bool Register(string name, int age) { if (string.IsNullOrEmpty(name)) { throw new ArgumentException("name should not be empty", "name"); } if (age < 10 || age > 70) { throw new ArgumentExcept

【ADO.NET】2、各种版本的 简单登录验证

一.简单登录验证(防SQL注入) GetString(序号) 返回某一列的值(当用户不记得列名序号时,可使用GetOrdinal()获取到序号)GetInt32(序号) 针对的是 int 字段,返回int字段的值GetOrdinal("列名") 根据列名得到序号 Console.WriteLine("请输入用户名:"); string Uname=Console.ReadLine(); Console.WriteLine("请输入密码:"); s

C# 中参数验证方式的演变

一般在写方法的时候,第一步就是进行参数验证,这也体现了编码者的细心和缜密,但是在很多时候这个过程很枯燥和乏味,比如在拿到一个API设计文档的时候,通常会规定类型参数是否允许为空,如果是字符可能有长度限制,如果是整数可能需要判断范围,如果是一些特殊的类型比如电话号码,邮件地址等,可能需要使用正则表达式进行判断. 通常,我们一般都是在方法开始的地方进行条件判断,然后抛出合适的异常,这是最普通和通用的做法,但是在.NET中,利用一些语言特性和类库,可以使用一些其他的方式将我们从复杂繁琐的工作中解放出来

c# 9.0 特性提案 简化空参数验证代码

简而言之就是将已存在的特性null参数验证,使用一个简单的语义标注进一步简化. 对于如下这段代码 // Before void Insert(string s) { if (s is null) { throw new ArgumentNullException(nameof(s)); } ... } 简化为: // After void Insert(string s!) { ... } 这个提案是在代码执行时,对值进行检测. 而已存在的可空类型(Nullable)不会影响代码的执行语义(代码

ASP.NET WebAPI 11 参数验证

在绑定完Action的所有参数后,WebAPI并不会马上执行该方法,而要对参数进行验证,以保证输入的合法性. ModelState 在ApiController中一个ModelState属性用来获取参数验证结果. public abstract class ApiController : IHttpController, IDisposable { public ModelStateDictionary ModelState { get; } } ApiContext的ModelState属性实

带有“非简单参数”的函数为什么不能包含 &quot;use strict&quot; 指令

非简单参数就是 ES6 里新加的参数语法,包括:1.默认参数值.2.剩余参数.3.参数解构.本文接下来要讲的就是 ES7 为什么禁止在使用了非简单参数的函数里使用 "use strict" 指令: function f(foo = "bar") { "use strict" // SyntaxError: Illegal 'use strict' directive in function with non-simple parameter li

WebService 简单安全验证

转http://www.cnblogs.com/luking/archive/2011/03/04/1970592.html WebService 简单安全验证 2011-03-04 10:34 by Vincent.Studio, 9815 阅读, 0 评论, 收藏, 编辑 最近新接了一个需要调用第三方WebService的项目,看到这个第三方WebService被调用的时候,需要授权用户名和密码,于是自己也想对WebService的安全授权这个方面进行了一下研究,以前调用的WebServic

C# MVC 进入Action 方法之后怎么使用MVC参数验证模型

Action 接收的是json字符串,然后在把字符串序列化为实体,序列化完之后怎么再使用mvc自带的参数验证框架来验证参数, 这个问题困扰了我好久.也许有人说,调用接口的时候,加一个请求头,把contentype设置为application/json ,action 方法就可以用实体接受json的参数啦.但是我面对的不是这种情况.我需要解决的就是接受json字符串,然后序列化为实体.不要为我为什么,我就是那么固执.哈哈 解决方案直接上代码,通过给Controller添加扩展方法满足了我的需求,有

淘宝SOA框架dubbo学习(4)--参数验证

1.由于没用maven,和对dubbo不是很了解的原因,这次,总因为jar包不对,而导致:dubbo客户端程序,启动不起来 所以决定:将原来用过的所有jar包全部去,将dubbo-demo-provider-2.5.4-SNAPSHOT/lib下的所有jar包全部导入项目中 一切就OK了 2.服务消费者代码 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34