Alternate Data Streams
Los Flujos Alternativos de Datos, Alternate Data Streams o ADS son una característica del sistema de archivos NTFS que permite almacenar metainformación con un fichero, sin necesidad de usar un fichero separado para almacenarla.
Implementación
editarEn 1993, Microsoft lanzó la primera versión del sistema operativo Windows NT que introdujo el sistema de archivos NTFS con soporte de ADS que fueron creados para soportar los forks nativos de los sistemas Macintosh, el sistema de archivos extended file attributes y para guardar información de permisos estilo Unix para programas POSIX. Estos usos aún continúan vigentes.[1]
Usos
editarEl uso de metadatos asociados a un fichero es imprescindible en sistemas operativos de esas características, permite saber de donde proviene un archivo, donde más se ha usado y muchas otras características asociadas con el fichero. Por ejemplo: a partir de Windows XP, cuando se descarga un fichero ejecutable desde Internet se crea un ADS llamado Zone.Identifier que contiene el identificador de la zona de Internet desde donde se ha descargado el fichero. Esta información es utilizada luego por Windows Explorer para decidir si muestra o no una advertencia al tratar de ejecutar el programa.[2]
Otro ejemplo es el del software antivirus kaspersky que utiliza o utilizaba la tecnología iStreams para guardar en cada archivo escaneado un ADS con los resultados y de esa forma saber en un escaneo futuro cual era la situación de ese fichero[3]
Limitaciones
editarUn administrador puede añadir esta característica a casi todos los ficheros del sistema mientras que un usuario normal se limitará solo a los ficheros y directorios en donde tenga acceso de escritura. Por defecto los ADS solo sirven en volúmenes NTFS, a través de una red de área local es posible enviar ficheros con ADS, mientras que los volúmenes intermedios tengan el sistema de archivos NTFS.
Resulta imposible mandar un fichero con su metadato asociado ya que Internet solo envía el flujo de datos únicamente y se pierden los metadatos asociados en el sistema de archivos original.[4]
Uso práctico
editarLa forma más común de usar los ADS es mediante la shell de Windows.
Crear un archivo de texto normal:
echo texto dentro del archivo >archivo.txt
Crear un ADS de archivo.txt:
echo flujo alternativo de datos de archivo >archivo.txt:flujo.txt
La forma normal de ver un archivo de texto por consola es usando el comando type de esta manera:
type archivo.txt texto dentro del archivo
Sin embargo, no sirve con los ADS
type archivo.txt:flujo.txt The filename, directory name, or volume label syntax is incorrect.
Para poder ver el flujo alternativo de datos es necesario utilizar el comando more de esta manera:
more < archivo.txt:flujo.txt flujo alternativo de datos de archivo
También es posible editar el flujo alternativo de datos mediante un editor de texto gráfico como en Bloc de notas de Windows, solo que hay que abrirlo por consola de esta manera:
notepad archivo.txt:flujo.txt
También es posible que un fichero posea más de un ADS sin que modifiquen el tamaño del fichero contenedor y que este sea de otro formato (no solo archivos de texto).
Uso de ADS en GNU/Linux
editarEsto es posible mediante NTFS-3G, un software para leer particiones NTFS desde GNU/Linux, por defecto NTFS-3G solo lee y escribe los flujos de datos sin nombre, para acceder los flujos secundarios se debe montar el sistema de archivos con la opción:[5]
streams_interface=windows
Defectos de los ADS
editarBásicamente los ADS funcionan de manera correcta y constan de buena documentación oficial, el único problema es que son totalmente ocultos y es una característica que un usuario malintencionado puede usar en contra de la seguridad del sistema, ya que un archivo de 1 byte puede tener mucha información asociada consigo mismo.[6]
Seguridad de los ADS
editarLos ADS son una característica que no modifican la seguridad del sistema, sin embargo el desconocimientos de estos por parte del usuario sí atenta contra el sistema, ya que al no saber que un pequeño archivo de cualquier extensión puede tener asociados muchos archivos de cualquier extensión incluyendo los ejecutables puede llevar a ejecutar cosas que no se pretenden ejecutar. Además los directorios (incluyendo el raíz, generalmente llamado C:) también pueden contener ADS y sin un software especial es imposible eliminarlos, a menos que se mueva el archivo a otro sistema de archivos y luego se regrese al NTFS (si es que el archivo se puede mover), agregado a la dificultad de encontrarlos se vuelven una buena alternativa para un atacante.
Los tipos de ataques que se podrían efectuar utilizando los ADS son dos:
- Esconder un archivo malicioso en un archivo cualquiera.
- Crear varios ADS distribuidos por todo el sistema para ocupar espacio en el disco e intentar lograr un ataque DOS
Otro problema de los ADS es la utilización maliciosa de la sintaxis archivo:flujo:$DATA, especialmente el uso de fichero::$DATA para acceder al flujo principal de datos de un fichero. Esta sintaxis puede engañar a sistemas que gestionan ficheros basados en su extensión, ya que agregando ::$DATA al final del nombre del fichero hace que su extensión ya no se vea como antes, y si la aplicación no es consciente de la existencia de los ADS, seguramente se "confundirá".[1]
Herramientas
editarA partir de Windows Vista y Windows Server 2008, el comando dir cuenta con el flag /r para listar los ADS dentro de un fichero. Pero para los usuarios de sistemas operativos anteriores es bastante más difícil saber siquiera, si un fichero contiene ADS o no.
Existen algunas herramientas que sirven para tratar con los ADS, las hay en modo texto como LADS y otras gráficas como ADS Explorer y adsspy
Véase también
editarReferencias
editar- ↑ a b https://web.archive.org/web/20100123222359/http://www.kriptopolis.org/alternate-data-streams-ntfs
- ↑ «Copia archivada». Archivado desde el original el 18 de octubre de 2014. Consultado el 2 de febrero de 2010.
- ↑ http://www.kaspersky.com/news?id=177718126
- ↑ http://windowstips.wordpress.com/2007/01/29/alternate-data-streams-ads-que-es-y-como-funciona/
- ↑ http://vierito.es/wordpress/2009/06/01/alternate-data-streams-ads-con-ntfs-3g-en-linux/
- ↑ «Copia archivada». Archivado desde el original el 22 de agosto de 2010. Consultado el 2 de febrero de 2010.
Enlaces externos
editar- LADS (inglés)
- adsspy
- Heysoft (inglés o alemán)
- Windows Tips
- Kriptopolis