电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

php過濾器使用詳解

瀏覽:181日期:2022-06-06 14:54:44
目錄
  • PHP 過濾器
  • 什么是 PHP 過濾器
  • 為什么使用過濾器
  • 函數(shù)和過濾器
  • Validating 和 Sanitizing
  • 選項和標志
  • 驗證輸入
  • 凈化輸入
  • 過濾多個輸入
  • 使用Filter Callback

PHP 過濾器

PHP 過濾器用于驗證和過濾來自非安全來源的數(shù)據(jù),比如用戶的輸入。

什么是 PHP 過濾器

PHP 過濾器用于驗證和過濾來自非安全來源的數(shù)據(jù)。

測試、驗證和過濾用戶輸入或自定義數(shù)據(jù)是任何 Web 應用程序的重要組成部分。

PHP 的過濾器擴展的設(shè)計目的是使數(shù)據(jù)過濾更輕松快捷。

為什么使用過濾器

幾乎所有的 Web 應用程序都依賴外部的輸入。這些數(shù)據(jù)通常來自用戶或其他應用程序(比如 web 服務)。通過使用過濾器,您能夠確保應用程序獲得正確的輸入類型。

您應該始終對外部數(shù)據(jù)進行過濾!

輸入過濾是最重要的應用程序安全課題之一。

什么是外部數(shù)據(jù)?

來自表單的輸入數(shù)據(jù)

Cookies

Web services data

服務器變量

數(shù)據(jù)庫查詢結(jié)果

函數(shù)和過濾器

如需過濾變量,請使用下面的過濾器函數(shù)之一:

filter_var() - 通過一個指定的過濾器來過濾單一的變量

filter_var_array() - 通過相同的或不同的過濾器來過濾多個變量

filter_input - 獲取一個輸入變量,并對它進行過濾

filter_input_array - 獲取多個輸入變量,并通過相同的或不同的過濾器對它們進行過濾

在下面的實例中,我們用 filter_var() 函數(shù)驗證了一個整數(shù):

<?php
$int = 123;
if(!filter_var($int, FILTER_VALIDATE_INT))
{
    echo("不是一個合法的整數(shù)");
}
else
{
    echo("是個合法的整數(shù)");
}
?>

上面的代碼使用了 “FILTER_VALIDATE_INT” 過濾器來過濾變量。由于這個整數(shù)是合法的,因此上面的代碼將輸出:

是個合法的整數(shù)

如果我們嘗試使用一個非整數(shù)的變量(比如 “123abc”),則將輸出:“Integer is not valid”。

**

Validating 和 Sanitizing

**

有兩種過濾器:

Validating 過濾器:

用于驗證用戶輸入

嚴格的格式規(guī)則(比如 URL 或 E-Mail 驗證)

如果成功則返回預期的類型,如果失敗則返回 FALSE

Sanitizing 過濾器:

用于允許或禁止字符串中指定的字符

無數(shù)據(jù)格式規(guī)則

始終返回字符串

選項和標志

選項和標志用于向指定的過濾器添加額外的過濾選項。

不同的過濾器有不同的選項和標志。

在下面的實例中,我們用 filter_var() 和 “min_range” 以及 “max_range” 選項驗證了一個整數(shù):

<?php
$var=300;
$int_options = array(
    "options"=>array
    (
"min_range"=>0,
"max_range"=>256
    )
);
if(!filter_var($var, FILTER_VALIDATE_INT, $int_options))
{
    echo("不是一個合法的整數(shù)");
}
else
{
    echo("是個合法的整數(shù)");
}
?>

就像上面的代碼一樣,選項必須放入一個名為 “options” 的相關(guān)數(shù)組中。如果使用標志,則不需在數(shù)組內(nèi)。

由于整數(shù)是 “300”,它不在指定的范圍內(nèi),以上代碼的輸出將是:

不是一個合法的整數(shù)

驗證輸入

讓我們試著驗證來自表單的輸入。

我們需要做的第一件事情是確認是否存在我們正在查找的輸入數(shù)據(jù)。

然后我們用 filter_input() 函數(shù)過濾輸入的數(shù)據(jù)。

在下面的實例中,輸入變量 “email” 被傳到 PHP 頁面:

