매개변수화된 SQL 문을 사용하는 SQLAlchemy Connection.execute()
SQLAlchemy의 Connection.execute() 메서드를 사용하면 개발자가 SQL 문을 실행하고 SQL 문을 변환할 수 있습니다. 결과는 지도 배열로 생성됩니다. 매개변수 대체에 문자열 형식을 사용하는 것은 일반적인 관행이지만 이는 보안 위험을 초래하고 유연성을 제한합니다.
코드 보안을 강화하고 매개변수화를 활성화하려면 sqlalchemy.sql.text() 함수를 활용하여 매개변수화된 매개변수를 생성할 수 있습니다. SQL문. 이 접근 방식을 사용하면 바인드 매개변수가 올바르게 처리되어 SQL 주입 공격의 위험이 줄어듭니다.
질문에 제공된 __sql_to_data() 함수에 매개변수화를 통합하려면 다음과 같이 수정하세요.
def __sql_to_data(sql_text, parameters): result = [] connection = engine.connect() try: rows = connection.execute(sql_text, parameters) for row in rows: result_row = {} for col in row.keys(): result_row[str(col)] = str(row[col]) result.append(result_row) finally: connection.close() return result
sql_text 매개변수는 sqlalchemy.sql.text()를 통해 파싱된 SQL 문이어야 하며, 매개변수 매개변수는 처리할 값이 포함된 사전입니다. 대체됩니다.
이제 매개변수를 삽입하기 위해 문자열 형식을 사용하는 대신 사전을 Execute() 메서드에 전달할 수 있습니다.
return __sql_to_data(sql_get_profile, {'user_id': user_id})
이 접근 방식은 매개변수를 전달하는 안전하고 유연한 방법을 제공합니다. SQLAlchemy의 Connection.execute() 메소드에 있는 매개변수.
위 내용은 매개변수화된 SQL 문과 함께 SQLAlchemy의 Connection.execute()를 어떻게 안전하게 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!