CVE-2017-16021
Last modified
CVE-2017-16021 is a medium-severity vulnerability rated 6.5/10 on the CVSS scale. uri-js is a module that tries to fully implement RFC 3986. One of these features is validating whether or not a supplied URL is valid or not. EPSS estimates a 1.34% chance of exploitation in the next 30 days.
Description
uri-js is a module that tries to fully implement RFC 3986. One of these features is validating whether or not a supplied URL is valid or not. To do this, uri-js uses a regular expression, This regular expression is vulnerable to redos. This causes the program to hang and the CPU to idle at 100% usage while uri-js is trying to validate if the supplied URL is valid or not. To check if you're vulnerable, look for a call to `require("uri-js").parse()` where a user is able to send their own input. This affects uri-js 2.1.1 and earlier.
Metrics
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
Weakness Enumeration
Affected Software
| Vendor | Product | Versions |
|---|---|---|
| Garycourt | Uri-Js | <= 2.1.1 |
References
- https://github.com/garycourt/uri-js/issues/12Exploit, Issue Tracking, Third Party Advisory
- https://nodesecurity.io/advisories/100Broken Link, Third Party Advisory
- https://github.com/garycourt/uri-js/issues/12Exploit, Issue Tracking, Third Party Advisory
- https://nodesecurity.io/advisories/100Broken Link, Third Party Advisory
Timeline
- Published
- Last Modified
- Status
- Modified
Frequently Asked Questions
What is CVE-2017-16021?
How severe is CVE-2017-16021?
How do I fix CVE-2017-16021?
Are you affected by CVE-2017-16021?
Run a free Strix scan to check your systems for this vulnerability.
Scan your code nowSource: NVD / NIST
