-
-
Notifications
You must be signed in to change notification settings - Fork 424
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Adding new level in Unrestricted File upload which doesn't have a check on size of file uploaded #351
Comments
if it is complex to implement in springboot then i would suggest to add this in PHP as it is quite simple. Have a look at: https://github.com/SasanLabs/VulnerableApp-php PHP issue: SasanLabs/VulnerableApp-php#14 |
I will like to work on this also |
Noted @preetkaran20 |
@preetkaran20, could you assign this to me? I think I have a relatively clean solution. In short, I'd overwrite the spring MultipartFilter bean to provide a custom MultipartResolver implementation for a specific controller path only. All other paths would keep using the default spring resolver. Besides this, it would only need a new apache dependency to provide the basis for the custom implementation: The bean definition would be something like this:
And of course, we would need a new vulnerable endpoint for "/UnrestrictedFileUpload/LEVEL_10". I quickly tested this and it applies the default file size limits to all endpoints except the one specified above. (The above code is only a prototype, not the proposed final solution.) Thanks! |
@tkomlodi Thanks for finding the solution. Assigning the ticket to you. |
@preetkaran20, I have a question about the approach for the vulnerable endpoint. I implemented it so it accepts files with unlimited sizes and stores them in an in-memory list. This will cause the heap to run out of memory and start throwing OutOfMemoryErrors when sufficient large files have been uploaded. I went this way since saving the files to disk could cause serious issues to the system that hosts the application. E.g., I am not running the system in a container and don't want to cause my laptop to run out of disk space. I assume this could cause issues for others too. I'm not sure how scanners decide if the size of an uploaded file is unlimited, or just set to be very large. So it is possible that just simply allowing uploading unlimited sizes would be sufficient to trigger an alert, and there is no need to store them at all. Let me know what you think. |
Is your feature request related to a problem? Please describe.
Currently there is no level in Unrestricted File Upload which doesn't have a check on size of file uploaded.
Describe the solution you'd like
Adding a new level in Unrestricted File Upload with no size restriction such that it can cause DDOS in the vulnerable app.
Springboot has a default limit so we need to disable that limit using the following link: https://stackoverflow.com/questions/40271484/spring-upload-file-size-limit.
If we disable using application.properties then it will be applicable to all the levels but we don't want to disable to all the levels.
Adding new level is very easy, you just copy a level from above and then add the details to it. For information on what does each annotation/property does, look at: https://github.com/SasanLabs/VulnerableApp/blob/master/src/main/resources/sampleVulnerability/sampleVulnerability/SampleVulnerability.java#L86 javadocs and also https://sasanlabs.github.io/VulnerableApp/DesignDocumentation.html#design.
The text was updated successfully, but these errors were encountered: