데이터베이스와 상호 작용하는 코드를 테스트할 때는 사용자 입력을 적절하게 이스케이프하여 SQL 삽입 공격을 방지하는 것이 중요합니다. 그러나 모든 테스트를 위해 데이터베이스에 연결하는 것은 비효율적일 수 있습니다. 활성 데이터베이스 연결 없이 문자열을 이스케이프하는 방법이 있습니까?
안타깝게도 데이터베이스 연결 없이 문자열을 안정적으로 이스케이프하는 것은 불가능합니다. mysql_real_escape_string() 및 준비된 명령문 모두 사용 중인 문자 세트에 대한 데이터베이스의 지식에 의존합니다. 이 정보가 없으면 이스케이프 메커니즘을 우회하고 SQL 주입 취약점으로 이어지는 멀티바이트 문자 시퀀스를 만드는 것이 가능합니다.
목표가 순전히 테스트인 경우 다음을 수행할 수 있습니다. 속도와 단순성을 위해 mysql_escape_string() 사용을 고려해보세요. 완전히 안전하지는 않지만 테스트 환경에서 악용될 가능성은 거의 없습니다. 그러나 이는 프로덕션 코드에는 권장되지 않습니다.
데이터베이스 연결 없이 문자열을 이스케이프하는 방법을 찾고 싶지만 실제로는 불가능합니다. 데이터 무결성을 보장하는 유일한 방법은 데이터베이스 연결과 함께 적절한 이스케이프 기술을 사용하는 것입니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3