계: Security Features
소프트웨어 보안은 보안 소프트웨어가 아닙니다. 여기서는 인증, 액세스 제어, 기밀성, 암호화, 권한 관리 등의 항목에 대해 설명합니다.
Privacy Violation: BREACH
Abstract
응용 프로그램이 SSL/TLS 사용 채널을 통해 전송되는 HTTP 응답에 포함된 민감한 데이터를 누출할 수도 있습니다.
Explanation
BREACH(Browser Reconnaissance and Exfiltration via Adaptive Compression of Hypertext) 공격은 측면 채널 공격의 한 유형으로, 이를 통해 공격자는 SSL/TLS 사용 채널을 통해 전송되는 HTTP 응답에 포함된 민감한 정보를 훔칠 수 있습니다. 모든 기존 SSL/TLS 버전과 암호는 이 공격에 취약합니다. 다음 세 가지 조건이 충족되는 경우 공격자는 응용 프로그램에 대해 BREACH 공격을 성공적으로 수행할 수 있습니다.
1. 응용 프로그램에서 응답에 기밀 정보(예: CSRF 방지 토큰)를 전송합니다.
2. 응용 프로그램에서 기밀 정보가 포함된 응답에 사용자 입력을 보냅니다.
3. 웹 서버가 HTTP 압축을 사용하도록 구성되어 있습니다.
GZip을 사용하여 압축되는 응답의 크기는 응답 내용에서 확인된 반복 횟수에 따라 결정됩니다. 따라서 문자가 더 자주 반복될수록 응답 크기가 작아집니다. 따라서 공격자는 적용한 매개 변수 값을 통해 자신이 응용 프로그램에 대해 추측한 내용이 맞는지 아닌지 나타낼 수 있는 일종의 징후로 HTTP 압축을 활용할 수 있습니다. 추측한 문자가 기밀 정보의 해당하는 문자와 일치하면 압축되는 응답의 크기는 더 작습니다. 공격자는 이러한 프로세스를 통해 각각의 요청에 대한 압축률을 분석하여 전체 기밀 정보를 문자 단위로 확인할 수 있습니다.
공격자는 이 기법을 사용하여 응용 프로그램이 보안 채널을 통해 콘텐트를 제공하도록 구성되어 있는 경우에도 HTTP 응답에서 기밀 정보를 추출할 수 있습니다.
응용 프로그램이 BREACH 공격에 취약한지 여부를 평가하려면 먼저 해당 응용 프로그램이 HTTP 압축을 사용하도록 구성되어 있는지 확인합니다. HTTP 압축을 사용하도록 구성되어 있으면 보호해야 할 기밀 정보가 포함된 각각의 응답 내에 사용자 입력을 포함할지 여부를 평가합니다.
이 이슈가 보고되는 이유는 Django 응용 프로그램이 CSRF 토큰과 GZip 압축을 사용하도록 구성되어 있기 때문입니다.
1. 응용 프로그램에서 응답에 기밀 정보(예: CSRF 방지 토큰)를 전송합니다.
2. 응용 프로그램에서 기밀 정보가 포함된 응답에 사용자 입력을 보냅니다.
3. 웹 서버가 HTTP 압축을 사용하도록 구성되어 있습니다.
GZip을 사용하여 압축되는 응답의 크기는 응답 내용에서 확인된 반복 횟수에 따라 결정됩니다. 따라서 문자가 더 자주 반복될수록 응답 크기가 작아집니다. 따라서 공격자는 적용한 매개 변수 값을 통해 자신이 응용 프로그램에 대해 추측한 내용이 맞는지 아닌지 나타낼 수 있는 일종의 징후로 HTTP 압축을 활용할 수 있습니다. 추측한 문자가 기밀 정보의 해당하는 문자와 일치하면 압축되는 응답의 크기는 더 작습니다. 공격자는 이러한 프로세스를 통해 각각의 요청에 대한 압축률을 분석하여 전체 기밀 정보를 문자 단위로 확인할 수 있습니다.
공격자는 이 기법을 사용하여 응용 프로그램이 보안 채널을 통해 콘텐트를 제공하도록 구성되어 있는 경우에도 HTTP 응답에서 기밀 정보를 추출할 수 있습니다.
응용 프로그램이 BREACH 공격에 취약한지 여부를 평가하려면 먼저 해당 응용 프로그램이 HTTP 압축을 사용하도록 구성되어 있는지 확인합니다. HTTP 압축을 사용하도록 구성되어 있으면 보호해야 할 기밀 정보가 포함된 각각의 응답 내에 사용자 입력을 포함할지 여부를 평가합니다.
이 이슈가 보고되는 이유는 Django 응용 프로그램이 CSRF 토큰과 GZip 압축을 사용하도록 구성되어 있기 때문입니다.
MIDDLEWARE = (
...
'django.middleware.csrf.CsrfViewMiddleware',
'django.middleware.gzip.GZipMiddleware',
...
)
References
[1] BREACH Advisory
[2] Mitre CVE-2013-3587
[3] The gzip Home Page
[4] Django Foundation GZip middleware
[5] Standards Mapping - Common Weakness Enumeration CWE ID 310
[6] Standards Mapping - DISA Control Correlation Identifier Version 2 CCI-000197, CCI-002418, CCI-002420, CCI-002421, CCI-002422
[7] Standards Mapping - FIPS200 CM, SC
[8] Standards Mapping - General Data Protection Regulation (GDPR) Privacy Violation
[9] Standards Mapping - NIST Special Publication 800-53 Revision 4 AC-4 Information Flow Enforcement (P1), IA-5 Authenticator Management (P1), SC-8 Transmission Confidentiality and Integrity (P1)
[10] Standards Mapping - NIST Special Publication 800-53 Revision 5 AC-4 Information Flow Enforcement, IA-5 Authenticator Management, SC-8 Transmission Confidentiality and Integrity
[11] Standards Mapping - OWASP Application Security Verification Standard 4.0 2.6.3 Look-up Secret Verifier Requirements (L2 L3), 6.2.1 Algorithms (L1 L2 L3)
[12] Standards Mapping - OWASP Mobile 2014 M3 Insufficient Transport Layer Protection
[13] Standards Mapping - OWASP Mobile 2024 M5 Insecure Communication
[14] Standards Mapping - OWASP Top 10 2004 A10 Insecure Configuration Management
[15] Standards Mapping - OWASP Top 10 2007 A9 Insecure Communications
[16] Standards Mapping - OWASP Top 10 2010 A9 Insufficient Transport Layer Protection
[17] Standards Mapping - OWASP Top 10 2013 A5 Security Misconfiguration
[18] Standards Mapping - OWASP Top 10 2017 A3 Sensitive Data Exposure
[19] Standards Mapping - OWASP Top 10 2021 A02 Cryptographic Failures
[20] Standards Mapping - Payment Card Industry Data Security Standard Version 1.1 Requirement 6.1, Requirement 6.5.10
[21] Standards Mapping - Payment Card Industry Data Security Standard Version 1.2 Requirement 6.3.1.4, Requirement 6.5.9
[22] Standards Mapping - Payment Card Industry Data Security Standard Version 2.0 Requirement 6.5.4
[23] Standards Mapping - Payment Card Industry Data Security Standard Version 3.0 Requirement 6.5.4
[24] Standards Mapping - Payment Card Industry Data Security Standard Version 3.1 Requirement 6.5.4
[25] Standards Mapping - Payment Card Industry Data Security Standard Version 3.2 Requirement 6.5.4
[26] Standards Mapping - Payment Card Industry Data Security Standard Version 3.2.1 Requirement 6.5.4
[27] Standards Mapping - Payment Card Industry Data Security Standard Version 4.0 Requirement 6.2.4
[28] Standards Mapping - Payment Card Industry Data Security Standard Version 4.0.1 Requirement 6.2.4
[29] Standards Mapping - Payment Card Industry Software Security Framework 1.0 Control Objective 6.2 - Sensitive Data Protection
[30] Standards Mapping - Payment Card Industry Software Security Framework 1.1 Control Objective 6.2 - Sensitive Data Protection
[31] Standards Mapping - Payment Card Industry Software Security Framework 1.2 Control Objective 6.2 - Sensitive Data Protection, Control Objective C.4.1 - Web Software Communications
[32] Standards Mapping - Security Technical Implementation Guide Version 3.1 APP3250.1 CAT I, APP3260.1 CAT II
[33] Standards Mapping - Security Technical Implementation Guide Version 3.4 APP3250.1 CAT I, APP3260 CAT II
[34] Standards Mapping - Security Technical Implementation Guide Version 3.5 APP3250.1 CAT I, APP3260 CAT II
[35] Standards Mapping - Security Technical Implementation Guide Version 3.6 APP3250.1 CAT I, APP3260 CAT II
[36] Standards Mapping - Security Technical Implementation Guide Version 3.7 APP3250.1 CAT I, APP3260 CAT II
[37] Standards Mapping - Security Technical Implementation Guide Version 3.9 APP3250.1 CAT I, APP3260 CAT II
[38] Standards Mapping - Security Technical Implementation Guide Version 3.10 APP3250.1 CAT I, APP3260 CAT II
[39] Standards Mapping - Security Technical Implementation Guide Version 4.2 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[40] Standards Mapping - Security Technical Implementation Guide Version 4.3 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[41] Standards Mapping - Security Technical Implementation Guide Version 4.4 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[42] Standards Mapping - Security Technical Implementation Guide Version 4.5 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[43] Standards Mapping - Security Technical Implementation Guide Version 4.6 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[44] Standards Mapping - Security Technical Implementation Guide Version 4.7 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[45] Standards Mapping - Security Technical Implementation Guide Version 4.8 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[46] Standards Mapping - Security Technical Implementation Guide Version 4.9 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[47] Standards Mapping - Security Technical Implementation Guide Version 4.10 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[48] Standards Mapping - Security Technical Implementation Guide Version 4.11 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[49] Standards Mapping - Security Technical Implementation Guide Version 4.1 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[50] Standards Mapping - Security Technical Implementation Guide Version 5.1 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[51] Standards Mapping - Security Technical Implementation Guide Version 5.2 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[52] Standards Mapping - Security Technical Implementation Guide Version 5.3 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[53] Standards Mapping - Security Technical Implementation Guide Version 6.1 APSC-DV-001750 CAT I, APSC-DV-002440 CAT I, APSC-DV-002450 CAT II, APSC-DV-002460 CAT II, APSC-DV-002470 CAT II
[54] Standards Mapping - Web Application Security Consortium Version 2.00 Insufficient Transport Layer Protection (WASC-04)
desc.structural.python.privacy_violation_breach