CVE-2017-16021

MEDIUM

Garycourt Uri-js < 2.1.1 - Denial of Service

Title source: rule
STIX 2.1

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.

References (2)

Core 2
Core References
Exploit, Issue Tracking, Third Party Advisory x_refsource_misc
https://github.com/garycourt/uri-js/issues/12
Broken Link, Third Party Advisory x_refsource_misc
https://nodesecurity.io/advisories/100

Scores

CVSS v3 6.5
EPSS 0.0022
EPSS Percentile 44.1%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H

Details

CWE
CWE-1333 CWE-400
Status published
Products (2)
garycourt/uri-js < 2.1.1
npm/uri-js 0 - 3.0.0npm
Published Jun 04, 2018
Tracked Since Feb 18, 2026