From 78eedcfdb4ca88fa99dbba41fd259bd3204fd1ea Mon Sep 17 00:00:00 2001 From: Adam Shostack <1176137+adamshostack@users.noreply.github.com> Date: Fri, 3 Jan 2025 12:03:07 +0000 Subject: [PATCH] Improved "sanitization" to "safety" (#1574) Added a few additional points about how to handle user-specified names. --- cheatsheets/File_Upload_Cheat_Sheet.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/cheatsheets/File_Upload_Cheat_Sheet.md b/cheatsheets/File_Upload_Cheat_Sheet.md index 9ed41fe211..ef8a86644c 100644 --- a/cheatsheets/File_Upload_Cheat_Sheet.md +++ b/cheatsheets/File_Upload_Cheat_Sheet.md @@ -86,7 +86,7 @@ In conjunction with [content-type validation](#content-type-validation), validat > This should not be used on its own, as bypassing it is pretty common and easy. -### Filename Sanitization +### Filename Safety Filenames can endanger the system in multiple ways, either by using non acceptable characters, or by using special and restricted filenames. For Windows, refer to the following [MSDN guide](https://docs.microsoft.com/en-us/windows/win32/fileio/naming-a-file?redirectedfrom=MSDN#naming-conventions). For a wider overview on different filesystems and how they treat files, refer to [Wikipedia's Filename page](https://en.wikipedia.org/wiki/Filename). @@ -94,6 +94,9 @@ In order to avoid the above mentioned threat, creating a **random string** as a - Implement a maximum length - Restrict characters to an allowed subset specifically, such as alphanumeric characters, hyphen, spaces, and periods + - Consider telling the user what an acceptable filename is. + - Restrict use of leading periods (hidden files) and sequential periods (directory traversal). + - Restrict the use of a leading hyphen or spaces to make it safer to use shell scripts to process files. - If this is not possible, block-list dangerous characters that could endanger the framework and system that is storing and using the files. ### File Content Validation