>  기사  >  데이터 베이스  >  SQL 삽입 시 백스페이스 및 탭 문자를 이스케이프해야 합니까?

SQL 삽입 시 백스페이스 및 탭 문자를 이스케이프해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-28 04:09:30133검색

 Should Backspace and Tab Characters Be Escaped in SQL Injections?

SQL 주입에서 특수 문자 이스케이프

SQL 주입을 방지하려면 쿼리 실행을 조작할 수 있는 특정 문자를 이스케이프하는 것이 중요합니다. MySQL API의 mysql_real_escape_string() 함수에 따라 이러한 문자는 이스케이프되어야 합니다.

<pre class="brush:php;toolbar:false">0x00 : "\0",
0x08 : "\b",
0x09 : "\t",
0x0a : "\n",
0x0d : "\r",
0x1a : "\Z",
0x22 : '\"',
0x25 : "\%",
0x27 : "\'",
0x5c : "\\",
0x5f : "\_",
\n \r \ ' " \Z

그러나 OWASP.org의 Python용 ESAPI 보안 라이브러리는 인코딩 메커니즘의 다음을 포함하여 이러한 문자를 뛰어넘습니다.

SELECT a FROM b WHERE c = '...user input ...';

'%' 및 '_'와 같은 메타 문자를 이스케이프해야 하는 이유는 이해할 수 있지만 백스페이스('b') 및 표('t') 문자를 포함하면 의문이 생깁니다.

탭 문자 및 백스페이스 문자에 대한 보안 문제

탭 문자('t')

탭 문자(ASCII 코드 9)는 커서를 이동합니다. 특정 시스템에 대해 정의된 다음 탭 정지로 이동합니다. SQL 쿼리에서는 표 작성기를 사용하여 공백을 삽입하거나 데이터를 정렬할 수 있습니다. 탭 정지 설정에 따라 공격자가 쿼리를 수정하거나 공백을 삽입하여 의도하지 않은 동작을 유발할 수 있습니다.

백스페이스 문자('b')

백스페이스 문자(ASCII 코드 8)는 커서를 한 문자 뒤로 이동하여 효과적으로 덮어씁니다. SQL 쿼리에서 백스페이스를 사용하여 이전에 입력한 데이터를 삭제할 수 있으며 이로 인해 잠재적으로 삽입이나 데이터 조작이 발생할 수 있습니다.

예: 백스페이스 문자 악용

다음을 고려하세요. 쿼리:

Bobby]dor[p TA[ble[s

악의적인 사용자가 백스페이스 문자가 포함된 값을 입력하면 잠재적으로 쿼리의 일부가 지워져 의도하지 않은 동작이 발생할 수 있습니다. 예를 들어 다음 입력을 삽입하면 다음과 같습니다.

SELECT a FROM b WHERE c = 'Bobby';

백스페이스를 사용하여 "[dor[p TA[ble[s") 문자를 삭제하면 쿼리는 사실상 다음과 같습니다.

이 악성 코드는 다음과 같습니다. 입력은 잠재적으로 c가 'Bobby'인 모든 행을 반환하여 민감한 정보를 손상시킬 수 있습니다.

결론

탭 및 백스페이스 문자를 이스케이프하는 것은 일반적으로 필요하지 않을 수 있지만 SQL 삽입을 방지하기 위해 특정 시나리오에서 유용할 수 있습니다. 이러한 문자를 이스케이프함으로써 개발자는 악의적인 사용자가 잠재적인 취약점을 악용하여 SQL 쿼리를 변조하거나 손상시키지 못하도록 할 수 있습니다.

위 내용은 SQL 삽입 시 백스페이스 및 탭 문자를 이스케이프해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.