php filter 安全过滤函数

转自:http://www.blags.org/archives/741.html

php 利用filter
扩展编写的参数处理静态类,欢迎使用。
希望大家看得开心,用得放心。


<?php
/**
* @参数验证函数
* @method:
* @license http://www.blags.org/
* @created:2011年07月02日 11时00分
* @copyright 1997-2011 The Martin Group
* @author Martin <[email protected]>
* */
abstract class CFilter
{
/**
* 类型
* @var array
*/
public static $varType = array(
‘GET‘=> INPUT_GET,
‘POST‘=> INPUT_POST,
‘COOKIE‘=> INPUT_COOKIE,
‘SERVER‘=> INPUT_SERVER,
‘ENV‘=> INPUT_ENV
);
public static $filterType = array(
‘STRING‘=>FILTER_SANITIZE_STRING,
‘INT‘=>FILTER_VALIDATE_INT,
‘BOOLEAN‘=>FILTER_VALIDATE_BOOLEAN,
‘FLOAT‘=>FILTER_VALIDATE_FLOAT,
‘REGEXP‘=>FILTER_VALIDATE_REGEXP,
‘URL‘=>FILTER_VALIDATE_URL,
‘EMAIL‘=>FILTER_VALIDATE_EMAIL,
‘IP‘=>FILTER_VALIDATE_IP,
);

/**
* 支持过滤列表
*/
private static function lists()
{
return filter_list();
}

/**
* 验证类型
* @param string $type
*/
public static function filterType($type)
{
$filter_list = self::lists();
return array_search($type,$filter_list) !== false ? true : false;
}

/**
*
* @param $setVarType
*/
private static function getVarType($setVarType)
{
$setVarType = strtoupper($setVarType);
return isset(self::$varType[$setVarType]) ? self::$varType[$setVarType] : null;
}

/**
*
* @param string $setFilterType
*/
private static function getFilterType($setFilterType)
{
$setFilterType = strtoupper($setFilterType);
return isset(self::$filterType[$setFilterType]) ? self::$filterType[$setFilterType] : null;
}

/**
* 检测参数是否存在
* @param string $setVarType
* @param string $varName
*/
public static function VarExists($setVarType,$varName)
{
$FilterVarType = self::getVarType($setVarType);
if (is_null($FilterVarType))
return false;
return filter_has_var(self::$varType[$FilterVarType], $varName);
}

/**
*
* @param string $setVarType
* @param string $varName
* @param string $filterType
*/
public static function FilterInput($setVarType, $varName, $filterType = ‘INT‘)
{
$FilterVarType = self::getVarType($setVarType);
$filterType = self::getFilterType($filterType);
if (is_null($FilterVarType) || is_null($filterType))
return false;
return filter_input($FilterVarType, $varName, $filterType);
}

/**
* 验证变量
* @param string $var
* @param string $filterType
*/
public static function FilterVar($var,$filterType)
{
$filterType = self::getFilterType($filterType);
return filter_var($var, $filterType);
}

/**
* 字符串
* @param string $var
*/
public static function String($var)
{
return self::FilterVar($var,‘STRING‘);
}

public static function Int($var)
{
return self::FilterVar($var,‘INT‘);
}

public static function Boolean($var)
{
return self::FilterVar($var,‘INT‘);

}

public static function Float($var)
{
return self::FilterVar($var,‘FLOAT‘);
}

/**
*
* @param string $var
* @param array $option array("options"=>array("regexp"=>"/^M(.*)/"))
*/
public static function Regexp($var,$option)
{
$filterType = self::getFilterType($filterType);
return filter_var($var, $filterType, $option);
}

public static function Url($var)
{
return self::FilterVar($var,‘URL‘);
}

public static function Email($var)
{
return self::FilterVar($var,‘EMAIL‘);
}

public static function Ip($var)
{
return self::FilterVar($var,‘IP‘);
}
}

php filter 安全过滤函数,布布扣,bubuko.com

时间: 2024-10-26 04:55:24

php filter 安全过滤函数的相关文章

python之lambda,filter,map,reduce函数

g = lambda x:x+1 看一下执行的结果: g(1) >>>2 g(2) >>>3 当然,你也可以这样使用: lambda x:x+1(1) >>>2 可以这样认为,lambda作为一个表达式,定义了一个匿名函数,上例的代码x为入口参数,x+1为函数体,用函数来表示为: def g(x): return x+1 非常容易理解,在这里lambda简化了函数定义的书写形式.是代码更为简洁,但是使用函数的定义方式更为直观,易理解. Python中,

python之filter()函数

filter()函数是python内置的一个高阶函数. filter()函数接受一个函数f 和一个list,这个函数f的作用是对每个元素进行判断,返回True或False,filter()根据判断结果自动过滤掉不符合条件的元素,返回由符合条件元素组成的新list. 利用filter()过滤出1~100中平方根是整数的数. 代码实现方法如下: 方法一:(开方求余看是否等于0) import math def is_sqrt(x): return math.sqrt(x)%1==0 print fi

python 之filter()函数

filter()函数是 Python 内置的另一个有用的高阶函数,filter()函数接收一个函数 f 和一个list,这个函数 f 的作用是对每个元素进行判断,返回 True或 False,filter()根据判断结果自动过滤掉不符合条件的元素,返回由符合条件元素组成的新list. 例如,要从一个list [1, 4, 6, 7, 9, 12, 17]中删除偶数,保留奇数,首先,要编写一个判断奇数的函数: def is_odd(x): return x % 2 == 1 然后,利用filter

Python的map、filter、reduce函数

python提供了map.filter.reduce三个函数,用于对一整组输入进行统一处理. map:映射,对一整组输入中的每个值进行一个函数计算,输出每个值对应的结果. filter:过滤,输入的函数必须有一个返回值True或者False,filter只会把经过函数处理后结果是True的值输出. reduce:归纳,会对所有输入运用一个函数,返回一个输出. 例子: def even(x): return x%2==True map(even,range(4)) =>[True,False,Tr

python3:lambda,map,filter内置函数

notes: 参考文档-(菜鸟教程)http://www.runoob.com/python/python-built-in-functions.html 参考文档-(妖白)http://blog.csdn.net/qq_24753293/article/details/78337818 一.lambda() 描述: 简化def函数 实例: A=lambda x:x+1 理解为: def A(x): return x+1 冒号左边→想要传递的参数 冒号右边→想要得到的数(可能带表达式) 二.ma

django-admin 仿写stark组件action,filter筛选过滤,search查询

写在StandLi里面的方法都是通过ModelSubject这个类里面的stand_li方法,在它里面用StandLi这个类实例化出来一个对象,这个实例化出来的对象把数据传给前端HTML模板进行渲染,所以StandLi这个类里面的方法如果你找不到就是在给前端传数据用的 tag.py 1 from django.conf.urls import url 2 from django.shortcuts import render, redirect, reverse 3 from django.ut

lambda&amp;filter&amp;map&amp;reduce函数的基本使用

'''Created on 2019-03-14Author:BinzhouProject:python中lambda filter map reduce函数使用总结''' #lambda匿名函数,格式lambda x,y:x+y 表示一个函数的参数是x,y,函数实现功能是x+y #filter[function,sequence]用于过滤序列 返回迭代器对象(包含所有满足使function返回值为True的sequence值)#python2直接返回与sequence一致的数据类型(列表,元组

数据库编程1 Oracle 过滤 函数 分组 外连接 自连接

[本文谢绝转载原文来自http://990487026.blog.51cto.com] <大纲> 数据库编程1 Oracle 过滤 函数 分组 外连接 自连接 本文实验基于的数据表: winsows安装好Oracle11g之后,开始实验 SQLplus 登陆 ORacle sqlplus 退出的方式 查看用户之下有什么表 查看表的所有记录,不区分大小写 设置SQLplus行宽,页宽,列宽: 清屏命令 select as 语法 1,as别名的使用 2,没有引号带有空格的别名,无法识别: 3,带有

数据库编程2 Oracle 过滤 函数 分组 外连接 自连接

[本文谢绝转载原文来自http://990487026.blog.51cto.com] 续:数据库编程1 Oracle 过滤 函数 分组 外连接 自连接 where like模糊查询,查询员工姓名是4个字母 SQL> select * from emp where ename like '____';      EMPNO ENAME                JOB                       MGR HIREDATE          SAL       COMM