SlideShare una empresa de Scribd logo
1 de 5
Descargar para leer sin conexión
Ingeniería Inversa del Software
- Parte III -
Modificación de textos en programas (Editores hexadecimales
y de recursos)
Tradicionalmente, cuando se ha pretendido modificar un texto que se pueda ver en
un programa compilado, se ha utilizado un editor hexadecimal. Últimamente, no
obstante, se han puesto muy de moda los editores de recursos que hacen mucho más
sencillo e intuitivo este acto. No obstante, los editores hexadecimales siguen siendo
mucho más eficaces y no son tan complicados como pueda parecer a simple vista.
El editor hexadecimal es un tipo especial de editor que puede mostrar y modificar
cualquier tipo de carácter, incluso los especiales. Esto lo consigue manejando los
códigos hexadecimales en vez de los ASCII, aunque estos también son mostrados
cuando no son especiales en otra ventana aparte que sirve de referencia. Gracias a esta
característica se puede editar cualquier fichero, incluso ejecutables, sin perder ningún
carácter.
El editor de recursos es otro tipo de editor que solo muestra las cadenas de texto
estáticas que se han definido en tiempo de programación, ocultando de esta manera el
resto de caracteres hexadecimales.
El problema de los editores de recursos es que muchas veces son incapaces de editar
un programa que podría editarse hexadecimalmente. Esto es habitual cuando el
programa contiene pantallas con caracteres en algún lenguaje que no está instalado en el
ordenador, como por ejemplo el chino, japonés, árabe, etc.
La barrera que no puede saltarse ninguno de estos programas (de momento) es la
encriptación. Por tanto, nosotros como programadores que sabemos esto, deberemos
encriptar siempre la información importante contenida en nuestro software. Como
vamos a ver a continuación, es muy fácil cambiar el nombre del creador del programa,
su dirección de email o cualquier otro dato que se pueda proporcionar para cobrar por el
uso del software completo.
Veamos como podría hacerse esto con un editor hexadecimal como el WinHex y con
un editor de recursos como el Resource Hacker:
1. Se abre con el editor el programa (.exe) o la librería (.dll) correspondiente.
2. Se busca el texto que se quiera modificar.
3. Modificar el texto deseado, respetando siempre la longitud de la cadena de
texto original si se hace con editor hexadecimal. Se puede escribir un texto
más corto y rellenar con espacios, pero no se puede sobrepasar el texto
original porque estaríamos sobrescribiendo el código del programa y dejaría
de funcionar correctamente. Como los editores de recursos regeneran el
código para acomodar las nuevas cadenas, esta consideración no es necesaria
si se usa uno de esos programas.
4. Salvar el archivo modificado.
Al ejecutar el programa se puede observar se puede observar el resultado:
A la vista está que no es nada complicado conseguir “retocar” el texto de un
programa si éste no está oculto mediante encriptación, por lo que ésta debe de ser una
de nuestras herramientas esenciales de programación. No cuesta nada encriptar los
textos importantes de la aplicación y nos protege eficazmente contra cualquier ataque de
este tipo.
Jöx€@n Nieto

Más contenido relacionado

La actualidad más candente

La actualidad más candente (15)

Practico 1 taller de software cat.pdf
Practico 1 taller de software cat.pdfPractico 1 taller de software cat.pdf
Practico 1 taller de software cat.pdf
 
Presentación 4ºESO
Presentación 4ºESOPresentación 4ºESO
Presentación 4ºESO
 
Actividad de Aprendizaje 1
Actividad de Aprendizaje 1Actividad de Aprendizaje 1
Actividad de Aprendizaje 1
 
Software libre
Software libreSoftware libre
Software libre
 
Software para la edición de texto
Software para la edición de textoSoftware para la edición de texto
Software para la edición de texto
 
Comandos basicos
Comandos basicosComandos basicos
Comandos basicos
 
Actividad de aprendizaje 1 (1)
Actividad de aprendizaje 1 (1)Actividad de aprendizaje 1 (1)
Actividad de aprendizaje 1 (1)
 
Lenguaje demarcaslatex
Lenguaje demarcaslatexLenguaje demarcaslatex
Lenguaje demarcaslatex
 
Presentación
PresentaciónPresentación
Presentación
 
Programa 12
Programa 12Programa 12
Programa 12
 
Ramon caña
Ramon cañaRamon caña
Ramon caña
 
