"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Magic Quotes가 비활성화된 경우에도 PHP에서 POST 데이터가 자동 이스케이프되는 이유는 무엇입니까?

Magic Quotes가 비활성화된 경우에도 PHP에서 POST 데이터가 자동 이스케이프되는 이유는 무엇입니까?

2024년 11월 20일에 게시됨
검색:950

Why is POST Data Auto-Escaping in PHP Even When Magic Quotes are Disabled?

비활성화된 마법 인용문을 사용하여 PHP에서 신비한 자동 이스케이프 포스트 데이터 공개

PHP에서 POST 데이터로 작업할 때, 특히 WordPress 환경에서는 매직 따옴표를 꺼두었음에도 불구하고 예기치 않은 자동 이스케이프 동작이 발생할 수 있습니다. 이 난처한 문제는 마법 따옴표가 비활성화된 것으로 알려졌음에도 불구하고(get_magic_quotes_gpc()가 0을 반환함) POST 데이터가 자동 이스케이프 처리를 거칠 때 발생합니다.

WordPress의 영향

더 자세히 살펴보면 문제를 살펴보면 WordPress가 자동 이스케이프 메커니즘을 실행하는 데 중요한 역할을 한다는 것이 분명해졌습니다. WordPress가 애플리케이션 초기화 프로세스의 일부로 부트스트랩되면 해당 코드는 PHP의 마법 인용문의 자연스러운 동작을 방해합니다.

WordPress에는 POST 데이터를 포함한 요청 데이터를 가로채고 특정 작업을 수행하는 기능이 포함되어 있습니다. 작은따옴표(')를 이스케이프 처리합니다. 이 동작은 php.ini에서 매직 따옴표가 비활성화된 경우에도 확장됩니다.

버그 소스

WordPress 코드 베이스를 자세히 조사하면 아래에 보고된 버그가 드러납니다. WordPress Core Trac 시스템(티켓 18322) 이 문제는 원치 않는 이스케이프를 유발하는 요청 데이터의 잘못된 처리와 관련이 있습니다.

해결책

다행히도 이 자동 이스케이프 딜레마를 해결할 수 있는 솔루션이 있습니다. . WordPress Codex에서는 작업을 수행하기 전에 POST 데이터를 "이스케이프 해제"하기 위해 Stripslashes_deep() 함수를 사용할 것을 권장합니다. 이 기능을 사용하면 WordPress의 자동 이스케이프를 효과적으로 무시하고 원래 형식으로 데이터를 검색할 수 있습니다.

이 솔루션을 구현하려면 PHP 스크립트에 다음 코드를 추가하세요.

$_GET       = array_map('stripslashes_deep', $_GET);
$_POST      = array_map('stripslashes_deep', $_POST);
$_COOKIE    = array_map('stripslashes_deep', $_COOKIE);
$_SERVER    = array_map('stripslashes_deep', $_SERVER);
$_REQUEST   = array_map('stripslashes_deep', $_REQUEST);

이 코드는 모든 슈퍼 전역에서 슬래시를 제거하여 PHP에서 액세스할 때 POST 데이터가 자동으로 이스케이프되지 않도록 합니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3