国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > PHP > 正文

PHP高級教程(11)-PHP過濾器(Filter)

2020-03-24 17:02:57
字體:
來源:轉載
供稿:網友
PHP 過濾器用于驗證和過濾來自非安全來源的數據。 驗證和過濾用戶輸入或自定義數據是任何 Web html' target='_blank'>應用程序的重要組成部分。 設計 PHP 的過濾器擴展的目的是使數據過濾更輕松快捷。
為什么使用過濾器? 幾乎所有 web 應用程序都依賴外部的輸入。這些數據通常來自用戶或其他應用程序(比如 web 服務)。通過使用過濾器,您能夠確保應有程序獲得正確的輸入類型。 您應該始終對外部數據進行過濾! 輸入過濾是最重要的應用程序安全課題之一。 什么是外部數據? 來自表單的輸入數據 Cookies 服務器變量 數據庫查詢結果
filter_var() - 通過一個指定的過濾器來過濾單一的變量 filter_var_array() - 通過相同的或不同的過濾器來過濾多個變量 filter_input - 獲取一個輸入變量,并對它進行過濾 filter_input_array - 獲取多個輸入變量,并通過相同的或不同的過濾器對它們進行過濾 在下面的例子中,我們用 filter_var() 函數驗證了一個整數: ?php $int = 123; if(!filter_var($int, FILTER_VALIDATE_INT)) echo( Integer is not valid echo( Integer is valid ? 上面的代碼使用了 FILTER_VALIDATE_INT 過濾器來過濾變量。由于這個整數是合法的,因此代碼的輸出是: Integer is valid 。 假如我們嘗試使用一個非整數的變量,則輸出是: Integer is not valid 。
選項和標志用于向指定的過濾器添加額外的過濾選項。 不同的過濾器有不同的選項和標志。 在下面的例子中,我們用 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( Integer is not valid echo( Integer is valid ? 就像上面的代碼一樣,選項必須放入一個名為 options 的相關數組中。如果使用標志,則不需在數組內。 由于整數是 300 ,它不在指定的氛圍內,以上代碼的輸出將是 Integer is not valid 。 如需完整的函數及過濾器列表,請訪問 W3School 提供的 PHP Filter 參考手冊。您可以看到每個過濾器的可用選項和標志。
讓我們試著驗證來自表單的輸入。 我們需要作的第一件事情是確認是否存在我們正在查找的輸入數據。 然后我們用 filter_input() 函數過濾輸入的數據。 在下面的例子中,輸入變量 email 被傳到 PHP 頁面: ?php if(!filter_has_var(INPUT_GET, email )) echo( Input type does not exist if (!filter_input(INPUT_GET, email , FILTER_VALIDATE_EMAIL)) echo E-Mail is not valid else echo E-Mail is valid ? 例子解釋: 上面的例子有一個通過 GET 方法傳送的輸入變量 (email): 檢測是否存在 GET 類型的 email 輸入變量 如果存在輸入變量,檢測它是否是有效的郵件地址
讓我們試著清理一下從表單傳來的 URL。 首先,我們要確認是否存在我們正在查找的輸入數據。 然后,我們用 filter_input() 函數來凈化輸入數據。 在下面的例子中,輸入變量 url 被傳到 PHP 頁面: ?php if(!filter_has_var(INPUT_POST, url )) echo( Input type does not exist $url = filter_input(INPUT_POST, url , FILTER_SANITIZE_URL); ? 例子解釋: 上面的例子有一個通過 POST 方法傳送的輸入變量 (url): 檢測是否存在 POST 類型的 url 輸入變量 如果存在此輸入變量,對其進行凈化(刪除非法字符),并將其存儲在 $url 變量中 假如輸入變量類似這樣: http://www.W3#$%S^%$#ool.com.cn/ ,則凈化后的 $url 變量應該是這樣的: http://www.W3School.com.cn/
過濾多個輸入 表單通常由多個輸入字段組成。為了避免對 filter_var 或 filter_input 重復調用,我們可以使用 filter_var_array 或 the filter_input_array 函數。 在本例中,我們使用 filter_input_array() 函數來過濾三個 GET 變量。接收到的 GET 變量是一個名稱、一個年齡以及一個郵件地址: ?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( Age must be a number between 1 and 120. br / elseif(!$result[ email ]) echo( E-Mail is not valid. br / echo( User input is valid ? 例子解釋: 上面的例子有三個通過 GET 方法傳送的輸入變量 (name, age and email) 設置一個數組,其中包含了輸入變量的名稱,以及用于指定的輸入變量的過濾器 調用 filter_input_array 函數,參數包括 GET 輸入變量及剛才設置的數組 檢測 $result 變量中的 age 和 email 變量是否有非法的輸入。(如果存在非法輸入,) filter_input_array() 函數的第二個參數可以是數組或單一過濾器的 ID。 如果該參數是單一過濾器的 ID,那么這個指定的過濾器會過濾輸入數組中所有的值。 如果該參數是一個數組,那么此數組必須遵循下面的規則: 必須是一個關聯數組,其中包含的輸入變量是數組的鍵(比如 age 輸入變量) 此數組的值必須是過濾器的 ID ,或者是規定了過濾器、標志以及選項的數組
使用 Filter Callback 通過使用 FILTER_CALLBACK 過濾器,可以調用自定義的函數,把它作為一個過濾器來使用。這樣,我們就擁有了數據過濾的完全控制權。 您可以創建自己的自定義函數,也可以使用已有的 PHP 函數。 規定您準備用到過濾器的函數,與規定選項的方法相同。 在下面的例子中,我們使用了一個自定義的函數把所有 _ 轉換為空格: ?php function convertSpace($string) return str_replace( _ , , $string); $string = Peter_is_a_great_guy! echo filter_var($string, FILTER_CALLBACK, array( options = convertSpace )); ? 以上代碼的結果是這樣的: Peter is a great guy! 例子解釋: 上面的例子把所有 _ 轉換成空格: 創建一個把 _ 替換為空格的函數 調用 filter_var() 函數,它的參數是 FILTER_CALLBACK 過濾器以及包含我們的函數的數組html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南宁市| 台中市| 商南县| 明水县| 兴隆县| 吴堡县| 大英县| 文昌市| 吉木萨尔县| 鄂托克前旗| 门头沟区| 奉节县| 富蕴县| 迁安市| 寿宁县| 伊金霍洛旗| 新营市| 福鼎市| 金乡县| 樟树市| 湖口县| 无棣县| 泽州县| 武威市| 罗山县| 阿图什市| 榆林市| 五常市| 阆中市| 沙坪坝区| 策勒县| 石渠县| 罗平县| 拜城县| 保靖县| 灌云县| 合作市| 临江市| 惠来县| 星座| 闵行区|