CVE-2024-23340: Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal')
@hono/node-server is an adapter that allows users to run Hono applications on Node.js. Since v1.3.0, @hono/node-server has used its own Request object with url
behavior that is unexpected. In the standard API, if the URL contains ..
, here called “double dots”, the URL string returned by Request will be in the resolved path. However, the url
in @hono/node-server’s Request as does not resolve double dots, so http://localhost/static/.. /foo.txt
is returned. This causes vulnerabilities when using serveStatic
. Modern web browsers and a latest curl
command resolve double dots on the client side, so this issue does not affect those using either of those tools. However, problems may occur if accessed by a client that does not resolve them. Version 1.4.1 includes the change to fix this issue. As a workaround, don’t use serveStatic
.
References
- github.com/advisories/GHSA-rjq5-w47x-x359
- github.com/honojs/node-server/blob/8cea466fd05e6d2e99c28011fc0e2c2d3f3397c9/src/request.ts
- github.com/honojs/node-server/commit/dd9b9a9b23e3896403c90a740e7f1f0892feb402
- github.com/honojs/node-server/security/advisories/GHSA-rjq5-w47x-x359
- nvd.nist.gov/vuln/detail/CVE-2024-23340
Detect and mitigate CVE-2024-23340 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 →