* ¿Trabajas en una **empresa de ciberseguridad**? ¿Quieres ver tu **empresa anunciada en HackTricks**? ¿O quieres tener acceso a la **última versión de PEASS o descargar HackTricks en PDF**? ¡Consulta los [**PLANES DE SUSCRIPCIÓN**](https://github.com/sponsors/carlospolop)!
* Descubre [**The PEASS Family**](https://opensea.io/collection/the-peass-family), nuestra colección exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family)
* Obtén el [**swag oficial de PEASS y HackTricks**](https://peass.creator-spring.com)
* **Únete al** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo de Discord**](https://discord.gg/hRep4RUj7f) o al [**grupo de Telegram**](https://t.me/peass) o **sígueme** en **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks\_live)**.**
* **Comparte tus trucos de hacking enviando PRs al** [**repositorio de hacktricks**](https://github.com/carlospolop/hacktricks) **y al** [**repositorio de hacktricks-cloud**](https://github.com/carlospolop/hacktricks-cloud).
Encuentra las vulnerabilidades que más importan para que puedas solucionarlas más rápido. Intruder rastrea tu superficie de ataque, realiza escaneos proactivos de amenazas, encuentra problemas en toda tu pila tecnológica, desde APIs hasta aplicaciones web y sistemas en la nube. [**Pruébalo gratis**](https://www.intruder.io/?utm\_source=referral\&utm\_campaign=hacktricks) hoy.
**Microsoft SQL Server** es un sistema de gestión de bases de datos relacionales desarrollado por Microsoft. Como servidor de bases de datos, es un producto de software con la función principal de almacenar y recuperar datos según lo solicitado por otras aplicaciones de software, que pueden ejecutarse tanto en la misma computadora como en otra computadora a través de una red (incluida Internet).\
* **Base de datos model**: Se utiliza como plantilla para todas las bases de datos creadas en la instancia de SQL Server. Las modificaciones realizadas en la base de datos model, como el tamaño de la base de datos, la intercalación, el modelo de recuperación y otras opciones de la base de datos, se aplican a todas las bases de datos creadas posteriormente.
* **Base de datos Resource**: Es una base de datos de solo lectura que contiene objetos del sistema que se incluyen con SQL Server. Los objetos del sistema se almacenan físicamente en la base de datos Resource, pero aparecen lógicamente en el esquema sys de cada base de datos.
* **Base de datos tempdb**: Es un espacio de trabajo para almacenar objetos temporales o conjuntos de resultados intermedios.
Si **no tienes****credenciales**, puedes intentar adivinarlas. Puedes usar nmap o metasploit. Ten cuidado, puedes **bloquear cuentas** si fallas al iniciar sesión varias veces usando un nombre de usuario existente.
When conducting a penetration test on a Microsoft SQL Server (MSSQL), it is important to perform thorough enumeration to gather information about the target system. This information will help in identifying potential vulnerabilities and weaknesses that can be exploited.
Durante la realización de una prueba de penetración en un servidor Microsoft SQL (MSSQL), es importante realizar una enumeración exhaustiva para recopilar información sobre el sistema objetivo. Esta información ayudará a identificar posibles vulnerabilidades y debilidades que se pueden explotar.
The first step in the enumeration process is to identify the MSSQL service running on the target system. This can be done using various tools and techniques such as port scanning and banner grabbing.
El primer paso en el proceso de enumeración es identificar el servicio MSSQL que se ejecuta en el sistema objetivo. Esto se puede hacer utilizando varias herramientas y técnicas, como el escaneo de puertos y la obtención de banners.
Port scanning involves scanning the target system's ports to determine which ones are open and listening for incoming connections. This can be done using tools like Nmap or Masscan.
El escaneo de puertos implica escanear los puertos del sistema objetivo para determinar cuáles están abiertos y escuchando conexiones entrantes. Esto se puede hacer utilizando herramientas como Nmap o Masscan.
Banner grabbing is the process of retrieving information from the banner or header of a network service. This can be done using tools like Telnet or specialized banner grabbing tools.
La obtención de banners es el proceso de recuperar información del banner o encabezado de un servicio de red. Esto se puede hacer utilizando herramientas como Telnet o herramientas especializadas de obtención de banners.
Once the MSSQL service is identified, the next step is to determine the version of MSSQL running on the target system. This information is crucial as different versions may have different vulnerabilities and attack vectors.
Una vez identificado el servicio MSSQL, el siguiente paso es determinar la versión de MSSQL que se ejecuta en el sistema objetivo. Esta información es crucial, ya que diferentes versiones pueden tener diferentes vulnerabilidades y vectores de ataque.
The SQL Server Browser service is responsible for providing information about the SQL Server instances running on a network. It listens on UDP port 1434 and can be used to enumerate the SQL Server instances on the target system.
El servicio SQL Server Browser es responsable de proporcionar información sobre las instancias de SQL Server que se ejecutan en una red. Escucha en el puerto UDP 1434 y se puede utilizar para enumerar las instancias de SQL Server en el sistema objetivo.
Once the SQL Server instances are identified, the next step is to enumerate the databases and other objects within each instance. This can be done using tools like SQLPing or by querying the SQL Server using SQL commands.
Una vez identificadas las instancias de SQL Server, el siguiente paso es enumerar las bases de datos y otros objetos dentro de cada instancia. Esto se puede hacer utilizando herramientas como SQLPing o consultando el servidor SQL utilizando comandos SQL.
##### User Enumeration
##### Enumeración de Usuarios
User enumeration involves identifying the users present in the SQL Server instance. This can be done by querying the system tables or by using tools like Metasploit.
La enumeración de usuarios implica identificar los usuarios presentes en la instancia de SQL Server. Esto se puede hacer consultando las tablas del sistema o utilizando herramientas como Metasploit.
If the usernames are known, password cracking can be attempted to gain unauthorized access to the SQL Server instance. This can be done using tools like John the Ripper or Hashcat.
Si se conocen los nombres de usuario, se puede intentar descifrar las contraseñas para obtener acceso no autorizado a la instancia de SQL Server. Esto se puede hacer utilizando herramientas como John the Ripper o Hashcat.
Thorough enumeration is a critical step in the penetration testing process for MSSQL. It helps in identifying potential vulnerabilities and weaknesses that can be exploited to gain unauthorized access to the target system.
La enumeración exhaustiva es un paso crítico en el proceso de prueba de penetración para MSSQL. Ayuda a identificar posibles vulnerabilidades y debilidades que se pueden explotar para obtener acceso no autorizado al sistema objetivo.
SELECT * FROM <databaseName>.INFORMATION_SCHEMA.TABLES;
#List Linked Servers
EXEC sp_linkedservers
SELECT * FROM sys.servers;
#List users
select sp.name as login, sp.type_desc as login_type, sl.password_hash, sp.create_date, sp.modify_date, case when sp.is_disabled = 1 then 'Disabled' else 'Enabled' end as status from sys.server_principals sp left join sys.sql_logins sl on sp.principal_id = sl.principal_id where sp.type not in ('G', 'R') order by sp.name;
#Create user with sysadmin privs
CREATE LOGIN hacker WITH PASSWORD = 'P@ssword123!'
1.**Securable:** Estos son los recursos a los que el sistema de autorización del motor de base de datos de SQL Server controla el acceso. Hay tres categorías más amplias en las que se puede diferenciar un securable:
* Servidor: por ejemplo, bases de datos, inicios de sesión, puntos de conexión, grupos de disponibilidad y roles de servidor.
* Base de datos: por ejemplo, roles de base de datos, roles de aplicación, esquema, certificado, catálogo de texto completo, usuario.
* Esquema: por ejemplo, tabla, vista, procedimiento, función, sinónimo.
2.**Permiso:** Cada securable de SQL Server tiene permisos asociados como ALTER, CONTROL, CREATE que se pueden otorgar a un principal. Los permisos se administran a nivel de servidor utilizando inicios de sesión y a nivel de base de datos utilizando usuarios.
3.**Principal:** La entidad que recibe permiso para un securable se llama principal. Los principales más comunes son los inicios de sesión y los usuarios de la base de datos. El acceso a un securable se controla otorgando o denegando permisos o agregando inicios de sesión y usuarios a roles que tienen acceso.
Ten en cuenta que para poder ejecutar comandos no solo es necesario tener **`xp_cmdshell`** **habilitado**, sino también tener el **permiso EXECUTE en el procedimiento almacenado `xp_cmdshell`**. Puedes obtener quién (excepto los sysadmins) puede usar **`xp_cmdshell`** con:
[**Lee este artículo**](../../windows-hardening/active-directory-methodology/abusing-ad-mssql.md) **para obtener más información sobre cómo abusar de esta característica:**
Para escribir archivos usando `MSSQL`, **necesitamos habilitar** [**Ole Automation Procedures**](https://docs.microsoft.com/en-us/sql/database-engine/configure-windows/ole-automation-procedures-server-configuration-option), lo cual requiere privilegios de administrador, y luego ejecutar algunos procedimientos almacenados para crear el archivo:
Por defecto, `MSSQL` permite la lectura de archivos en cualquier sistema operativo al que la cuenta tenga acceso de lectura. Podemos utilizar la siguiente consulta SQL:
SELECT * FROM OPENROWSET(BULK N'C:/Windows/System32/drivers/etc/hosts', SINGLE_CLOB) AS Contents
```
Sin embargo, la opción **`BULK`** requiere el permiso **`ADMINISTER BULK OPERATIONS`** o el permiso **`ADMINISTER DATABASE BULK OPERATIONS`**.
```sql
# Check if you have it
SELECT * FROM fn_my_permissions(NULL, 'SERVER') WHERE permission_name='ADMINISTER BULK OPERATIONS' OR permission_name='ADMINISTER DATABASE BULK OPERATIONS';
The error-based vector for SQLi is a technique used to exploit vulnerabilities in Microsoft SQL Server (MSSQL). It involves injecting malicious SQL statements into user input fields to trigger errors in the database. These errors can reveal valuable information about the database structure and data, which can be used to further exploit the system. By carefully crafting SQL queries that generate specific error messages, an attacker can gain unauthorized access to the database and perform various malicious actions. It is important for security professionals to be aware of this technique and take necessary measures to protect against SQL injection attacks.
MSSQL te permite ejecutar **scripts en Python y/o R**. Este código será ejecutado por un **usuario diferente** al que utiliza **xp\_cmdshell** para ejecutar comandos.
Microsoft SQL Server proporciona **múltiples procedimientos almacenados extendidos** que te permiten interactuar no solo con la red, sino también con el sistema de archivos e incluso el [**Registro de Windows**](https://blog.waynesheffield.com/wayne/archive/2017/08/working-registry-sql-server/)**:**
EXECUTE master.sys.xp_instance_regwrite 'HKEY_LOCAL_MACHINE', 'Software\Microsoft\MSSQLSERVER\SQLServerAgent\MyNewKey', 'MyNewValue', 'REG_SZ', 'Now you see me!';
### RCE con Función Definida por el Usuario de MSSQL - SQLHttp <a href="#mssql-user-defined-function-sqlhttp" id="mssql-user-defined-function-sqlhttp"></a>
Es posible **cargar un archivo .NET dll dentro de MSSQL con funciones personalizadas**. Sin embargo, esto **requiere acceso a `dbo`**, por lo que necesitas una conexión con la base de datos **como `sa` o con un rol de administrador**.
Existen otros métodos para obtener la ejecución de comandos, como agregar [procedimientos almacenados extendidos](https://docs.microsoft.com/en-us/sql/relational-databases/extended-stored-procedures-programming/adding-an-extended-stored-procedure-to-sql-server), [Ensamblados CLR](https://docs.microsoft.com/en-us/dotnet/framework/data/adonet/sql/introduction-to-sql-server-clr-integration), [Trabajos del Agente de SQL Server](https://docs.microsoft.com/en-us/sql/ssms/agent/schedule-a-job?view=sql-server-ver15) y [scripts externos](https://docs.microsoft.com/en-us/sql/relational-databases/system-stored-procedures/sp-execute-external-script-transact-sql).
Encuentra las vulnerabilidades que más importan para que puedas solucionarlas más rápido. Intruder rastrea tu superficie de ataque, realiza escaneos de amenazas proactivos, encuentra problemas en toda tu pila tecnológica, desde APIs hasta aplicaciones web y sistemas en la nube. [**Pruébalo gratis**](https://www.intruder.io/?utm\_source=referral\&utm\_campaign=hacktricks) hoy.
Si se le otorga el rol de **`db_owner`** a un **usuario regular** sobre la **base de datos propiedad de un usuario administrador** (como **`sa`**) y esa base de datos está configurada como **`trustworthy`**, ese usuario puede abusar de estos privilegios para **elevar sus privilegios** porque los procedimientos almacenados creados allí pueden **ejecutarse** como el propietario (**administrador**).
SQL Server tiene un permiso especial llamado **`IMPERSONATE`**, que **permite al usuario que lo ejecuta asumir los permisos de otro usuario** o inicio de sesión hasta que se restablezca el contexto o finalice la sesión.
```sql
# Find users you can impersonate
SELECT distinct b.name
FROM sys.server_permissions a
INNER JOIN sys.server_principals b
ON a.grantor_principal_id = b.principal_id
WHERE a.permission_name = 'IMPERSONATE'
# Check if the user "sa" or any other high privileged user is mentioned
# Impersonate sa user
EXECUTE AS LOGIN = 'sa'
SELECT SYSTEM_USER
SELECT IS_SRVROLEMEMBER('sysadmin')
```
{% hint style="info" %}
Si puedes hacerse pasar por un usuario, incluso si no es sysadmin, debes verificar **si el usuario tiene acceso** a otras **bases de datos** o servidores vinculados.
{% endhint %}
Ten en cuenta que una vez que eres sysadmin, puedes hacerse pasar por cualquier otro usuario:
```sql
-- Impersonate RegUser
EXECUTE AS LOGIN = 'RegUser'
-- Verify you are now running as the the MyUser4 login
SELECT SYSTEM_USER
SELECT IS_SRVROLEMEMBER('sysadmin')
-- Change back to sa
REVERT
```
Puedes realizar este ataque con un módulo de **metasploit**:
Encuentra las vulnerabilidades que más importan para que puedas solucionarlas más rápido. Intruder rastrea tu superficie de ataque, realiza escaneos de amenazas proactivas, encuentra problemas en toda tu infraestructura tecnológica, desde APIs hasta aplicaciones web y sistemas en la nube. [**Pruébalo gratis**](https://www.intruder.io/?utm\_source=referral\&utm\_campaign=hacktricks) hoy.
Microsoft SQL Server is a relational database management system developed by Microsoft. As a database server, it is a software product with the primary function of storing and retrieving data as requested by other software applications—which may run either on the same computer or on another computer across a network (including the Internet).
* ¿Trabajas en una **empresa de ciberseguridad**? ¿Quieres ver tu **empresa anunciada en HackTricks**? ¿O quieres tener acceso a la **última versión de PEASS o descargar HackTricks en PDF**? ¡Consulta los [**PLANES DE SUSCRIPCIÓN**](https://github.com/sponsors/carlospolop)!
* Descubre [**La Familia PEASS**](https://opensea.io/collection/the-peass-family), nuestra colección exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family)
* Obtén el [**merchandising oficial de PEASS y HackTricks**](https://peass.creator-spring.com)
* **Únete al** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo de Discord**](https://discord.gg/hRep4RUj7f) o al [**grupo de Telegram**](https://t.me/peass) o **sígueme** en **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks\_live)**.**
* **Comparte tus trucos de hacking enviando PRs al** [**repositorio de hacktricks**](https://github.com/carlospolop/hacktricks) **y al** [**repositorio de hacktricks-cloud**](https://github.com/carlospolop/hacktricks-cloud).