10 KiB
Aprende hacking en AWS de cero a héroe con htARTE (Experto en Red de HackTricks en AWS)!
Otras formas de apoyar a HackTricks:
- Si deseas ver tu empresa anunciada en HackTricks o descargar HackTricks en PDF Consulta los PLANES DE SUSCRIPCIÓN!
- Obtén la merchandising oficial de PEASS & HackTricks
- Descubre La Familia PEASS, nuestra colección exclusiva de NFTs
- Únete al 💬 grupo de Discord o al grupo de telegram o síguenos en Twitter 🐦 @hacktricks_live.
- Comparte tus trucos de hacking enviando PRs a los HackTricks y HackTricks Cloud repositorios de github.
Marcas de tiempo
Un atacante puede estar interesado en cambiar las marcas de tiempo de los archivos para evitar ser detectado.
Es posible encontrar las marcas de tiempo dentro del MFT en los atributos $STANDARD_INFORMATION
__ y __ $FILE_NAME
.
Ambos atributos tienen 4 marcas de tiempo: Modificación, acceso, creación y modificación del registro MFT (MACE o MACB).
El explorador de Windows y otras herramientas muestran la información de $STANDARD_INFORMATION
.
TimeStomp - Herramienta anti-forense
Esta herramienta modifica la información de la marca de tiempo dentro de $STANDARD_INFORMATION
pero no la información dentro de $FILE_NAME
. Por lo tanto, es posible identificar actividades sospechosas.
Usnjrnl
El Diario USN (Diario de Número de Secuencia de Actualización) es una característica del NTFS (sistema de archivos de Windows NT) que realiza un seguimiento de los cambios de volumen. La herramienta UsnJrnl2Csv permite examinar estos cambios.
La imagen anterior es la salida mostrada por la herramienta donde se puede observar que se realizaron algunos cambios al archivo.
$LogFile
Todos los cambios de metadatos en un sistema de archivos se registran en un proceso conocido como registro de escritura anticipada. Los metadatos registrados se mantienen en un archivo llamado **$LogFile**
, ubicado en el directorio raíz de un sistema de archivos NTFS. Herramientas como LogFileParser se pueden utilizar para analizar este archivo e identificar cambios.
Nuevamente, en la salida de la herramienta es posible ver que se realizaron algunos cambios.
Utilizando la misma herramienta es posible identificar a qué hora se modificaron las marcas de tiempo:
- CTIME: Hora de creación del archivo
- ATIME: Hora de modificación del archivo
- MTIME: Modificación del registro MFT del archivo
- RTIME: Hora de acceso al archivo
Comparación de $STANDARD_INFORMATION
y $FILE_NAME
Otra forma de identificar archivos modificados sospechosos sería comparar la hora en ambos atributos en busca de inconsistencias.
Nanosegundos
Las marcas de tiempo de NTFS tienen una precisión de 100 nanosegundos. Por lo tanto, encontrar archivos con marcas de tiempo como 2010-10-10 10:10:00.000:0000 es muy sospechoso.
SetMace - Herramienta anti-forense
Esta herramienta puede modificar ambos atributos $STARNDAR_INFORMATION
y $FILE_NAME
. Sin embargo, a partir de Windows Vista, es necesario tener un sistema operativo en vivo para modificar esta información.
Ocultación de datos
NTFS utiliza un clúster y el tamaño mínimo de información. Esto significa que si un archivo ocupa un clúster y medio, el medio restante nunca se utilizará hasta que se elimine el archivo. Por lo tanto, es posible ocultar datos en este espacio vacío.
Existen herramientas como slacker que permiten ocultar datos en este espacio "oculto". Sin embargo, un análisis del $logfile
y $usnjrnl
puede mostrar que se agregaron datos:
Entonces, es posible recuperar el espacio vacío utilizando herramientas como FTK Imager. Ten en cuenta que este tipo de herramienta puede guardar el contenido de forma obfuscada o incluso encriptada.
UsbKill
Esta es una herramienta que apagará la computadora si se detecta algún cambio en los puertos USB.
Una forma de descubrir esto sería inspeccionar los procesos en ejecución y revisar cada script de Python en ejecución.
Distribuciones de Linux en vivo
Estas distribuciones se ejecutan dentro de la memoria RAM. La única forma de detectarlas es en caso de que el sistema de archivos NTFS esté montado con permisos de escritura. Si está montado solo con permisos de lectura, no será posible detectar la intrusión.
Eliminación segura
https://github.com/Claudio-C/awesome-data-sanitization
Configuración de Windows
Es posible deshabilitar varios métodos de registro de Windows para dificultar mucho la investigación forense.
Deshabilitar marcas de tiempo - UserAssist
Esta es una clave del registro que mantiene las fechas y horas en que se ejecutó cada ejecutable por el usuario.
Deshabilitar UserAssist requiere dos pasos:
- Establecer dos claves del registro,
HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\Start_TrackProgs
yHKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\Start_TrackEnabled
, ambos en cero para indicar que queremos deshabilitar UserAssist. - Limpiar las subramas de tu registro que se parecen a
HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\UserAssist\<hash>
.
Deshabilitar marcas de tiempo - Prefetch
Esto guardará información sobre las aplicaciones ejecutadas con el objetivo de mejorar el rendimiento del sistema Windows. Sin embargo, esto también puede ser útil para prácticas forenses.
- Ejecutar
regedit
- Seleccionar la ruta de archivo
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SessionManager\Memory Management\PrefetchParameters
- Hacer clic derecho en tanto
EnablePrefetcher
comoEnableSuperfetch
- Seleccionar Modificar en cada uno de estos para cambiar el valor de 1 (o 3) a 0
- Reiniciar
Deshabilitar marcas de tiempo - Hora de último acceso
Cada vez que se abre una carpeta desde un volumen NTFS en un servidor Windows NT, el sistema toma tiempo para actualizar un campo de marca de tiempo en cada carpeta listada, llamado la hora de último acceso. En un volumen NTFS muy utilizado, esto puede afectar el rendimiento.
- Abrir el Editor del Registro (Regedit.exe).
- Navegar a
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem
. - Buscar
NtfsDisableLastAccessUpdate
. Si no existe, agregar este DWORD y establecer su valor en 1, lo que deshabilitará el proceso. - Cerrar el Editor del Registro y reiniciar el servidor.
Eliminar historial USB
Todas las Entradas de Dispositivos USB se almacenan en el Registro de Windows bajo la clave del registro USBSTOR que contiene subclaves que se crean cada vez que conectas un Dispositivo USB a tu PC o portátil. Puedes encontrar esta clave aquí HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USBSTOR
. Al eliminar esto eliminarás el historial USB.
También puedes usar la herramienta USBDeview para asegurarte de haberlos eliminado (y para eliminarlos).
Otro archivo que guarda información sobre los USB es el archivo setupapi.dev.log
dentro de C:\Windows\INF
. Este también debería ser eliminado.
Deshabilitar Copias de sombra
Listar las copias de sombra con vssadmin list shadowstorage
Eliminar ejecutando vssadmin delete shadow
También puedes eliminarlas a través de la GUI siguiendo los pasos propuestos en https://www.ubackup.com/windows-10/how-to-delete-shadow-copies-windows-10-5740.html
Para deshabilitar las copias de sombra pasos desde aquí:
- Abrir el programa Servicios escribiendo "servicios" en el cuadro de búsqueda de texto después de hacer clic en el botón de inicio de Windows.
- En la lista, encontrar "Copia de sombra de volumen", seleccionarla y luego acceder a Propiedades haciendo clic derecho.
- Elegir Deshabilitado en el menú desplegable "Tipo de inicio" y luego confirmar el cambio haciendo clic en Aplicar y Aceptar.
También es posible modificar la configuración de qué archivos se van a copiar en la copia de sombra en el registro HKLM\SYSTEM\CurrentControlSet\Control\BackupRestore\FilesNotToSnapshot
Sobrescribir archivos eliminados
- Puedes usar una herramienta de Windows:
cipher /w:C
Esto indicará a cipher que elimine cualquier dato del espacio de disco no utilizado disponible dentro de la unidad C. - También puedes usar herramientas como Eraser
Eliminar registros de eventos de Windows
- Windows + R --> eventvwr.msc --> Expandir "Registros de Windows" --> Hacer clic derecho en cada categoría y seleccionar "Borrar registro"
for /F "tokens=*" %1 in ('wevtutil.exe el') DO wevtutil.exe cl "%1"
Get-EventLog -LogName * | ForEach { Clear-EventLog $_.Log }
Deshabilitar registros de eventos de Windows
reg add 'HKLM\SYSTEM\CurrentControlSet\Services\eventlog' /v Start /t REG_DWORD /d 4 /f
- Dentro de la sección de servicios, deshabilitar el servicio "Registro de eventos de Windows"
WEvtUtil.exec clear-log
oWEvtUtil.exe cl
Deshabilitar $UsnJrnl
fsutil usn deletejournal /d c: