php 通用过滤器,php的过滤器功能

1.简介

PHP 过滤器用于验证和过滤来自非安全来源的数据,比如用户的输入。

1.1 外部数据:

来自表单的输入数据

Cookies

Web services data

服务器变量

数据库查询结果

1.2 验证和纠错

FILTERS, 该扩展可以用来验证(validation)和纠错(sanitization);

验证(validation)主要用来检查数据是不是符合特定条件, 例如: 当传入 FILTER_VALIDATE_EMAIL 时, 它将检查该邮件地址是否有效, 当发现不符合规范时, 不会进行纠错处理

纠错(sanitization)将会对数据进行处理, 将不符合规范的字符进行转换或移除, 例如: 当传入 FILTER_SANITIZE_EMAIL 时, 它将会处理邮件地址所包含不符合规范的字符,

但不会去检查该邮件地址是否有效。

2.过滤器相关函数

2.1 filter_var(); 通过一个指定的过滤器来过滤单一的变量

//1. 过滤器

$int = '123';$res = filter_var($int,FILTER_VALIDATE_INT);var_dump($res);echo '


';//2. 过滤选项

$int_options =['options' =>['min_range' => 0,

'max_range' => 256]

];$filter = filter_var($int,FILTER_VALIDATE_INT,$int_options);var_dump($filter);echo '


';//3.filter callback 函数

function convert_space( $str){return str_replace('_','.',$str);

}$str = 'www_myvic_con!';echo filter_var($str,FILTER_CALLBACK,['options'=>'convert_space']);echo '
';

2.2 filter_var_array() 函数获取多个变量,并进行过滤

//filter_var_array()

$arr =['name' => 'vic',

'age' =>30,

'email' =>'vic@qq.com'];$filters =['name' =>['filter' => FILTER_CALLBACK,

'flags' => FILTER_FORCE_ARRAY,

'options' =>'ucwords'],

'age' =>['filter' => FILTER_VALIDATE_INT,

'options' =>['min_range' => 1,

'max_range' => 120]

],

'email' =>FILTER_VALIDATE_EMAIL

];var_dump(filter_var_array($arr,$filters));

2.3 filter_input() 函数从脚本外部获取输入(比如表单输入),并进行过滤。

该函数可从各种来源获取输入:

INPUT_GET

INPUT_POST

INPUT_COOKIE

INPUT_ENV

INPUT_SERVER

INPUT_SESSION(尚未推行)

INPUT_REQUEST(尚未推行)

filter_input(INPUT_POST,'email',FILTER_VALIDATE_EMAIL)

2.4 filter_input_array() 函数从脚本外部获取多项输入(比如表单输入),并进行过滤。同filter_input()

$filters = array("name" => array("filter"=>FILTER_SANITIZE_STRING

),

"age" => array("filter"=>FILTER_VALIDATE_INT,

'flags' =>FILTER_REQUIRE_ARRAY, //需求的值是个数组

"options"=>array("min_range"=>1,

"max_range"=>120)

),

"email"=>FILTER_VALIDATE_EMAIL

);$result = filter_input_array(INPUT_GET, $filters);var_dump($result);

2.5 filter_has_var()

filter_has_var() 函数检查是否存在指定输入类型的变量。

如果成功则返回 TRUE,如果失败则返回 FALSE。

可能的输入类型:

INPUT_GET

INPUT_POST

INPUT_COOKIE

INPUT_SERVER

INPUT_ENV

$filter = filter_has_var(INPUT_GET, 'email');

参考资料:http://php.net/manual/zh/filter.filters.php

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值