File Upload vulnerability in ChestnutCMS through 1.5.0. Based on the code analysis, it was determined that the /api/member/avatar API endpoint receives a base64 string as input. This string is then passed to the memberService.uploadAvatarByBase64 method for processing. Within the service, the base64-encoded image is parsed. For example, given a string like: data:image/html;base64,PGh0bWw+PGltZyBzcmM9eCBvbmVycm9yPWFsZXJ0KDEpPjwvaHRtbD4= the content after the comma is extracted and decoded using Base64.getDecoder().decode(). The substring from the 11th character up to the first occurrence of a semicolon (;) is assigned to the suffix variable (representing the file extension). The decoded content is then written to a file. However, the file extension is not validated, and since this functionality is exposed to the frontend, it poses significant security risks.
                
            Metrics
Affected Vendors & Products
References
        History
                    Mon, 21 Apr 2025 17:30:00 +0000
| Type | Values Removed | Values Added | 
|---|---|---|
| First Time appeared | 1000mz 1000mz chestnutcms | |
| CPEs | cpe:2.3:a:1000mz:chestnutcms:*:*:*:*:*:*:*:* | |
| Vendors & Products | 1000mz 1000mz chestnutcms | 
Tue, 14 Jan 2025 21:15:00 +0000
| Type | Values Removed | Values Added | 
|---|---|---|
| Weaknesses | CWE-434 | |
| Metrics | cvssV3_1 
 
 | 
Mon, 06 Jan 2025 18:00:00 +0000
| Type | Values Removed | Values Added | 
|---|---|---|
| Description | File Upload vulnerability in ChestnutCMS through 1.5.0. Based on the code analysis, it was determined that the /api/member/avatar API endpoint receives a base64 string as input. This string is then passed to the memberService.uploadAvatarByBase64 method for processing. Within the service, the base64-encoded image is parsed. For example, given a string like: data:image/html;base64,PGh0bWw+PGltZyBzcmM9eCBvbmVycm9yPWFsZXJ0KDEpPjwvaHRtbD4= the content after the comma is extracted and decoded using Base64.getDecoder().decode(). The substring from the 11th character up to the first occurrence of a semicolon (;) is assigned to the suffix variable (representing the file extension). The decoded content is then written to a file. However, the file extension is not validated, and since this functionality is exposed to the frontend, it poses significant security risks. | |
| References |  | 
 MITRE
                        MITRE
                    Status: PUBLISHED
Assigner: mitre
Published: 2025-01-06T00:00:00
Updated: 2025-01-14T20:50:37.356Z
Reserved: 2025-01-02T00:00:00
Link: CVE-2024-56828
 Vulnrichment
                        Vulnrichment
                    Updated: 2025-01-14T20:49:50.983Z
 NVD
                        NVD
                    Status : Analyzed
Published: 2025-01-06T18:15:23.467
Modified: 2025-04-21T17:10:54.567
Link: CVE-2024-56828
 Redhat
                        Redhat
                    No data.