Colegio particular
Colegio particularColegio particular
Colegio particular
 
Emelyn
EmelynEmelyn
Emelyn
 
Código HTML
Código HTML Código HTML
Código HTML
 
Tarea3 tema0 zaira lorenzo pérez
Tarea3 tema0  zaira lorenzo pérezTarea3 tema0  zaira lorenzo pérez
Tarea3 tema0 zaira lorenzo pérez
 

Similar a Ingenieria inversa del software (iv)

Similar a Ingenieria inversa del software (iv) (20)

Software de programacion
Software de programacionSoftware de programacion
Software de programacion
 
Clase 3 Editores para Programación Web
Clase 3 Editores para Programación WebClase 3 Editores para Programación Web
Clase 3 Editores para Programación Web
 
Editor de páginas web
Editor de páginas webEditor de páginas web
Editor de páginas web
 
OAs editores
OAs editoresOAs editores
OAs editores
 
Software para la edición de texto
Software para la edición de textoSoftware para la edición de texto
Software para la edición de texto
 
software editor de texto
 software editor de texto software editor de texto
software editor de texto
 
Colegio particular
Colegio particularColegio particular
Colegio particular
 
ADA 1
ADA 1ADA 1
ADA 1
 
Editores de texto
Editores de textoEditores de texto
Editores de texto
 
Editor y prosesador de texto
Editor y prosesador de textoEditor y prosesador de texto
Editor y prosesador de texto
 
Editor y prosesador de texto
Editor y prosesador de textoEditor y prosesador de texto
Editor y prosesador de texto
 
Adriana dominguez
Adriana dominguezAdriana dominguez
Adriana dominguez
 
Software para edición de texto
Software para edición de textoSoftware para edición de texto
Software para edición de texto
 
Editores de texto
Editores de textoEditores de texto
Editores de texto
 
ADA # 1
ADA # 1ADA # 1
ADA # 1
 
ADA # 1
ADA # 1ADA # 1
ADA # 1
 
Arquitectura de los computadores
Arquitectura de los computadoresArquitectura de los computadores
Arquitectura de los computadores
 
Mireya tiguila
Mireya tiguilaMireya tiguila
Mireya tiguila
 
Lenguaje c nardy y daniela
Lenguaje c nardy y danielaLenguaje c nardy y daniela
Lenguaje c nardy y daniela
 
Programando en html
Programando en htmlProgramando en html
Programando en html
 

Último

guía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Josephguía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan JosephBRAYANJOSEPHPEREZGOM
 
Hernandez_Hernandez_Practica web de la sesion 12.pptx
Hernandez_Hernandez_Practica web de la sesion 12.pptxHernandez_Hernandez_Practica web de la sesion 12.pptx
Hernandez_Hernandez_Practica web de la sesion 12.pptxJOSEMANUELHERNANDEZH11
 
ATAJOS DE WINDOWS. Los diferentes atajos para utilizar en windows y ser más e...
ATAJOS DE WINDOWS. Los diferentes atajos para utilizar en windows y ser más e...ATAJOS DE WINDOWS. Los diferentes atajos para utilizar en windows y ser más e...
ATAJOS DE WINDOWS. Los diferentes atajos para utilizar en windows y ser más e...FacuMeza2
 
trabajotecologiaisabella-240424003133-8f126965.pdf
trabajotecologiaisabella-240424003133-8f126965.pdftrabajotecologiaisabella-240424003133-8f126965.pdf
trabajotecologiaisabella-240424003133-8f126965.pdfIsabellaMontaomurill
 
SalmorejoTech 2024 - Spring Boot <3 Testcontainers
SalmorejoTech 2024 - Spring Boot <3 TestcontainersSalmorejoTech 2024 - Spring Boot <3 Testcontainers
SalmorejoTech 2024 - Spring Boot <3 TestcontainersIván López Martín
 
Plan de aula informatica segundo periodo.docx
Plan de aula informatica segundo periodo.docxPlan de aula informatica segundo periodo.docx
Plan de aula informatica segundo periodo.docxpabonheidy28
 
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricGlobal Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricKeyla Dolores Méndez
 
La era de la educación digital y sus desafios
La era de la educación digital y sus desafiosLa era de la educación digital y sus desafios
La era de la educación digital y sus desafiosFundación YOD YOD
 
Redes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfRedes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfsoporteupcology
 
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...silviayucra2
 
International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)GDGSucre
 
Proyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptxProyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptx241521559
 
EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveFagnerLisboa3
 
Trabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíaTrabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíassuserf18419
 
KELA Presentacion Costa Rica 2024 - evento Protégeles
KELA Presentacion Costa Rica 2024 - evento ProtégelesKELA Presentacion Costa Rica 2024 - evento Protégeles
KELA Presentacion Costa Rica 2024 - evento ProtégelesFundación YOD YOD
 
Instrumentación Hoy_ INTERPRETAR EL DIAGRAMA UNIFILAR GENERAL DE UNA PLANTA I...
Instrumentación Hoy_ INTERPRETAR EL DIAGRAMA UNIFILAR GENERAL DE UNA PLANTA I...Instrumentación Hoy_ INTERPRETAR EL DIAGRAMA UNIFILAR GENERAL DE UNA PLANTA I...
Instrumentación Hoy_ INTERPRETAR EL DIAGRAMA UNIFILAR GENERAL DE UNA PLANTA I...AlanCedillo9
 
PARTES DE UN OSCILOSCOPIO ANALOGICO .pdf
PARTES DE UN OSCILOSCOPIO ANALOGICO .pdfPARTES DE UN OSCILOSCOPIO ANALOGICO .pdf
PARTES DE UN OSCILOSCOPIO ANALOGICO .pdfSergioMendoza354770
 
Cortes-24-de-abril-Tungurahua-3 año 2024
Cortes-24-de-abril-Tungurahua-3 año 2024Cortes-24-de-abril-Tungurahua-3 año 2024
Cortes-24-de-abril-Tungurahua-3 año 2024GiovanniJavierHidalg
 
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE  DE TECNOLOGIA E INFORMATICA PRIMARIACLASE  DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIAWilbisVega
 

Último (19)

guía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Josephguía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Joseph
 
Hernandez_Hernandez_Practica web de la sesion 12.pptx
Hernandez_Hernandez_Practica web de la sesion 12.pptxHernandez_Hernandez_Practica web de la sesion 12.pptx
Hernandez_Hernandez_Practica web de la sesion 12.pptx
 
ATAJOS DE WINDOWS. Los diferentes atajos para utilizar en windows y ser más e...
ATAJOS DE WINDOWS. Los diferentes atajos para utilizar en windows y ser más e...ATAJOS DE WINDOWS. Los diferentes atajos para utilizar en windows y ser más e...
ATAJOS DE WINDOWS. Los diferentes atajos para utilizar en windows y ser más e...
 
trabajotecologiaisabella-240424003133-8f126965.pdf
trabajotecologiaisabella-240424003133-8f126965.pdftrabajotecologiaisabella-240424003133-8f126965.pdf
trabajotecologiaisabella-240424003133-8f126965.pdf
 
SalmorejoTech 2024 - Spring Boot <3 Testcontainers
SalmorejoTech 2024 - Spring Boot <3 TestcontainersSalmorejoTech 2024 - Spring Boot <3 Testcontainers
SalmorejoTech 2024 - Spring Boot <3 Testcontainers
 
Plan de aula informatica segundo periodo.docx
Plan de aula informatica segundo periodo.docxPlan de aula informatica segundo periodo.docx
Plan de aula informatica segundo periodo.docx
 
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricGlobal Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
 
La era de la educación digital y sus desafios
La era de la educación digital y sus desafiosLa era de la educación digital y sus desafios
La era de la educación digital y sus desafios
 
Redes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdfRedes direccionamiento y subredes ipv4 2024 .pdf
Redes direccionamiento y subredes ipv4 2024 .pdf
 
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
POWER POINT YUCRAElabore una PRESENTACIÓN CORTA sobre el video película: La C...
 
International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)International Women's Day Sucre 2024 (IWD)
International Women's Day Sucre 2024 (IWD)
 
Proyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptxProyecto integrador. Las TIC en la sociedad S4.pptx
Proyecto integrador. Las TIC en la sociedad S4.pptx
 
EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial Uninove
 
Trabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíaTrabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnología
 
KELA Presentacion Costa Rica 2024 - evento Protégeles
KELA Presentacion Costa Rica 2024 - evento ProtégelesKELA Presentacion Costa Rica 2024 - evento Protégeles
KELA Presentacion Costa Rica 2024 - evento Protégeles
 
Instrumentación Hoy_ INTERPRETAR EL DIAGRAMA UNIFILAR GENERAL DE UNA PLANTA I...
Instrumentación Hoy_ INTERPRETAR EL DIAGRAMA UNIFILAR GENERAL DE UNA PLANTA I...Instrumentación Hoy_ INTERPRETAR EL DIAGRAMA UNIFILAR GENERAL DE UNA PLANTA I...
Instrumentación Hoy_ INTERPRETAR EL DIAGRAMA UNIFILAR GENERAL DE UNA PLANTA I...
 
PARTES DE UN OSCILOSCOPIO ANALOGICO .pdf
PARTES DE UN OSCILOSCOPIO ANALOGICO .pdfPARTES DE UN OSCILOSCOPIO ANALOGICO .pdf
PARTES DE UN OSCILOSCOPIO ANALOGICO .pdf
 
Cortes-24-de-abril-Tungurahua-3 año 2024
Cortes-24-de-abril-Tungurahua-3 año 2024Cortes-24-de-abril-Tungurahua-3 año 2024
Cortes-24-de-abril-Tungurahua-3 año 2024
 
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE  DE TECNOLOGIA E INFORMATICA PRIMARIACLASE  DE TECNOLOGIA E INFORMATICA PRIMARIA
CLASE DE TECNOLOGIA E INFORMATICA PRIMARIA
 

Ingenieria inversa del software (iv)

  • 1. Ingeniería Inversa del Software - Parte III - Modificación de textos en programas (Editores hexadecimales y de recursos) Tradicionalmente, cuando se ha pretendido modificar un texto que se pueda ver en un programa compilado, se ha utilizado un editor hexadecimal. Últimamente, no obstante, se han puesto muy de moda los editores de recursos que hacen mucho más sencillo e intuitivo este acto. No obstante, los editores hexadecimales siguen siendo mucho más eficaces y no son tan complicados como pueda parecer a simple vista. El editor hexadecimal es un tipo especial de editor que puede mostrar y modificar cualquier tipo de carácter, incluso los especiales. Esto lo consigue manejando los códigos hexadecimales en vez de los ASCII, aunque estos también son mostrados cuando no son especiales en otra ventana aparte que sirve de referencia. Gracias a esta característica se puede editar cualquier fichero, incluso ejecutables, sin perder ningún carácter. El editor de recursos es otro tipo de editor que solo muestra las cadenas de texto estáticas que se han definido en tiempo de programación, ocultando de esta manera el resto de caracteres hexadecimales. El problema de los editores de recursos es que muchas veces son incapaces de editar un programa que podría editarse hexadecimalmente. Esto es habitual cuando el programa contiene pantallas con caracteres en algún lenguaje que no está instalado en el ordenador, como por ejemplo el chino, japonés, árabe, etc. La barrera que no puede saltarse ninguno de estos programas (de momento) es la encriptación. Por tanto, nosotros como programadores que sabemos esto, deberemos encriptar siempre la información importante contenida en nuestro software. Como vamos a ver a continuación, es muy fácil cambiar el nombre del creador del programa, su dirección de email o cualquier otro dato que se pueda proporcionar para cobrar por el uso del software completo.
  • 2. Veamos como podría hacerse esto con un editor hexadecimal como el WinHex y con un editor de recursos como el Resource Hacker: 1. Se abre con el editor el programa (.exe) o la librería (.dll) correspondiente. 2. Se busca el texto que se quiera modificar. 3. Modificar el texto deseado, respetando siempre la longitud de la cadena de texto original si se hace con editor hexadecimal. Se puede escribir un texto más corto y rellenar con espacios, pero no se puede sobrepasar el texto original porque estaríamos sobrescribiendo el código del programa y dejaría de funcionar correctamente. Como los editores de recursos regeneran el
  • 3. código para acomodar las nuevas cadenas, esta consideración no es necesaria si se usa uno de esos programas.
  • 4. 4. Salvar el archivo modificado. Al ejecutar el programa se puede observar se puede observar el resultado:
  • 5. A la vista está que no es nada complicado conseguir “retocar” el texto de un programa si éste no está oculto mediante encriptación, por lo que ésta debe de ser una de nuestras herramientas esenciales de programación. No cuesta nada encriptar los textos importantes de la aplicación y nos protege eficazmente contra cualquier ataque de este tipo. Jöx€@n Nieto