> 데이터 베이스 > MySQL 튜토리얼 > mysql_real_escape_string()은 정말로 결함이 있는 것인가, 아니면 단지 오용된 것인가?

mysql_real_escape_string()은 정말로 결함이 있는 것인가, 아니면 단지 오용된 것인가?

DDD
풀어 주다: 2024-12-04 10:11:17
원래의
388명이 탐색했습니다.

Is mysql_real_escape_string() Truly Flawed, or Just Misused?

의심된 결함 폭로: mysql_real_escape_string()의 신뢰성 탐색

mysql_real_escape_string()이 단점을 보인다는 주장에도 불구하고, 강력한 기능을 제공한다는 증거가 있습니다. 사용 시 SQL 주입 취약점으로부터 보호

소위 결함을 면밀히 조사해 보면 이러한 결함은 일반적으로 부적절한 사용이나 오래된 정보에서 비롯되는 것으로 나타났습니다. MySQL C API 문서에 명시적으로 나와 있듯이 SET NAMES 또는 SET CHARACTER SET 문 대신 mysql_set_character_set()을 사용하여 문자 집합을 설정하는 것이 중요합니다. 후자의 옵션은 mysql_real_escape_string()에서 사용하는 문자 집합에 영향을 주지 않습니다.

PHP의 mysql_set_charset()는 MySQL의 mysql_set_character_set()에 대응하는 역할을 합니다. 이를 활용하여 인코딩을 수정함으로써 개발자는 호환성을 보장하고 잠재적인 문제를 피할 수 있습니다.

코드 예:

<?php
$mysqli = new mysqli('host', 'user', 'password', 'database');
$mysqli->set_charset('utf8mb4'); // Set utf8mb4 encoding

// Example usage of mysql_real_escape_string()
$escaped_string = mysql_real_escape_string($mysqli->connect_errno, $_POST['username']);
로그인 후 복사

이 접근 방식은 mysql_real_escape_string(을 사용하여 문자 세트를 효과적으로 설정하고 사용자 입력을 적절하게 이스케이프합니다( ), SQL 주입 공격의 위험을 완화합니다.

위 내용은 mysql_real_escape_string()은 정말로 결함이 있는 것인가, 아니면 단지 오용된 것인가?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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