<?php
if(!filter_has_var(INPUT_GET, "email"))
{
    echo("沒有 email 參數(shù)");
}
else
{
    if (!filter_input(INPUT_GET, "email", FILTER_VALIDATE_EMAIL))
    {
echo "不是一個合法的 E-Mail";
    }
    else
    {
echo "是一個合法的 E-Mail";
    }
}
?>

以上實例測試結(jié)果如下:

是一個合法的 E-Mail

實例解釋

上面的實例有一個通過 “GET” 方法傳送的輸入變量 (email):

檢測是否存在 “GET” 類型的 “email” 輸入變量

如果存在輸入變量,檢測它是否是有效的 e-mail 地址

凈化輸入

讓我們試著清理一下從表單傳來的 URL。

首先,我們要確認是否存在我們正在查找的輸入數(shù)據(jù)。

然后,我們用 filter_input() 函數(shù)來凈化輸入數(shù)據(jù)。

在下面的實例中,輸入變量 “url” 被傳到 PHP 頁面:

<?php
if(!filter_has_var(INPUT_GET, "url"))
{
    echo("沒有 url 參數(shù)");
}
else
{
    $url = filter_input(INPUT_GET, 
    "url", FILTER_SANITIZE_URL);
    echo $url;
}
?>

實例解釋

上面的實例有一個通過 “GET” 方法傳送的輸入變量 (url):

檢測是否存在 “GET” 類型的 “url” 輸入變量

如果存在此輸入變量,對其進行凈化(刪除非法字符),并將其存儲在 $url 變量中

過濾多個輸入

表單通常由多個輸入字段組成。為了避免對 filter_var 或 filter_input 函數(shù)重復調(diào)用,我們可以使用 filter_var_array 或 the filter_input_array 函數(shù)。

在本例中,我們使用 filter_input_array() 函數(shù)來過濾三個 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):

設(shè)置一個數(shù)組,其中包含了輸入變量的名稱和用于指定的輸入變量的過濾器

調(diào)用 filter_input_array() 函數(shù),參數(shù)包括 GET 輸入變量及剛才設(shè)置的數(shù)組

檢測 $result 變量中的 “age” 和 “email” 變量是否有非法的輸入。(如果存在非法輸入,在使用 filter_input_array() 函數(shù)之后,輸入變量為 FALSE。)

filter_input_array() 函數(shù)的第二個參數(shù)可以是數(shù)組或單一過濾器的 ID。

如果該參數(shù)是單一過濾器的 ID,那么這個指定的過濾器會過濾輸入數(shù)組中所有的值。

如果該參數(shù)是一個數(shù)組,那么此數(shù)組必須遵循下面的規(guī)則:

必須是一個關(guān)聯(lián)數(shù)組,其中包含的輸入變量是數(shù)組的鍵(比如 “age” 輸入變量)

此數(shù)組的值必須是過濾器的 ID ,或者是規(guī)定了過濾器、標志和選項的數(shù)組

使用Filter Callback

通過使用 FILTER_CALLBACK 過濾器,可以調(diào)用自定義的函數(shù),把它作為一個過濾器來使用。這樣,我們就擁有了數(shù)據(jù)過濾的完全控制權(quán)。

您可以創(chuàng)建自己的自定義函數(shù),也可以使用已存在的 PHP 函數(shù)。

將您準備用到的過濾器的函數(shù),按指定選項的規(guī)定方法進行規(guī)定。在關(guān)聯(lián)數(shù)組中,帶有名稱 “options”。

在下面的實例中,我們使用了一個自定義的函數(shù)把所有 “_” 轉(zhuǎn)換為 “.”:

<?php
function convertSpace($string)
{
    return str_replace("_", ".", $string);
}
$string = "www_*****_com!";
echo filter_var($string, FILTER_CALLBACK,
array("options"=>"convertSpace"));
?>

上面代碼的結(jié)果如下所示:

www.*****.com!

實例解釋

上面的實例把所有 “_” 轉(zhuǎn)換成 “.” :

創(chuàng)建一個把 “_” 替換為 “.” 的函數(shù)

調(diào)用 filter_var() 函數(shù),它的參數(shù)是 FILTER_CALLBACK 過濾器以及包含我們的函數(shù)的數(shù)組

到此這篇關(guān)于php過濾器使用詳解的文章就介紹到這了,更多相關(guān)php過濾器內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 好杂志网-首页| 东莞猎头公司_深圳猎头公司_广州猎头公司-广东万诚猎头提供企业中高端人才招聘服务 | 苏商学院官网 - 江苏地区唯一一家企业家自办的前瞻型、实操型商学院 | 武汉高低温试验箱_恒温恒湿试验箱厂家-武汉蓝锐环境科技有限公司 | 附着力促进剂-尼龙处理剂-PP处理剂-金属附着力处理剂-东莞市炅盛塑胶科技有限公司 | 集装箱展厅-住人集装箱住宿|建筑|房屋|集装箱售楼处-山东锐嘉科技工程有限公司 | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 镀锌角钢_槽钢_扁钢_圆钢_方矩管厂家_镀锌花纹板-海邦钢铁(天津)有限公司 | 金属切削液-脱水防锈油-电火花机油-抗磨液压油-深圳市雨辰宏业科技发展有限公司 | PVC地板|PVC塑胶地板|PVC地板厂家|地板胶|防静电地板-无锡腾方装饰材料有限公司-咨询热线:4008-798-128 | 【直乐】河北石家庄脊柱侧弯医院_治疗椎间盘突出哪家医院好_骨科脊柱外科专业医院_治疗抽动症/关节病骨伤权威医院|排行-直乐矫形中医医院 | 铝合金重力铸造_铝合金翻砂铸造_铝铸件厂家-东莞市铝得旺五金制品有限公司 | 铝合金风口-玻璃钢轴流风机-玻璃钢屋顶风机-德州东润空调设备有限公司 | 河南mpp电力管_mpp电力管生产厂家_mpp电力电缆保护管价格 - 河南晨翀实业 | 箱式破碎机_移动方箱式破碎机/价格/厂家_【华盛铭重工】 | 锂电池砂磨机|石墨烯砂磨机|碳纳米管砂磨机-常州市奥能达机械设备有限公司 | 今日热点_实时热点_奇闻异事_趣闻趣事_灵异事件 - 奇闻事件 | 氧化锆纤维_1800度高温退火炉_1800度高温烧结炉-南京理工宇龙新材料股份有限公司 | 臭氧老化试验箱,高低温试验箱,恒温恒湿试验箱,防水试验设备-苏州亚诺天下仪器有限公司 | 广东西屋电气有限公司-广东西屋电气有限公司 | 钢骨架轻型板_膨石轻型板_钢骨架轻型板价格_恒道新材料 | 鲁网 - 山东省重点新闻网站,山东第一财经门户| 新能源汽车教学设备厂家报价[汽车教学设备运营18年]-恒信教具 | 软膜天花_软膜灯箱_首选乐创品牌_一站式天花软膜材料供应商! | 酒瓶_酒杯_玻璃瓶生产厂家_徐州明政玻璃制品有限公司 | 液氮罐_液氮容器_自增压液氮罐_杜瓦瓶_班德液氮罐厂家 | 正压送风机-多叶送风口-板式排烟口-德州志诺通风设备 | 智能气瓶柜(大型气瓶储存柜)百科 | 今日扫码_溯源二维码_产品防伪一物一码_红包墙营销方案 | PTFE接头|聚四氟乙烯螺丝|阀门|薄膜|消解罐|聚四氟乙烯球-嘉兴市方圆氟塑制品有限公司 | 成都治疗尖锐湿疣比较好的医院-成都治疗尖锐湿疣那家医院好-成都西南皮肤病医院 | 智能化的检漏仪_气密性测试仪_流量测试仪_流阻阻力测试仪_呼吸管快速检漏仪_连接器防水测试仪_车载镜头测试仪_奥图自动化科技 | 合同书格式和范文_合同书样本模板_电子版合同,找范文吧 | 河南15年专业网站建设制作设计,做网站就找郑州启凡网络公司 | 家庭教育吧-在线家庭教育平台,专注青少年家庭教育 | 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | ★济南领跃标识制作公司★济南标识制作,标牌制作,山东标识制作,济南标牌厂 | 执业药师报名时间,报考条件,考试时间-首页入口 | 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | 重庆磨床过滤机,重庆纸带过滤机,机床伸缩钣金,重庆机床钣金护罩-重庆达鸿兴精密机械制造有限公司 | 加中寰球移民官网-美国移民公司,移民机构,移民中介,移民咨询,投资移民 |