> 백엔드 개발 > PHP 튜토리얼 > 안전한 정규식 패턴 사용을 위해 PHP의 `preg_quote()` 함수 이스케이프 문자를 어떻게 사용할 수 있나요?

안전한 정규식 패턴 사용을 위해 PHP의 `preg_quote()` 함수 이스케이프 문자를 어떻게 사용할 수 있나요?

Mary-Kate Olsen
풀어 주다: 2024-12-22 03:20:11
원래의
336명이 탐색했습니다.

How Can PHP's `preg_quote()` Function Escape Characters for Safe Regex Pattern Use?

PHP에서 정규식 패턴의 문자 이스케이프

PHP에서 preg_quote() 함수는 정규식( Regex) Regex 엔진에 특별한 의미가 있는 패턴입니다. 이렇게 하면 이러한 문자가 패턴의 일부로 해석되는 것을 방지하여 충돌을 일으키지 않고 다른 Regex 패턴 내에서 표현식을 사용할 수 있습니다.

C#의 Regex.Escape() 함수와 유사하게 preg_quote()는 Regex 구문의 일부인 입력 문자열의 모든 문자 앞에 백슬래시()가 있습니다. 이러한 특수 문자에는

  • 이 포함됩니다. * ? [ ^ ] $ ( ) { } = ! < > | : -

기본적으로 preg_quote()는 Regex 패턴을 묶는 데 사용되는 구분 문자를 이스케이프하지 않습니다. 구분 기호도 이스케이프되도록 하려면 이를 함수의 두 번째 매개 변수로 지정하세요.

예:

URL $url = 'http'가 있다고 가정합니다. //stackoverflow.com/questions?sort=newest', 다음으로 둘러싸인 문자열 내에서 찾고 싶습니다. 공백:

// Escape the characters in the URL and the forward slash (/) delimiter
$escapedUrl = preg_quote($url, '/');

// Enclose the Regex pattern in forward slashes
$regex = '/\s' . $escapedUrl . '\s/';

// Find occurrences of the URL in the string
preg_match($regex, $haystack, $matches);

var_dump($matches);
로그인 후 복사

이 예에서 preg_quote()는 URL의 점(.), 물음표(?), 등호(=)와 모든 슬래시를 이스케이프합니다. 결과적으로 우리가 생성한 Regex 패턴은 haystack 문자열 내에서 URL을 성공적으로 찾을 수 있습니다.

위 내용은 안전한 정규식 패턴 사용을 위해 PHP의 `preg_quote()` 함수 이스케이프 문자를 어떻게 사용할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