什么是PHP 过滤器?有那几种过滤器呢?
时间:2021-06-05
来源:互联网
今天PHP爱好者给大家带来上篇文章给大家介绍了《如何用PHP编写 E-mail的程序文件?》,本文继续给大家介绍什么是PHP 过滤器?有那几种过滤器呢?一起出发吧!希望对大家有所帮助。
什么是 PHP 过滤器?
PHP 过滤器用于验证和过滤来自非安全来源的数据。
测试、验证和过滤用户输入或自定义数据是任何 Web 应用程序的重要组成部分。
PHP 的过滤器扩展的设计目的是使数据过滤更轻松快捷。
PHP 过滤器用于验证和过滤来自非安全来源的数据,比如用户的输入。
为什么使用过滤器?
几乎所有的 Web 应用程序都依赖外部的输入。这些数据通常来自用户或其他应用程序(比如 web 服务)。通过使用过滤器,您能够确保应用程序获得正确的输入类型。
您应该始终对外部数据进行过滤!
输入过滤是最重要的应用程序安全课题之一。
什么是外部数据?
来自表单的输入数据
Cookies
Web services data
服务器变量
数据库查询结果
函数和过滤器
如需过滤变量,请使用下面的过滤器函数之一:
filter_var() - 通过一个指定的过滤器来过滤单一的变量
filter_var_array() - 通过相同的或不同的过滤器来过滤多个变量
filter_input - 获取一个输入变量,并对它进行过滤
filter_input_array - 获取多个输入变量,并通过相同的或不同的过滤器对它们进行过滤
在下面的实例中,我们用 filter_var() 函数验证了一个整数:
<?php
$int = 123;
if(!filter_var($int, FILTER_VALIDATE_INT))
{
echo("不是一个合法的整数");
}
else
{
echo("是个合法的整数");
}
?>
运行代码结果如下:
Validating 和 Sanitizing
有两种过滤器:
Validating 过滤器:
用于验证用户输入
严格的格式规则(比如 URL 或 E-Mail 验证)
如果成功则返回预期的类型,如果失败则返回 FALSE
Sanitizing 过滤器:
用于允许或禁止字符串中指定的字符
无数据格式规则
始终返回字符串
选项和标志选项和标志用于向指定的过滤器添加额外的过滤选项。
不同的过滤器有不同的选项和标志。
在下面的实例中,我们用 filter_var() 和 "min_range" 以及 "max_range" 选项验证了一个整数:
<?php
$var=300;
$int_options = array(
"options"=>array
(
"min_range"=>0,
"max_range"=>256
)
);
if(!filter_var($var, FILTER_VALIDATE_INT, $int_options))
{
echo("不是一个合法的整数");
}
else
{
echo("是个合法的整数");
}
?>
就像上面的代码一样,选项必须放入一个名为 "options" 的相关数组中。如果使用标志,则不需在数组内。
由于整数是 "300",它不在指定的范围内,以上代码的输出将是
运行代码结果如下:
过滤多个输入
表单通常由多个输入字段组成。为了避免对 filter_var 或 filter_input 函数重复调用,我们可以使用 filter_var_array 或 the filter_input_array 函数。
在本例中,我们使用 filter_input_array() 函数来过滤三个 GET 变量。接收到的 GET 变量是一个名字、一个年龄以及一个 e-mail 地址:
<?php
$filters = array
(
"name" => array
(
"filter"=>FILTER_SANITIZE_STRING
),
"age" => array
(
"filter"=>FILTER_VALIDATE_INT,
"options"=>array
(
"min_range"=>1,
"max_range"=>120
)
),
"email"=> FILTER_VALIDATE_EMAIL
);
$result = filter_input_array(INPUT_GET, $filters);
if (!$result["age"])
{
echo("年龄必须在 1 到 120 之间。<br>");
}
elseif(!$result["email"])
{
echo("E-Mail 不合法<br>");
}
else
{
echo("输入正确");
}
?>
结果如下:
实例解释:
上面的实例有三个通过 "GET" 方法传送的输入变量 (name、age 和 email):
设置一个数组,其中包含了输入变量的名称和用于指定的输入变量的过滤器
调用 filter_input_array() 函数,参数包括 GET 输入变量及刚才设置的数组
检测 $result 变量中的 "age" 和 "email" 变量是否有非法的输入。(如果存在非法输入,在使用 filter_input_array() 函数之后,输入变量为 FALSE。)
filter_input_array() 函数的第二个参数可以是数组或单一过滤器的 ID。
如果该参数是单一过滤器的 ID,那么这个指定的过滤器会过滤输入数组中所有的值。
如果该参数是一个数组,那么此数组必须遵循下面的规则:
必须是一个关联数组,其中包含的输入变量是数组的键(比如 "age" 输入变量)
此数组的值必须是过滤器的 ID ,或者是规定了过滤器、标志和选项的数组
以上就是什么是PHP 过滤器?有那几种过滤器呢?的详细内容,更多请关注php爱好者其它相关文章!
-
什么是PlaysOut?PlaysOut是如何运作的?PlaysOut发展路线图介绍 时间:2025-05-01
-
币圈新手技术分析攻略:八大技术指标解读加密货币跟市场趋势 时间:2025-05-01
-
趋势线怎么画、KD值怎么看黄金交叉?如何使用TradingView画趋势线? 时间:2025-05-01
-
Movernance是什么?一站式质押+治理+发币平台及生态明星项目介绍 时间:2025-05-01
-
区块链与Web3之间是什么关系?区块链将如何推动Web3的扩展? 时间:2025-05-01
-
什么是Recal?Recall项目背景、核心技术、特性介绍及风险分析 时间:2025-05-01
今日更新
-
解决ThinkPHP5.1版本引入composer vendor扩展包的问题
阅读:18
-
users是什么文件夹
阅读:18
-
excel点击右键菜单栏不出现怎么办
阅读:18
-
jquery UI Datepicker时间控件的用法(一)
阅读:18
-
php数组怎么增加一个元素
阅读:18
-
PHP如何使用Mcrypt加密
阅读:18
-
峰值功率是什么意思
阅读:18
-
详细介绍PHP中json_encode函数参数
阅读:18
-
jquery UI Datepicker时间控件的用法(二)
阅读:18
-
wps如何为同一对象添加多个动画
阅读:18