Starlette has possible denial-of-service vector when parsing large files in multipart forms
链接: https://github.com/advisories/GHSA-2c2j-9gv5-cj73
仓库 Star: 11259
CVSS 评分: 5.3
参考链接:
https://github.com/encode/starlette/security/advisories/GHSA-2c2j-9gv5-cj73
https://github.com/encode/starlette/commit/9f7ec2eb512fcc3fe90b43cb9dd9e1d08696bec1
https://github.com/encode/starlette/discussions/2927#discussioncomment-13721403
描述:
Summary
When parsing a multi-part form with large files (greater than the default max spool size) starlette
will block the main thread to roll the file over to disk. This blocks the event thread which means we can’t accept new connections.
Details
Please see this discussion for details: https://github.com/encode/starlette/discussions/2927#discussioncomment-13721403. In summary the following UploadFile code (copied from here) has a minor bug. Instead of just checking for self._in_memory
we should also check if the additional bytes will cause a rollover.
1 |
|
I have already created a PR which fixes the problem: https://github.com/encode/starlette/pull/2962
PoC
See the discussion here for steps on how to reproduce.
Impact
To be honest, very low and not many users will be impacted. Parsing large forms is already CPU intensive so the additional IO block doesn’t slow down starlette
that much on systems with modern HDDs/SSDs. If someone is running on tape they might see a greater impact.