CVE-2022-21230: Incorrect Permission Assignment for Critical Resource
(updated )
Whenever an HTTP Session is parsing the body of an HTTP request, the body of the request is written to a RandomAccessFile
when the it is larger than 1024 bytes. This file is created with insecure permissions that allow its contents to be viewed by all users on the host machine. Workaround: Manually specifying the -Djava.io.tmpdir=
argument when launching Java to set the temporary directory to a directory exclusively controlled by the current user can fix this issue.
References
- github.com/JLLeitschuh/security-research/security/advisories/GHSA-2r85-x9cf-8fcg
- github.com/NanoHttpd/nanohttpd/blob/efb2ebf85a2b06f7c508aba9eaad5377e3a01e81/core/src/main/java/org/nanohttpd/protocols/http/tempfiles/DefaultTempFile.java%23L58
- github.com/NanoHttpd/nanohttpd/blob/efb2ebf85a2b06f7c508aba9eaad5377e3a01e81/core/src/main/java/org/nanohttpd/protocols/http/tempfiles/DefaultTempFileManager.java%23L60
- nvd.nist.gov/vuln/detail/CVE-2022-21230
- snyk.io/vuln/SNYK-JAVA-ORGNANOHTTPD-2422798
Detect and mitigate CVE-2022-21230 with GitLab Dependency Scanning
Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →