> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 SQL 주입을 방지하기 위해 `Add()`보다 `AddWithValue()`가 선호되는 이유는 무엇입니까?

MySQL에서 SQL 주입을 방지하기 위해 `Add()`보다 `AddWithValue()`가 선호되는 이유는 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-04 06:53:11
원래의
263명이 탐색했습니다.

Why is `AddWithValue()` Preferred Over `Add()` for Preventing SQL Injection in MySQL?

Command.Parameters.Add()는 더 이상 사용되지 않습니다: MySQL 쿼리 삽입에서 AddWithValue() 사용

Command.Parameters.Add 사용법 () MySQL 쿼리에서는 보안상의 이유로 더 이상 사용되지 않습니다. 쿼리 삽입 안전을 보장하려면 대신 AddWithValue() 메서드를 사용하는 것이 좋습니다.

AddWithValue()를 사용하도록 코드를 업데이트하는 방법은 다음과 같습니다.

string SQL = "INSERT INTO `twMCUserDB` (`mc_userName`, `mc_userPass`, `tw_userName`, `tw_userPass`) VALUES (@mcUserName, @mcUserPass, @twUserName, @twUserPass)";
command.CommandText = SQL;
command.Parameters.AddWithValue("@mcUserName", mcUserNameNew);
command.Parameters.AddWithValue("@mcUserPass", mcUserPassNew);
command.Parameters.AddWithValue("@twUserName", twUserNameNew);
command.Parameters.AddWithValue("@twUserPass", twUserPassNew);
로그인 후 복사

AddWithValue() 사용 를 사용하면 쿼리에 특수 문자나 악의적인 SQL 명령이 포함될 위험을 제거하여 SQL 삽입 공격을 방지할 수 있습니다.

래핑된 원본 SQL 쿼리 작은 따옴표로 묶인 자리 표시자 역시 보안 취약점이었습니다. MySQL에서 SQL 쿼리의 올바른 형식은 필드 및 테이블 이름에 작은따옴표 대신 백틱(`)을 사용하는 것입니다. 따라서 업데이트된 SQL 쿼리는 다음과 같아야 합니다.

string SQL = "INSERT INTO `twMCUserDB` (`mc_userName`, `mc_userPass`, `tw_userName`, `tw_userPass`) VALUES (@mcUserName, @mcUserPass, @twUserName, @twUserPass)";
로그인 후 복사

위 내용은 MySQL에서 SQL 주입을 방지하기 위해 `Add()`보다 `AddWithValue()`가 선호되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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