> 데이터 베이스 > MySQL 튜토리얼 > 매개변수화된 쿼리가 Python의 SQLite 상호 작용에서 SQL 주입을 어떻게 방지할 수 있습니까?

매개변수화된 쿼리가 Python의 SQLite 상호 작용에서 SQL 주입을 어떻게 방지할 수 있습니까?

Barbara Streisand
풀어 주다: 2025-01-05 00:17:40
원래의
518명이 탐색했습니다.

How Can Parameterized Queries Prevent SQL Injection in Python's SQLite Interactions?

Python에서 SQL 주입 방지

문제:

다음과 같은 Python 스크립트가 있습니다. SQLite 데이터베이스에서 char(80) 값을 업데이트합니다. 문자열 값은 사용자로부터 직접 가져와 JSON 페이로드로 스크립트에 전달됩니다. 이 접근 방식은 SQL 주입 공격에 취약하다는 점을 알고 계실 것입니다.

해결책:

SQL 주입을 방지하려면 업데이트 작업에 매개변수화된 쿼리를 사용할 수 있습니다. 매개변수화된 쿼리를 사용하면 쿼리 문자열에 값을 직접 포함하지 않고도 SQL 문에 값을 전달할 수 있습니다. 이렇게 하면 악의적인 입력으로 인해 SQL 구문이 중단되는 것을 방지할 수 있습니다.

Python sqlite3 라이브러리는 ? 자리 표시자. 쿼리의 자리 표시자에 해당하는 값의 튜플로 값을 실행 메소드에 전달할 수 있습니다.

수정된 코드:

다음은 수정된 버전의 코드입니다. 매개변수화된 쿼리를 사용하는 setLabel 메소드:

def setLabel( self, userId, refId, label ):
    self._db.cursor().execute(
        """
        UPDATE items SET label = ? WHERE userId = ? AND refId = ?""",
        (label, userId, refId)
    )
    self._db.commit()
로그인 후 복사

매개변수화된 쿼리를 사용하면 사용자가 입력은 SQL 문의 일부가 아닌 값으로 처리되어 SQL 주입 공격을 효과적으로 방지합니다.

위 내용은 매개변수화된 쿼리가 Python의 SQLite 상호 작용에서 SQL 주입을 어떻게 방지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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