VDB
EN
CRITICAL 9.8

GHSA-2gr4-ppc7-7mhx

CodeIgniter4 has a validation bypass when uploading file extensions via `ext_in` rule

상세

### Impact The `ext_in` upload validation rule checked the MIME-derived guessed extension instead of the client-provided filename extension. As a result, an uploaded file named `shell.php` containing GIF-like content could pass validation such as: ``` uploaded[avatar]|is_image[avatar]|mime_in[avatar,image/gif]|ext_in[avatar,gif] ``` because the detected MIME type maps to `gif`, even though the uploaded filename extension is `php`.

Applications are impacted if they: - accept user-controlled uploads, - rely on `ext_in` to validate the uploaded filename extension, - save uploaded files using the original client filename: `$file->move($path)`, - store uploads in a web-accessible directory, - and allow PHP or other executable files to run from that directory.

In those conditions, this may lead to arbitrary code execution. The default application does not expose such an upload endpoint.

### Patches Upgrade to v4.7.3 or later.

### Workarounds - Save uploads outside the public web root, preferably under `writable/uploads` - Use `$file->store()` or `$file->move($path, $file->getRandomName())` instead of preserving the original filename - Disable script execution in any public upload directory - Manually verify the client filename extension before moving the file - Reject files when `$file->getClientExtension()` is not in the allowed list or does not match `$file->guessExtension()`

### Resources - [CodeIgniter4 uploaded files documentation](https://codeigniter.com/user_guide/libraries/uploaded_files.html#moving-files) - [CodeIgniter4 file upload validation documentation](https://codeigniter.com/user_guide/libraries/validation.html#rules-for-file-uploads) - [CWE-434: Unrestricted Upload of File with Dangerous Type](https://cwe.mitre.org/data/definitions/434.html) - [OWASP File Upload Cheat Sheet](https://cheatsheetseries.owasp.org/cheatsheets/File_Upload_Cheat_Sheet.html)

이 버전이 영향받나요?

사용 중인 패키지 버전을 입력하면 즉시 평가합니다.

영향 패키지

Packagist / codeigniter4/framework
최초 영향 버전: 0 수정 버전: 4.7.3
수정 composer require codeigniter4/framework:^4.7.3

참고