@hono/node-server cannot handle "double dots" in URL
Moderate severity
GitHub Reviewed
Published
Jan 21, 2024
in
honojs/node-server
•
Updated Jan 23, 2024
Description
Published by the National Vulnerability Database
Jan 22, 2024
Published to the GitHub Advisory Database
Jan 23, 2024
Reviewed
Jan 23, 2024
Last updated
Jan 23, 2024
Impact
Since v1.3.0, we use our own Request object. This is great, but the
url
behavior 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 our Request does not resolve double dots, sohttp://localhost/static/.. /foo.txt
is returned.It will pass unresolved paths to the web application. This causes vulnerabilities like #123 when using
serveStatic
.Note: Modern web browsers and a latest
curl
command resolve double dots on the client side, so it does not affect you if the user uses them. However, problems may occur if accessed by a client that does not resolve them.Patches
"v1.4.1" includes the change to fix this issue.
Workarounds
Don't use
serveStatic
.References