이 문서에 포함된 어떠한 내용도 불법적이거나 비윤리적인 목적으로 보안 도구나 방법론을 사용하도록 가르치거나 장려하지 않습니다. 항상 책임감 있는 태도로 행동하세요. 여기에 설명된 도구나 기법을 사용하기 전에 개인 테스트 환경 또는 허가를 받았는지 확인하세요. |
[ 환경 ]
DVWA | v1.9 |
Burp Suite | Community Edition v2024.11.2 |
이 코드는 사용자가 업로드한 파일이 JPEG 또는 PNG 이미지인지 확인한 후, 파일 크기가 100KB 미만이면 서버의 특정 디렉터리로 저장하는 간단한 파일 업로드 기능을 제공한다.
$uploaded_name = $_FILES[ 'uploaded' ][ 'name' ];
$uploaded_type = $_FILES[ 'uploaded' ][ 'type' ];
$uploaded_size = $_FILES[ 'uploaded' ][ 'size' ];
if( ( $uploaded_type == "image/jpeg" || $uploaded_type == "image/png" ) &&
( $uploaded_size < 100000 ) ) {
MIME 타입 신뢰성 부족
파일 이름 검증 부족
업로드 디렉터리 보호 부족
확장자 검증 부족
파일 크기 제한의 하드코딩
Low level에서 사용한 WebShell을 업로드하면 [그림 2]와 같이 오류가 발생하며, 애플리케이션이 파일의 유효성을 검사한다.
WebShell 파일을 업로드하기 전에 Burp Suite로 Intercept 하여 전송되는 Request를 살펴보면, [그림 3]과 같이 Content-Type이 application/octet-stream으로 되어 있는 것을 확인할 수 있다.
HTTP Content-Type은 클라이언트(브라우저 또는 기타 HTTP 클라이언트)와 서버 간의 통신에서 데이터의 MIME 타입을 지정하는 HTTP 헤더로, 서버는 이 헤더를 사용하여 클라이언트에게 전달되는 데이터가 어떤 형식인지 알린다. 클라이언트는 이 정보를 바탕으로 데이터를 적절히 처리하고 렌더링할 수 있다.
주요 구성 요소
예시 | 설명 |
Content-Type: text/html; charset=UTF-8 | 브라우저가 HTML 문서를 렌더링하도록 지시 |
Content-Type: application/json | 클라이언트가 JSON 형식의 데이터를 파싱하도록 알림 |
Content-Type: image/jpeg | 브라우저나 이미지 뷰어가 JPEG 이미지를 처리하도록 지시 |
주요 MIME 타입 목록
MIME 타입 | 설명 |
text/plain | 일반 텍스트 파일 |
text/html | HTML 문서 |
application/json | JSON 데이터 |
application/xml | XML 데이터 |
application/pdf | PDF 문서 |
image/jpeg | JPEG 이미지 |
image/png | PNG 이미지 |
video/mp4 | MP4 비디오 파일 |
audio/mpeg | MP3 오디오 파일 |
Content-Type가 중요한 이유
앞서 소스코드를에 살펴보았듯이 MIME 타입과 파일 크기를 검증하지만, 클라이언트 측에서 조작 가능한 정보를 신뢰하고 있어 보안상 취약하다. 검증을 우회하기 위해 Content-Type을 기존 application/octet-stream을 image/jpeg 또는 image/png 등 이미지 형태로 변경해서 전송한다.
Response 내용을 살펴보면 [그림 5]와 같이 파일검증을 우회하여, WebShell이 Low level에서 확인한 동일한 디렉터리에 업로드되는 것을 확인할 수 있다.
확인한 업로드 경로를 이용하여 URL을 입력하여 직접 접근하면 업로드한 WebShell을 실행할 수 있다.
DVWA : File Upload - Impossible level (0) | 2025.01.05 |
---|---|
DVWA : File Upload - High level (0) | 2025.01.05 |
DVWA : File Upload - Low level (0) | 2025.01.05 |
DVWA : File Inclusion - Impossible level (0) | 2025.01.04 |
DVWA : File Inclusion - High level (0) | 2025.01.03 |