> Java > java지도 시간 > Java의 준비된 문이 MySQL에서 변수 열 이름을 안전하게 처리할 수 있습니까?

Java의 준비된 문이 MySQL에서 변수 열 이름을 안전하게 처리할 수 있습니까?

Susan Sarandon
풀어 주다: 2024-12-06 20:09:12
원래의
302명이 탐색했습니다.

Can Prepared Statements in Java Handle Variable Column Names Securely in MySQL?

준비된 문을 사용한 변수 열 이름

문제:

변수 열 이름을 지정할 수 있습니까? SQL 주입을 방지하기 위해 Java를 사용하여 MySQL에서 준비된 명령문을 활용할 때 취약점?

설명:

준비된 문은 기본 쿼리 문에서 쿼리 매개 변수를 분리하여 SQL 삽입을 방지하도록 설계되었습니다. 준비된 문을 사용하려고 하면 열 이름이 매개 변수로 인식되지 않고 대신 리터럴 값으로 쿼리에 삽입됩니다. 제공된 열 이름이 제대로 삭제되지 않으면 보안 문제가 발생할 수 있습니다.

해결책:

  • 동적 열 이름 방지: 사용자 지정 열 이름이 필요하지 않도록 데이터베이스 스키마를 다시 디자인하는 것이 좋습니다. 대신, 원하는 열 이름을 저장할 별도의 열을 생성하고 이를 쿼리에 포함하는 것을 고려해 보세요.
  • 수동 쿼리 구성 및 삭제: 동적 열 이름이 불가피한 경우 다음을 수행해야 합니다. SQL 쿼리 문자열을 직접 작성하십시오. SQL 삽입을 방지하려면 String#replace() 메서드를 사용하여 열 이름에 포함된 따옴표를 이스케이프하세요. 예:
// Sanitize the user-provided column names
String sanitizedColumns = columnNames.replace("'", "\'");

// Build the SQL query string
String query = "SELECT a,b,c,ROW_NUMBER() OVER(), " + sanitizedColumns + " FROM " + name + " WHERE d=?";

// Prepare the statement
stmt = conn.prepareStatement(query);
stmt.setString(1, "x");
로그인 후 복사

위 내용은 Java의 준비된 문이 MySQL에서 변수 열 이름을 안전하게 처리할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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