* ¿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).
Las recompensas de HackenProof se lanzan solo cuando sus clientes depositan el presupuesto de recompensa. Obtendrás la recompensa después de que se verifique el error.
**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 soliciten otras aplicaciones de software, que pueden ejecutarse en la misma computadora o 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.
The first step in enumerating a Microsoft SQL Server (MSSQL) is to identify if the service is running on the target system. This can be done using various methods such as port scanning or banner grabbing.
El primer paso para enumerar un servidor Microsoft SQL (MSSQL) es identificar si el servicio está en ejecución en el sistema objetivo. Esto se puede hacer utilizando varios métodos, como el escaneo de puertos o la obtención de banners.
##### Port Scanning
##### Escaneo de Puertos
Port scanning is a technique used to discover open ports on a target system. It involves sending network packets to different ports and analyzing the responses to determine if the port is open or closed.
El escaneo de puertos es una técnica utilizada para descubrir puertos abiertos en un sistema objetivo. Implica enviar paquetes de red a diferentes puertos y analizar las respuestas para determinar si el puerto está abierto o cerrado.
##### Banner Grabbing
##### Obtención de Banners
Banner grabbing is the process of retrieving information from the banner or header of a network service. This information can provide details about the service, including the version number and other useful information for further enumeration.
La obtención de banners es el proceso de recuperar información del banner o encabezado de un servicio de red. Esta información puede proporcionar detalles sobre el servicio, incluido el número de versión y otra información útil para una enumeración adicional.
By default, MSSQL uses TCP port 1433 for communication. However, it is important to note that the port number can be changed during the installation or configuration of the MSSQL server.
De forma predeterminada, MSSQL utiliza el puerto TCP 1433 para la comunicación. Sin embargo, es importante tener en cuenta que el número de puerto puede cambiar durante la instalación o configuración del servidor MSSQL.
The SQL Server Browser service is responsible for providing information about the SQL Server instances running on the network. It listens on UDP port 1434 and can be used to enumerate the SQL Server instances and their corresponding ports.
El servicio del Explorador de SQL Server es responsable de proporcionar información sobre las instancias de SQL Server que se ejecutan en la red. Escucha en el puerto UDP 1434 y se puede utilizar para enumerar las instancias de SQL Server y sus puertos correspondientes.
Once the MSSQL service is detected, the next step is to enumerate the SQL Server instances running on the target system. This can be done using tools like `sqlcmd` or `osql` to connect to the SQL Server and retrieve a list of instances.
Una vez detectado el servicio MSSQL, el siguiente paso es enumerar las instancias de SQL Server que se ejecutan en el sistema objetivo. Esto se puede hacer utilizando herramientas como `sqlcmd` u `osql` para conectarse al servidor SQL y obtener una lista de instancias.
Knowing the version of the SQL Server can be helpful in identifying potential vulnerabilities and determining the appropriate exploitation techniques. The version information can be obtained by querying the SQL Server using tools like `sqlcmd` or by analyzing the banner information.
Saber la versión de SQL Server puede ser útil para identificar posibles vulnerabilidades y determinar las técnicas de explotación adecuadas. La información de la versión se puede obtener consultando el servidor SQL utilizando herramientas como `sqlcmd` o analizando la información del banner.
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 permisos 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.
To perform an error-based SQLi attack, the attacker needs to identify vulnerable input fields, such as login forms or search boxes, where user-supplied data is directly used in SQL queries without proper sanitization or validation. The attacker then crafts SQL statements that are designed to cause errors in the database.
One common error-based technique is to use the `CONVERT` function with an invalid data type. For example, the attacker can inject a payload like `CONVERT(INT, (SELECT @@VERSION))`, which attempts to convert the SQL Server version into an integer. If the conversion fails, an error message will be displayed, potentially revealing the version information.
Another technique is to use the `CAST` function with an invalid data type. For instance, the attacker can inject a payload like `CAST((SELECT user_name()) AS INT)`, which tries to cast the current user's name as an integer. If the casting fails, an error will be generated, potentially leaking the username.
By carefully crafting error-based payloads and analyzing the error messages, an attacker can gather valuable information about the database, such as table and column names, user credentials, and even execute arbitrary SQL statements.
It is important for developers to implement proper input validation and parameterized queries to prevent error-based SQLi attacks. Regular security assessments and penetration testing can also help identify and mitigate these vulnerabilities.
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 como `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).
Las recompensas de HackenProof se lanzan solo cuando sus clientes depositan el presupuesto de recompensa. Obtendrás la recompensa después de que se verifique el error.
Si se le otorga al **usuario regular** el rol de **`db_owner`** 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**:
**HackenProof es el hogar de todas las recompensas por errores de criptografía.**
**Obtén recompensas sin demoras**\
Las recompensas de HackenProof se lanzan solo cuando sus clientes depositan el presupuesto de recompensa. Obtendrás la recompensa después de que se verifique el error.
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).