> 백엔드 개발 > PHP 튜토리얼 > PHP 애플리케이션에서 SQL 주입을 효과적으로 방지하는 방법은 무엇입니까?

PHP 애플리케이션에서 SQL 주입을 효과적으로 방지하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-30 06:36:10
원래의
416명이 탐색했습니다.

How to Effectively Prevent SQL Injection in PHP Applications?

PHP에서 SQL 주입을 방지하는 방법

수정 없이 SQL 쿼리에 사용자 입력을 직접 삽입하면 애플리케이션이 SQL 주입 공격에 취약해집니다. 이를 방지하려면 SQL에서 데이터를 분리하여 데이터가 데이터로 유지되고 SQL 파서의 명령으로 해석되지 않도록 하는 것이 중요합니다.

가장 효과적인 솔루션

사용 중인 데이터베이스에 관계없이 SQL 주입 공격을 방지하기 위해 권장되는 접근 방식은 준비된 명령문과 매개변수화된 쿼리. 이는 데이터베이스 서버가 매개변수와 함께 독립적으로 구문 분석하는 SQL 문입니다. 이 접근 방식을 사용하면 공격자가 악성 SQL을 삽입하는 것이 불가능합니다.

PDO 또는 MySQLi를 사용한 구현

PDO는 지원되는 모든 데이터베이스 드라이버에 대한 범용 솔루션을 제공하는 반면, MySQLi는 특정 드라이버에 국한됩니다. MySQL로.

사용 PDO

$stmt = $pdo->prepare('SELECT * FROM employees WHERE name = :name');
$stmt->execute(['name' => $name]);

foreach ($stmt as $row) {
    // Do something with $row
}
로그인 후 복사

MySQLi 사용(execute_query()가 포함된 PHP 8.2)

$result = $db->execute_query('SELECT * FROM employees WHERE name = ?', [$name]);

while ($row = $result->fetch_assoc()) {
    // Do something with $row
}
로그인 후 복사

MySQLi 사용(PHP 8.1 및 이전 버전)

$stmt = $db->prepare('SELECT * FROM employees WHERE name = ?');
$stmt->bind_param('s', $name); // 's' specifies string type
$stmt->execute();
$result = $stmt->get_result();

while ($row = $result->fetch_assoc()) {
    // Do something with $row
}
로그인 후 복사

올바른 연결 설정

MySQL용 PDO를 사용할 때는 에뮬레이션을 비활성화하여 실제 준비된 명령문이 사용되는지 확인하세요.

$dbConnection = new PDO('mysql:dbname=dbtest;host=127.0.0.1;charset=utf8mb4', 'user', 'password');

$dbConnection->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$dbConnection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
로그인 후 복사

MySQLi의 경우 다음을 사용하세요.

mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT); // error reporting
$dbConnection = new mysqli('127.0.0.1', 'username', 'password', 'test');
$dbConnection->set_charset('utf8mb4'); // charset
로그인 후 복사

설명

준비된 문장을 파싱합니다. 그리고 데이터베이스 서버에 의해 컴파일되어 SQL 문을 매개변수와 분리합니다. 매개변수가 전달되면 컴파일된 문과 문자열로 결합되어 SQL 삽입 위험이 제거됩니다.

동적 쿼리

준비된 문은 다음 용도로 사용할 수 있습니다. 동적 쿼리의 매개변수에서는 동적 쿼리 구조 자체를 매개변수화할 수 없습니다. 이러한 경우에는 화이트리스트 필터를 사용하는 것이 좋습니다.

위 내용은 PHP 애플리케이션에서 SQL 주입을 효과적으로 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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