주석이 있는 INSERT 문에 대한 SQL 주입
웹 애플리케이션을 개발할 때 다음과 같은 안전한 작업에서도 SQL 주입을 방지하는 것이 중요합니다. 사용자 입력을 포함하는 INSERT 문.
이 특정 시나리오에서는 설문조사 웹 양식에 다음 항목에 대한 텍스트 상자가 포함되어 있습니다. 주석, 주석 입력이 안전하게 처리되지 않으면 실제로 SQL 주입이 발생할 수 있습니다. 사용자가 다음과 같은 악성 댓글을 제출했다고 가정해 보겠습니다.
'); DELETE FROM users; --
이 댓글을 삽입하기 위한 SQL 문이 단순하게 구성되면 모든 사용자 기록이 무단으로 삭제될 수 있습니다.
INSERT INTO COMMENTS VALUES(123, '"); DELETE FROM users; -- ');
이러한 공격을 방지하려면 사용자 입력을 쿼리 문자열에 연결하지 않는 매개변수화된 SQL 문을 사용하는 것이 중요합니다. .NET 2.0에서는 매개변수와 함께 SqlCommand 클래스를 활용할 수 있습니다. 예를 들면 다음과 같습니다.
string comment = "..."; // User input int id = 123; string sql = "INSERT INTO COMMENTS (ID, Comment) VALUES (@id, @comment)"; SqlCommand command = new SqlCommand(sql, connection); command.Parameters.AddWithValue("@id", id); command.Parameters.AddWithValue("@comment", comment); command.ExecuteNonQuery();
매개변수화된 SQL 문을 사용하면 좋은 코딩 방법을 유지할 수 있습니다. SQL 주입을 방지하고 설문조사 웹 페이지에서 무단 데이터 조작을 방지합니다.
위 내용은 사용자 설명이 있는 경우에도 INSERT 문에서 SQL 주입이 어떻게 발생할 수 있으며 어떻게 방지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!