elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.


Tema destacado: ¿Eres nuevo? ¿Tienes dudas acerca del funcionamiento de la comunidad? Lee las Reglas Generales


+  Foro de elhacker.net
|-+  Seguridad Informática
| |-+  Análisis y Diseño de Malware
| | |-+  Abril negro (Moderadores: Man-In-the-Middle, WHK, kub0x, fary)
| | | |-+  Abril Negro 2008: Taller de ASM
0 Usuarios y 4 Visitantes están viendo este tema.
Páginas: 1 2 [3] 4 5 6 7 8 9 10 Ir Abajo Respuesta Imprimir
Autor Tema: Abril Negro 2008: Taller de ASM  (Leído 75,197 veces)
SheKeL_C$


Desconectado Desconectado

Mensajes: 549


_-=[Sh3K3L_C$]=-_


Ver Perfil
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #20 en: 15 Abril 2008, 15:39 pm »

NO HE DIXO NADA


« Última modificación: 15 Abril 2008, 15:42 pm por SheKeL_C$ » En línea

byebye


Desconectado Desconectado

Mensajes: 5.093



Ver Perfil
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #21 en: 15 Abril 2008, 15:46 pm »

Citar
pero como sería para llamar a una API sin el include?

mirate los ejemplos que trae fasm, permite definir tu mismo las funciones que usaras de varias formas.


En línea

byebye


Desconectado Desconectado

Mensajes: 5.093



Ver Perfil
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #22 en: 15 Abril 2008, 17:50 pm »

Citar
A) Usar solamente el include de kernel32 ( en caso de fasm ( no lo uso pero masm o nasm si ) ).

B) Sacar el kernelbase ( en plan shellcode ).


hay mas, si vas a ir de listo lo minimo es que te informes.

Citar
Y ahora llega un punto importante ( esto no lo ley en ningun sitio lo saque depurando un programa en C simplemente vi que registro cambiaba y es ecx )

lo cual quiere decir que en vez de eax responde en ecx.

o tu estas muy mal o cambia de depurador. la respuesta a una funcion se da en eax y GetProcAddress no es que sea otra cosa.

Código:
PD: [fs:edx] ( use el registro fs en mi codigo como pista pero nadie lo pillo ).

si, esque usar el PEB es nuevo ahora. (no tiene años ya).

Citar
PD2: Respuesta a E0N no es que no seas pro es que es una ***** de codigo y tutorial , es un tuto de ensamblador muy basico no de desarrollo de virus. Lo de esp es para estabilizar la pila como te atreves a preguntar que para que es siendo el autor del tutorial? :S xDDDDDDDDD

deslumbranos con tus artes viricas que nos vamos a reir un rato.

ROZOR eres un patan y un petardo de tio, igual que todos los codigos que pones en el foro que amontonas instrucciones y no sabes ni para que funcionan.

Citar
push
push
push
popa
call [funcion]
popa
ret
no me funciona esto ¿alguien sabe pq?.

Citar
Lo de esp es para estabilizar la pila como te atreves a preguntar que para que es siendo el autor del tutorial?

yo quiero que lo contestes tu, maestro de las artes ocultas.

PD: E0N no sera pro, pero tampoco va de pro. si hace una introduccion al lenguaje ensamblador esta en su derecho y mas ¿tu que ofreces? (aparte de las risas que nos pegamos a tu costa) solo intentas tirar a tierra el trabajo de los demas.
En línea

Flamareoon2000

Desconectado Desconectado

Mensajes: 37


Ver Perfil
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #23 en: 15 Abril 2008, 17:52 pm »

sigue con este estupendo manual EON mucho te lo vamos a agradecer mucho , ya lo estoy leyendo y practicando  :D muchas gracias!!!
En línea

Distorsion

Desconectado Desconectado

Mensajes: 238


15Hz ~ 20Hz


Ver Perfil
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #24 en: 15 Abril 2008, 19:10 pm »

Ha palabras necias oidos sordos. Habre tu propio post no desvirtualices a los demas, ademas esta claro que la casa se empieza por los cimientos. Weno aqui una duda, se puede 'apañar' para que el segmento de datos ocupe lo justo y tambien estaria bien eliminar los DB 0 del final que ocupan mas que el codigo propio. Supongo que habra que modificar el PE indicando al compilador lo que queremos.
Gracias por el manual tengo mi asm un poco oxidado jeje y solo habia programado en 16 bits.
Un saludo.
En línea

byebye


Desconectado Desconectado

Mensajes: 5.093



Ver Perfil
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #25 en: 15 Abril 2008, 19:34 pm »

lo de el tamaño extra se debe a los redondeos que se hacen. en el tutorial de ferchu se explica.
En línea

~~
Ex-Staff
*
Desconectado Desconectado

Mensajes: 2.981


Ver Perfil WWW
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #26 en: 16 Abril 2008, 16:44 pm »

@Distorsion

Si, mira, por poner un ejemplo compila esto con el fasm:

