![]() |
¿Como se hacen los programas estilo "keygen"?
A proposito de un hilo en este mismo apartado acerca del tamaño de los ejecutables, yo siempre he tenido la duda de como es que hacen los hackers los programitas que hay por toda la red que son keygenerators para diferentes aplicaciones.
Generalmente estos keygens son aplicaciones de unos cuantos Kb que muchas veces traen efectos rimbombantes, como animaciones muy elaboradas y audio de fondo y yo me pregunto donde es que metieron todo eso dentro de un exe tan pequeño??? ni siquiera esta comprimido con UPX o algun otro compresor puesto que me permite todavia comprimirlo a mi con el UPX y se hace aún más pequeño. Definitivamente estos cuates tienen mucho talento y desde ahi se nota que hay gran diferencia entre ellos y un desarrollador común pues optimizan al máximo el ejecutable al parecer, lo que a muchos de nosotros nos viene a valer cacahuate. Pero no dejo de preguntarme como hacer para poner esos audios de fondo, no parecen ser midi, deben ser algun otro formato o de plano no tengo ni idea. |
Hola,
Sin salirnos de Delphi existe algo como KOL (Key Objects Library). En esta página de "demos" verás ejecutables con GUI desde 4 KB... |
Hombre Xander, no quito mérito a esos programas, pero todos sabemos que un ejecutable de Delphi, por buenos que seamos, ocupará, como mínimo, 300kb tan sólo para mostrar una ventanita vacía. No es una cuestión de capacidad sino de la herramienta que usamos. Desde luego, podemos usar opciones como la que menciona David, o podemos programar en C, o incluso en Delphi si decidimos prescindir de la VCL- pero, en tal caso, mejor programamos en C. En fin, que si programamos usando Delphi y su VCL, no obtendremos ejecutables diminutos.
// Saludos |
yo se que los keygen los hacen en ensamblador.
otros en C o c++ y con codigo en ensamblador., El audio si no se como lo meten. me imagino que son instrucciones de secuencias que el windows interpreta . |
Hola,
Cita:
|
Cita:
Cita:
Saludos, Hugo |
Creo que ya esta claro que el tema del tamaño es culpa de la VCL, y de que delphi crea aplicaciones "standalone", es decir, no suelen necesitar librerías para ejecutarse, metiendo todo dentro del ejecutable.
Si se quiere hacer una aplicación pequeña, solamente hay que hacer todo "a mano", usando la API de windows podemos hacer de todo. Recuerdo que hace tiempo, cuando tenia la fiebre de los ejecutables pequeños, llegue a implementar los threads llamando a la api, por no usar la unit classes ... luego te das cuenta de que estas exagerando ... o no :cool: :p Cita:
http://www.clubdelphi.com/foros/show...6&postcount=17 |
Cita:
1. El cerebro (lo mas importante :)) 2. Leer MUCHO y TODOS LOS DIAS. 3. Saber bastante assembler (lenguaje ensamblador) y saber programar en MASM32 o FASM32. Para estos tienes uno que se llama RadASM (IDE) Código:
http://www.radasm.com/Código:
http://www.masm32.com/5. Reconocer en qué lenguaje fue escrito un programa para poder analizarlo de forma correcta. Una ayuda para esto puede ser PEiD Código:
http://peid.has.it/7. Saber manejar por lo menos un depurador de aplicaciones para análisis, como es el mas básico y fácil, OllyDbg (para aplicaciones hechas en Delphi, Visual Basic, etc...) Código:
http://www.ollydbg.de/Código:
http://www.softpedia.com/get/Programming/Debuggers-Decompilers-Dissasemblers/DeDe.shtmlCódigo:
http://www.x-ways.net/winhex/index-e.htmlCódigo:
http://diablo2oo2.di.funpic.de/Código:
http://www.keygenmusic.net/Código:
http://sourceforge.net/projects/upxshell/Y bueno... MUUUUUUCHAS otras cosas que estaría horas hablando :D es un ejemplo de los pasos y algunas herramientas que necesitas previo al keygen o parche... si quieres saber mas pregúntale al tío google, porque me aburrí de escribir jejejeje :P COrdiales saludos. |
Chas Gracias Black Ocean... muy ilustrativo tu comentario :) Eso es lo que quería saber..
|
Ya saben que mas... acá les dejo un tutorial + el código fuente incluido (todo en ESPAÑOL!) de un ejemplo de cómo hacer un keygen en DELPHI!!!!!!!!! EXCLUSIVO!!
Código:
http://www.gigasize.com/get.php/1212171/KeyGDelphi.rarCódigo:
KeygenDelphiCódigo:
http://www.crackslatinos.hispadominio.net |
xander, dac, roman...
En realidad si se debe tener algo de experiencia en crear esos programillas tan pequeños... alguien citaba: "no menos de 300 Kb", eso es totalmente mentira, pues el modo de abstraccion que utilizo Borland para representar un objeto ventana fue algo grueso. La solucion esta en solo utilizar APIs, que al final es de lo que hacen uso los lenguajes de programacion visual, y en el hermoso Delphi en particular podemos meterle algo de codigo en Assembler, comienza creando aplicaciones SIN ventanas; consolas, luego quitale la opcion de consola y estaras haciendo un programa de 8 Kb +/- en la cual con algunas APIspodrs ponerle un entorno mas Güindos... Espero estar aqui para darles algunos consejillos, pues esa fue mi "especialidad".
|
Yo soy el que citas :D
Pero a lo que me refería, es justamente a que, usando la VCL, es imposible bajar de 300kb. No usándola, desde luego que se puede bajar- y drásticamente -el tamaño. Quizá debí aclarar más. // Saludos |
Ok
Okey makey, pero es que la VCL no es algo impresindible siempre. Y respeto ambas posiciones.
PD: no uses el upx, los dos mejores (ahora para mi, pues antes lo usaba), son el mew (para aplicaciones de pocos Kb) y el PECompact (para aplicaciones medianas y grandes). Lo malo del primero es que no respeta el recurso para compatibilidad xp, (xpman.res?) SDS xander & roman |
De acuerdo en que no es imprescindible, y para el tipo de programas del que hablan aquí, seguro que hay que prescindir de ella. Pero en términos generales, si voy a programar en Delphi, usaré la VCL, que pese a su tamaño es una excelente biblioteca que nos facilitará enormemente el trabajo.
El UPX lo uso cuando necesito distribuir actualizaciones por correo, pero no había pensado en lo del XP- de hecho, hasta hace muy poco no usaba el XP Manifest - Que bueno que mencionas esos otros compresores, voy a revisarlos. Por cierto, bienvenido a los foros. // Saludos |
Hola,
Cita:
|
Pues me extraña esto que comentas dec, pues hace poco se mencionó esto, y de ahí que no me sonara desconocido eso. Será cuestión de la versión.
// Saludos |
Hola,
No sé. A mí me suena raro porque llevo usando UPX hace bastante tiempo y no recuerdo haberme topado con ese problema. He visto el Hilo que enlazas, pero, no me queda claro. UPX comprime el ejecutable, es cierto, pero cuando este último se ejecuta, propiamente, UPX lo descomprime: dejándolo, obviamente, como estaba. Pero, aparte de esta idea mía, que puede estar equivocada, insisto: acabo de probar con UPX 1.25, que era el que venía utilizando; he ido a la Web de UPX y he descargado la versión 2.05 (la última versión) y he probado de nuevo y todo ha ido como esperaba, o sea. :) Si fuera cuestión de la versión (que puede ser) lo cierto es que sería (según mi idea) un Bug de dicha versión, por lo que he mencionado: UPX comprime y añade un descompresor al ejecutable que se encarga de descomprimirlo: creo que se trata en todo caso de una compresión "sin pérdida", así que cuando se descomprime todo debe estar como al principio. |
Upppss
Lamento si no me explique bien, no me refiero al upx pues este si respeta dicho recurso, el que no lo hace y el cual sugeri utilizar para aplicaciones realmente pequeñas. El mew es el que no respeta al xpman.res :o
|
Pues tienes razón David. Ya lo he probado yo mismo y funciona como dices.
// Saludos |
A todo esto, ¿que c#ing@o$ es el XP Manifiesto ese??? pa que sirve o que onda??... me sirve de algo si estoy trabajando con Delphi2007 que según ya es para Vista y no para XP ???? o que onda?
|
Hola,
Existe una unidad en Delphi 7 de nombre "XpMan.pas". Esta unidad se limita exclusivamente a añadir al ejecutable (como un recurso más) el archivo "WindowsXP.res", que puede encontrarse en: "C:\Archivos de programa\Borland\Delphi7\Lib". Pues bien, dicho archivo ".res" contiene el siguiente XML: Código:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>¿Si te sirve de algo en Delphi 2007? Ignoro siquiera si se incluye la unidad "XpMan.pas", empero, a no ser que se incluya el recurso "WindowsXP.res" por defecto en los ejecutables (cosa que dudo, pero por pura intuición), si quieres que tu programa adopte el tema de Windows XP... deberá usarse igual que en Delphi 7, por ejemplo. En general podría decirse que cualquier ejecutable (de Delphi o de otro lenguaje/entorno) que contenga el XML referido (como un recurso más dentro del ejecutable), tomará en sus controles comunes (de Windows) la apariencia del tema de Windows XP que esté usando el usuario. PD. Pero no mezclemos distintos temas en un mismo Hilo que puedo acabar echándome la bronca a mí mismo y no veas tú qué compromiso. :) |
Gracias Dec, las cosas de las que se entera uno... no tenía ni idea de eso
:D |
Hola,
Vamos a ampliar ambos la información, ya puestos, y a leer el artículo de Michael A. Allen y Zarko Gajic: Windows XP Manifest in Delphi. :) |
Volviendo al tema de los KeyGen... yo pensaba que los sacaban las propias compañías de software.
Aunque suene a broma, lo digo en serio. El interés de dicha acción sería para permitir que usuarios no profesionales puedan acceder a sus productos. |
Cita:
Ejemplo de cómo especificarlo:
También el otro método que existe es simplemente poniendo el archivo .manifest en la misma carpeta en donde radicará el ejecutable de tu proyecto pero con el mismo nombre del ejecutable, es decir, si nuestro ejecutable se llama MiProyecto.exe, el archivo manifest se tendrá que llamar MiProyecto.manifest Espero que les haya servido la información. |
Sé que llego tarde, y que esto está degenerando un poco, pero voy a recuperar el hilo inicial de esta conversación.
Lo de los programas "keygen" que muestran esas impresionantes presentaciones en poco más de 30Ko de ejecutable es herencia de las "tech-demos" que se empezaron a hacer en los '80. En estas se intentaba hacer el programa más impresionante (e inútil, todo sea dicho de paso) en el menor espacio posible. Yo fui demo-maker en mis tiempos, pero yo lo hacía en MSX y no en PC. Para ahorrar el máximo de memoria las demos se programaban exclusivamente en ensamblador, realizando llamadas directas al BIOS y accediendo a los puertos y a la memoria del sistema de forma directa, sin pasar por el sistema operativo. Por otro lado, lo que hincha un programa Windows suelen ser los recursos. Si en lugar de crear las ventanas y diálogos con el IDE, arrastrando y soltando componentes con el ratón, lo hacemos a golpe de código podemos reducir considerablemente el tamaño de los ejecutables. Hace ya algunos años hice una demostración con Delphi 6 en el que ahorré una media de 1'5Ko por control (no sólo los visibles como los botones sino también los invisibles como los TQuery, TDialog, etc.) al reproducir un programa RAD a golpe de código. Si un programa tiene 200 componentes, lo cual es bastante común, podemos ahorrar casi 300Ko. Eso sí, es mucho más difícil diseñar un formulario escribiendo el código directamente en Pascal que utilizando los componentes visuales. |
O sea, que de RAD pasó a SAD :p :D
// Saludos |
Cita:
Mi programa va a medir menos que usando el editor de formularios de Delphi??? Me puedes firmar con tu sangre eso?? Y de ser así, porque es que sucede eso??? al final de cuentas eso es lo que hace el compilador de Delphi al crear el formulario, que no? |
No estaría yo tan seguro que sea tanto el ahorro, pero sí debe disminuir el tamaño. Todas las propiedades de las componentes y formularios que se establecen en tiempo de diseño (es decir, el DFM), se guardan como recursos dentro del ejecutable. Al hacerlo por código, eliminas ese recurso del ejecutable.
// Saludos |
Cita:
Lo malo es que quitando esas clases pasamos, como bien dice roman, de RAD (Rapid application development) a SAD (Slow ??? application development) :D , es decir, un montón de lineas para crear una ventana, un montón de lineas para crear un boton, etc ... |
Cita:
|
SAD de slow y de :(
Yo también había pensado que Ñuño se refería a lo que hemos dicho antes: crear formularios a mano, con la API de Windows. Pero aún haciéndolo así, si te pones a usar las unidades DB, DBCtrls, StdCtrls, ExtCtrls, necesarias para lo que menciona (botones, querys, etc) pues viene a ser casi lo mismo: ejecutables de más de 300kb. Por ello, cuando leí el mensaje de xander, pensé que realmente se refería a quitar el dfm del ejecutable. Pero, al igual que xander, estoy escéptico en este punto. // Saludos |
Regresando al tema.
En definitiva si quieren crear una aplicacion buena de ese tipo (virus?) lo mejor es solo usar las APIs de Guindos... y lenguaje de maquina, ñuño me comprenderá en la idea, el pasarse a 32 bits no creo que le sea mucho lio.
Lo que yo cuido en mis aplicaciones son dos cosas... la primera es no utilizar ningun tipo de concatenacion de cadenas, pues suele ocupar varios Kb. lo mejor es siempre usar vectores concatenados con metodos de movimientos de memoria... lo segundo es no utilizar por ningun motivo la unidad SysUtils pues esa engorda en gran medida al ejecutable... En algun momento les pasaré algunas de mis aplicaciones de esta clase... tengo como una docena y si realmente estan interesados les pasare parte del codigo, no si este foro lo permite pero si no, les paso por mail (los programas) y el codigo lo hago publico aca mismo. PD: "uses windows;" y nada mas!!! |
Ahh me olvidaba!
El asunto de lo que comentaba roman de las BDs... este tema de los "keygens" en definitiva es "bajar de nivel" lastimosamente estamos muy acostumbrados a utilizar lo que el IDE nos dá a primera vista... pero alguna vez hicieron Ctrl+Click... vieron todo lo que hay por debajo? y que pasa si se nos ocurre realizar nuestra propia interfaz con una base de datos creada por nosotros mismos? entonces si logramos menos de 100 Kb. con una BD.
Si hablamos de KeyGens y parecidos, necesariamente hablamos de bajo nivel y no es necesario hacer uso de las interfaces de BDs DBxxxx.pas |
Cita:
Es cierto que el ahorro no era mucho, pero siempre hay que valorar si el esfuerzo de hacerlo así merece la pena por el ahorro conseguido. Eso sí, estuve una temporada aprendiendo a programar GTK+ y ahí sí que se notó un ahorro bárbaro... |
Cita:
Simplemente por pura lógica. Un Keygen no es más que un programa que a partir de un dato (Nombre de usuario) genera otro dato (Serial) utilizando una serie de cálculos. Para eso no hace falta en absoluto programar en ensamblador. Es más, en ensamblador sería bastante más tedioso que en cualquier otro lenguaje de medio-alto nivel. Para hacer un "Patcher" pasa algo similar; Se trata de cambiar una serie de Bits de un fichero por otros distintos; BIS de lo explicado antes. Doy por supuesto que una persona que genera Keygens no es tonta, por lo tanto no hay razón para usar ensamblador en una cosa que no se necesita. En cuanto a los "patchers", como ya han dicho, ni siquiera programan, ya que existen múltiples herramientas que a partir de una plantilla y los datos que se le dan, genera ese ejecutable (que parchea otro) con un par de clicks. La única razón para usar ensamblador sería el tamaño, pero existen otras alternativas; por ejemplo las KOL son un gran ejemplo, aunque hay más... Volviendo al tema del lenguaje, he realizado una simple prueba, con varios programas; 7 en concreto. Después de desempaquetarlos y desemcriptarlos he obtenido: * 2 Programados con Borland Delphi (delphi 4.0 y Delphi 7.0) * 2 programado con Microsoft Visual C++ * 1 programado con LCC Win32 * 1 Microsoft Visual Basic 5.0 o 6.0 * 1 Desconocido NOTA: Cierto que hay que saber ensamblador, pero no para generar los Keygen. NOTA2: Llego un poco tarde, ya habéis avanzado bastante en el tema... |
Ok
Comparto la idea naftali... el uso de lenguaje de maquina esta directamente relacionado con el tamaño y velocidad del producto final (ver tema).
Lo de los resultados analizados, en definitiva si eres bueno en lo que haces hasta en lenguajes etiquetados (HTML?) podemos dominar el mundo con pocos Kb. Pero no nos alejemos de Delphi que es nuestra herramienta principal. |
mira te explico breve mente yo soy cracker y tu preguntas como programamos los keygen. a lo mejor ya se te contesto tu duda pero por si no te explico en el caso de la musica utilizamos bueno la mayoria utiliza musica en formato XM la cual no pesa mucho y es de buen formato para eso utilizamos la libreria Ufmod la cual nos permite reproducir la musica en XM aparte de eso utilizamos la herramienta eff la cual nos convierte la musica XM en un archivo .PAS que utiliza delphi el cual contiene el codigo de esa musica y se agrega de esta manera:
primero en uses declaramos Ufmod despues abrimos el archivo .Pas y copiamos el codigo de la musica en el evento oncreate metemos Ufmod_Playsong(@xm,length(xm),xm_memory); para tener la musica mientras este abierto el keygen jaja creo que no me pero mira hace algunos dias hice un tutorial de como hacerlo te lo dejo aqui para que lo descargues espero que te sirva http://rapidshare.com/files/22140361...i_by_ZELT_.rar en cuanto los demas efectos por lo regular es puro codigo como para lograr el movimiento de algun texto o el desvanecimiento de la ventana a y porcierto a mi me gusta hacer mis keygen en delphi pero a otros en ensamblador y otros en visual todo depende del cracker y en que lenguaje le guste programar |
Cita:
Hola, tengo un programa que lleva una protección consistente en un "usb dongle" con el sistema Guardant Stealth III. ¿eso puede piratearse? Lo pregunto sólo por curiosidad :D |
Cita:
Si, si se puede. Te lo digo no porque yo conosca como hacerlo, sino porque tengo un software que viene con una llave usb en la version "flotante" es decir que primero debes de copiar la clave que viene en la llave a tu sistema y de ahi ya puedes usar el software en la pc que lo hayas instalado, el software lo puedes instalara en todas las maquinas que quieras pero solo con los datos de la usb funcionara. Cuando quieres ir a otra maquina debes de devolver la clave a la llave e instalarlo en la otra maquina. Es un gorro eso! Pero como siempre los programadores rusos (¿que les enseñaban alla en el bloque oriental?) ya te dan la forma de brincarte eso y colocar tu clave en todas las maquinas que quieras. No hay nada seguro e inviolable. |
| La franja horaria es GMT +2. Ahora son las 14:56:31. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi