PHP 필터 (필터)
PHP 필터는 사용자 입력과 같은 비보안 소스의 데이터를 검증하고 필터링하는 데 사용됩니다.
PHP 필터란 무엇인가요?
PHP 필터는 안전하지 않은 소스의 데이터를 검증하고 필터링하는 데 사용됩니다.
사용자 입력 또는 맞춤 데이터를 검증하고 필터링하는 것은 모든 웹 애플리케이션에서 중요한 부분입니다.
PHP용 필터 확장은 데이터 필터링을 더 쉽고 빠르게 만들기 위해 설계되었습니다.
필터를 사용하는 이유는 무엇인가요?
거의 모든 웹 애플리케이션은 외부 입력에 의존합니다. 이 데이터는 일반적으로 사용자 또는 기타 애플리케이션(예: 웹 서비스)에서 제공됩니다. 필터를 사용하면 애플리케이션이 올바른 입력 유형을 얻도록 할 수 있습니다.
외부 데이터는 항상 필터링해야 합니다!
입력 필터링은 가장 중요한 애플리케이션 보안 주제 중 하나입니다.
외부 데이터란 무엇인가요?
- 양식에서 데이터 입력
- 쿠키
- 서버 변수
- 데이터베이스 쿼리 결과
기능 및 필터
변수를 필터링하려면 다음 필터 기능 중 하나를 사용하세요.
- filter_var() - 지정된 필터로 단일 변수를 필터링합니다
- filter_var_array() - 동일하거나 다른 필터를 사용하여 여러 변수를 필터링합니다
- filter_input - 입력 변수를 가져와 필터링합니다.
- filter_input_array - 여러 입력 변수를 가져와 동일하거나 다른 필터를 통해 필터링합니다.
아래 예에서는 filter_var() 함수를 사용하여 정수의 유효성을 검사합니다.
<?php $int = 123; if(!<code>filter_var($int, FILTER_VALIDATE_INT)</code>) { echo("Integer is not valid"); } else { echo("Integer is valid"); } ?>
위 코드는 "FILTER_VALIDATE_INT" 필터를 사용하여 변수를 필터링합니다. 이 정수는 유효하므로 코드 출력은 "정수는 유효합니다"입니다.
정수가 아닌 변수를 사용하려고 하면 "정수가 유효하지 않습니다."라는 결과가 출력됩니다.
함수 및 필터의 전체 목록을 보려면 PHP 필터 참조 매뉴얼을 방문하세요.
검증 및 삭제
필터에는 두 가지 유형이 있습니다.
필터 확인 중:
- 사용자 입력을 확인하는 데 사용됩니다
- 엄격한 형식 규칙(예: URL 또는 이메일 확인)
- 성공하면 예상 유형을 반환하고, 실패하면 FALSE를 반환합니다
필터 살균:
- 문자열에서 특정 문자를 허용하거나 금지하는 데 사용됩니다
- 데이터 형식 규칙 없음
- 항상 문자열을 반환합니다
옵션 및 플래그
옵션과 플래그는 지정된 필터에 추가 필터링 옵션을 추가하는 데 사용됩니다.
필터마다 옵션과 플래그가 다릅니다.
아래 예에서는 "min_range" 및 "max_range" 옵션과 함께 filter_var()를 사용하여 정수의 유효성을 검사합니다.
<?php $var=300; <span class="marked"> $int_options = array( "options"=>array ( "min_range"=>0, "max_range"=>256 ) ); if(!<code>filter_var($var, FILTER_VALIDATE_INT, $int_options)</code>) { echo("Integer is not valid"); } else { echo("Integer is valid"); } ?>
위 코드와 마찬가지로 옵션도 "options"라는 관련 배열에 넣어야 합니다. 플래그를 사용하는 경우 배열에 있을 필요는 없습니다.
정수는 지정된 범위 내에 있지 않은 "300"이므로 위 코드의 출력은 "정수가 유효하지 않습니다"입니다.
함수 및 필터의 전체 목록을 보려면 W3School에서 제공하는 PHP 필터 참조 매뉴얼을 방문하세요. 각 필터에 사용 가능한 옵션과 플래그를 볼 수 있습니다.
입력 유효성 검사
양식에서 입력된 내용을 확인해 보겠습니다.
가장 먼저 해야 할 일은 찾고 있는 입력 데이터가 존재하는지 확인하는 것입니다.
그런 다음 filter_input() 함수를 사용하여 입력 데이터를 필터링합니다.
다음 예에서는 입력 변수 "email"이 PHP 페이지에 전달됩니다.
<?php if(!filter_has_var(INPUT_GET, "email")) { echo("Input type does not exist"); } else { if (!<code>filter_input(INPUT_GET, "email", FILTER_VALIDATE_EMAIL)</code>) { echo "E-Mail is not valid"; } else { echo "E-Mail is valid"; } } ?>
예제 설명:
위의 예에는 "GET" 메소드를 통해 전달된 입력 변수(이메일)가 있습니다.
- "GET" 유형의 "이메일" 입력 변수가 있는지 감지
- 입력변수가 존재하는 경우, 유효한 이메일 주소인지 확인하세요
입력 정화
양식에서 전달된 URL을 정리해 보겠습니다.
먼저 찾고 있는 입력 데이터가 존재하는지 확인하고 싶습니다.
그런 다음 filter_input() 함수를 사용하여 입력 데이터를 정제합니다.
다음 예에서는 입력 변수 "url"이 PHP 페이지에 전달됩니다.
<?php if(!filter_has_var(INPUT_POST, "url")) { echo("Input type does not exist"); } else { $url = <code>filter_input(INPUT_POST, "url", FILTER_SANITIZE_URL)</code>; } ?>
예제 설명:
위의 예에는 "POST" 메소드를 통해 전달된 입력 변수(url)가 있습니다.
- "POST" 유형의 "url" 입력 변수가 있는지 감지
- 이 입력 변수가 존재하는 경우 이를 삭제하고(불법 문자 제거) $url 변수에 저장하세요.
입력 변수가 "http://www.W3 불법 ol.com.c 문자 n/"과 유사한 경우 정제된 $url 변수는 다음과 같아야 합니다.
http://www.W3School.com.cn/
过滤多个输入
表单通常由多个输入字段组成。为了避免对 filter_var 或 filter_input 重复调用,我们可以使用 filter_var_array 或 the filter_input_array 函数。
在本例中,我们使用 filter_input_array() 函数来过滤三个 GET 变量。接收到的 GET 变量是一个名字、一个年龄以及一个邮件地址:
<?php <span class="marked">$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 = <code>filter_input_array(INPUT_GET, $filters)</code>;(array(3) { ["name"]=> string(1) "1" ["age"]=> bool(false) ["email"]=> string(8) "1@qq.com" }) if (!$result["age"]) { echo("Age must be a number between 1 and 120.<br />"); } elseif(!$result["email"]) { echo("E-Mail is not valid.<br />"); } else { 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 <span class="marked">function convertSpace($string) { return str_replace("_", " ", $string); } $string = "Peter_is_a_great_guy!"; echo <code>filter_var($string, FILTER_CALLBACK, array("options"=>"convertSpace")); ?>
以上代码的结果是这样的:
Peter is a great guy!
例子解释:
上面的例子把所有 "_" 转换成空格:
- 创建一个把 "_" 替换为空格的函数
- 调用 filter_var() 函数,它的参数是 FILTER_CALLBACK 过滤器以及包含我们的函数的数组

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