Código
  1. format PE GUI 4.0
  2. include 'H:\archivos de programa\fasm\include\win32a.inc'
  3.  
  4.  
  5.        invoke  MessageBox,0,cuerpo, titulo,MB_OK
  6.        invoke  ExitProcess,0
  7.  
  8.        cuerpo db 'Hola mundo', 0
  9.        titulo db ':P', 0
  10.  
  11. data import
  12.  
  13. library kernel32,'KERNEL32.DLL',\
  14.         user32,'USER32.DLL'
  15.  
  16.  import kernel32,\
  17.        ExitProcess,'ExitProcess'
  18.  import user32,\
  19.        MessageBox,'MessageBoxA'
  20.  
  21. end data  

Veras que solo se crea una sección en el ejecutable, la flat, q es la crea fasm por defecto cuando se estructura de esta manera el código ;)

Ahora haz esto: borras todos los bytes con un editor hexadecimal a partir del 0x2BC
y cambias el RawSize de la sección por 0xBC. Con esto te kedará un archivo de 700 bytes ;)


Posiblemente se pueda reducir un poco mas el tamaño del ejecutable, pero de esta manera ya tienes la sección de "codigo" bien ajustadita



Respecto a lo de Rozor, ya lo hemos hablado por privado y me a pedido disculpas, parece q por fin ha entrad en razon, asi q si algun mod puede borrar todos los post q no estén relaccionados con el taller pues mejor.

Salu2
En línea

elmeister

Desconectado Desconectado

Mensajes: 43


Ver Perfil
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #27 en: 16 Abril 2008, 17:04 pm »

E0N, tengo una duda, estaba trasteando con los ejemplos que trae el FASM, y modifiqué el BEER.ASM quedando así

Código
  1. ; Beer - example of tiny (one section) Win32 program
  2.  
  3. format PE GUI 4.0
  4.  
  5. include 'H:/Archivos de Programa/FASM/include/win32a.inc'
  6.  
  7. ; no section defined - fasm will automatically create .flat section for both
  8. ; code and data, and set entry point at the beginning of this section
  9.  
  10. invoke MessageBoxA,0,_message,_caption,MB_ICONQUESTION+MB_YESNO
  11. cmp eax,IDYES
  12. jne exit
  13.  
  14. invoke mciSendString,_cmd_open,0,0,0
  15. invoke mciSendString,_cmd_eject,0,0,0
  16. invoke mciSendString,_cmd_close,0,0,0
  17. invoke MessageBoxA,0,_aburrimiento, _aburres,MB_ICONQUESTION+MB_OK
  18.  
  19. exit:
  20. invoke ExitProcess,0
  21.  
  22. _message db 'Te veo aburrido, quieres echar unas canastas?',0
  23. _caption db 'Estás aburrido',0
  24.  
  25. _cmd_open db 'open cdaudio',0
  26. _cmd_eject db 'set cdaudio door open',0
  27. _cmd_close db 'close cdaudio',0
  28.  
  29. _aburrimiento db 'Hala! Haz un Triple!',0
  30. _aburres db 'NBA',0
  31.  
  32. ; import data in the same section
  33.  
  34. data import
  35.  
  36. library kernel32,'KERNEL32.DLL',\
  37. user32,'USER32.DLL',\
  38. winmm,'WINMM.DLL'
  39.  
  40. import kernel32,\
  41. ExitProcess,'ExitProcess'
  42.  
  43. import user32,\
  44. MessageBoxA,'MessageBoxA'
  45.  
  46. import winmm,\
  47. mciSendString,'mciSendStringA'
  48.  
  49. end data
  50.  

Añadí un mensaje despues de que se abriese la bandeja del CD, mi duda es, como puedo cambiar el icono?, lo he compilado y funciona perfecto, pero no puedo cambiarlo (el código lo adjunta para mostrar como quedó y nada más, aunque solo he añadido y traducido, no he cambiado más)
En línea

~~
Ex-Staff
*
Desconectado Desconectado

Mensajes: 2.981


Ver Perfil WWW
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #28 en: 16 Abril 2008, 17:15 pm »

Fijate en los parametros del MessageBoxA. Si miras en la MSDN la descripcion de este api veras que para modificar el icono hay que cambiar el último parametro.
http://msdn2.microsoft.com/en-us/library/ms645505(VS.85).aspx

Por poner un ejemplo:
Código:
include 'H:/Archivos de Programa/FASM/include/win32ax.inc'
 
.code
start:
        invoke MessageBox, 0, 'Error', 0, MB_ICONERROR
        invoke MessageBox, 0, 'Pregunta', '', MB_ICONQUESTION
        invoke MessageBox, 0, 'Warning', '', MB_ICONWARNING
        invoke MessageBox, 0, 'Información', '', MB_ICONINFORMATION

        invoke ExitProcess, 0
.end start 

En la MSDN encontrarás prácticamente todo lo que necesites respecto a apis
Salu2 E0N
En línea

elmeister

Desconectado Desconectado

Mensajes: 43


Ver Perfil
Re: Abril Negro 2008: Taller de ASM by E0N
« Respuesta #29 en: 16 Abril 2008, 17:51 pm »

no me refiero a eso, aunque tambien me viene bien, gracias, me refiero al icono del ejecutable
En línea

Páginas: 1 2 [3] 4 5 6 7 8 9 10 Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
Abril Negro 2008
Abril negro
WHK 0 3,607 Último mensaje 4 Febrero 2017, 19:30 pm
por WHK
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines