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

 

 


Tema destacado: Sigue las noticias más importantes de seguridad informática en el Twitter! de elhacker.NET


  Mostrar Temas
Páginas: 1 2 [3]
21  Foros Generales / Foro Libre / Alguien Juega al CounterStrike en: 1 Agosto 2010, 06:09 am
Bueno el titulo lo dice todo... algunas veces estoy un tanto aburrido pero no encuentro muchas personas con las cuales pasar un rato de diversion y quisiera saber cuales miembros de la comunidad aun lo juegan.

22  Foros Generales / Foro Libre / «Matematica» Demostracion de las Mujeres en: 31 Julio 2010, 01:34 am
Vaya demostracion que he encontrado en mis dias bellos en facebook...

23  Programación / Programación C/C++ / [Taller] Signals y Slots en Qt. en: 15 Julio 2010, 03:12 am
Los Signals y Slots son los mecanismos de comunicación utilizados para comunicar objetos que heredan de Q_OBJECT. Q_OBJECT es la base de todos los objetos de Qt.

Los Slot son simplemente funciones, que se quiere decir con esto, que pueden ser llamadas por el objeto según el estandar de C++ precediendo el nombre del metodo del nombre de la funcion seguida de un punto(.) o precediendola de una  flecha(->).

Las señales podrian interpretarse como los valores de retorno que se enviaran al metodo que esta conectado a esta señal. Se declaran como si fueran metodos pero sin procedimientos. Se envian colocando primero la macro “emit” posteriormente la señal rellenando sus argumentos con los valores que se desean emitir.

Los Signals y Slots se conectan utilizando la API de Qt llamada connect(), la cual lleva la siguiente forma: connect(const Qobject* sender, const char* signal, const Qobject* reciever, const char*  slot);

Hay ciertas caracteristicas con las que cuenta la comunicación entre los signals y los slots, entre estas estan:

  • Son type-safe, esto quiere decir que la signal debe encajar con el slot.
  • Los objetos emiten señales, pero no se preocupan de que estos sean recibidos por un slot.
  • Se pueden conectar multiples signals a un solo slot.
  • Se pueden conectar un signal a multiples slots.
  • Se puede conectar un signal con otro signal.
  • Para conectarse un signal con un slot estos deben tener el mismo numero de parametros y el mismo tipo de parametros en el orden correcto.
  • Existe una simple excepcion, si un signal contiene mas parametros que un slot y ambos se conectan, se obviaran los parametros sobrantes en el signal.

No existe mejor forma para hechar un vistazo que viendo un codigo de ejemplo que demuestre lo antes explicado.

Código
  1. //Ejemplo.h
  2. #ifndef EJEMPLO_H
  3. #define EJEMPLO_H
  4.  
  5. #include <QtGui>
  6.  
  7. class QSpinBox;
  8. class QSlider;
  9. class QLabel;
  10. class QVBoxLayout;
  11. class QHBoxLayout;
  12.  
  13. class Ejemplo : public QWidget
  14. {
  15.    Q_OBJECT
  16.  
  17. signals:
  18.    void setRGB(int,int,int);
  19.  
  20. private slots:
  21.    void getRGB(int,int,int);
  22.    void setRed(int);
  23.    void setGreen(int);
  24.    void setBlue(int);
  25.    void setAlpha(int);
  26.  
  27. private:
  28.    short int red, green, blue, alpha;
  29.    QSpinBox *SpinRed, *SpinGreen, *SpinBlue;
  30.    QSlider *SliderRed, *SliderGreen, *SliderBlue;
  31.    QLabel *LabelRed, *LabelBlue, *LabelGreen;
  32.    QVBoxLayout *LeftVertical, *MiddleRightVertical, *MiddleLeftVertical;
  33.    QHBoxLayout *MainHorizontal;
  34.  
  35.  
  36. public:
  37.    Ejemplo(QWidget *parent = 0);
  38.  
  39.  
  40. };
  41.  
  42. #endif // EJEMPLO_H
  43.  


Código
  1. //Ejemplo.cpp
  2. #include "ejemplo.h"
  3.  
  4. Ejemplo::Ejemplo(QWidget *parent)
  5.    : QWidget(parent)
  6. {
  7.  
  8.    //Construimos los Slider que utilizaremos.
  9.    this->SliderBlue = new QSlider(Qt::Vertical,0);
  10.    this->SliderBlue->setMinimum(0);
  11.    this->SliderBlue->setMaximum(255);
  12.    this->SliderRed = new QSlider(Qt::Vertical,0);
  13.    this->SliderRed->setMinimum(0);
  14.    this->SliderRed->setMaximum(255);
  15.    this->SliderGreen = new QSlider(Qt::Vertical,0);
  16.    this->SliderGreen->setMinimum(0);
  17.    this->SliderGreen->setMaximum(255);
  18.  
  19.    //Construimos los SpinBox que utilizaremos.
  20.  
  21.    this->SpinRed = new QSpinBox;
  22.    this->SpinRed->setMinimum(0);
  23.    this->SpinRed->setMaximum(255);
  24.    this->SpinBlue = new QSpinBox;
  25.    this->SpinBlue->setMinimum(0);
  26.    this->SpinBlue->setMaximum(255);
  27.    this->SpinGreen = new QSpinBox;
  28.    this->SpinGreen->setMinimum(0);
  29.    this->SpinGreen->setMaximum(255);
  30.  
  31.    //Construimos los Labels.
  32.    this->LabelBlue = new QLabel("Azul");
  33.    this->LabelGreen = new QLabel("Verde");
  34.    this->LabelRed = new QLabel("Rojo");
  35.  
  36.    //Construimos los Layout para Organizar.
  37.    this->LeftVertical = new QVBoxLayout;
  38.    this->MiddleLeftVertical = new QVBoxLayout;
  39.    this->MiddleRightVertical = new QVBoxLayout;
  40.    this->MainHorizontal = new QHBoxLayout;
  41.  
  42.    //Vamos agregando los Objetos a los Layout.
  43.    this->LeftVertical->addWidget(this->LabelRed);
  44.    this->LeftVertical->addWidget(this->SpinRed);
  45.    this->LeftVertical->addWidget(this->SliderRed);
  46.    this->MiddleLeftVertical->addWidget(this->LabelGreen);
  47.    this->MiddleLeftVertical->addWidget(this->SpinGreen);
  48.    this->MiddleLeftVertical->addWidget(this->SliderGreen);
  49.    this->MiddleRightVertical->addWidget(this->LabelBlue);
  50.    this->MiddleRightVertical->addWidget(this->SpinBlue);
  51.    this->MiddleRightVertical->addWidget(this->SliderBlue);
  52.    this->MainHorizontal->addLayout(this->LeftVertical);
  53.    this->MainHorizontal->addLayout(this->MiddleLeftVertical);
  54.    this->MainHorizontal->addLayout(this->MiddleRightVertical);
  55.    this->setLayout(this->MainHorizontal);
  56.    this->setWindowTitle("Cambia el Fondo(Codigo de Ejemplo)");
  57.  
  58.    this->MainHorizontal->addStretch();
  59.    this->setFixedHeight(this->sizeHint().height());
  60.  
  61.    this->red = 0;
  62.    this->blue = 0;
  63.    this->green = 0;
  64.    this->alpha = 0;
  65.  
  66.    //Realizamos las conexiones que necesitaremos.
  67.    connect(this->SpinRed,SIGNAL(valueChanged(int)),this->SliderRed,SLOT(setValue(int)));
  68.    connect(this->SpinGreen,SIGNAL(valueChanged(int)),this->SliderGreen,SLOT(setValue(int)));
  69.    connect(this->SpinBlue,SIGNAL(valueChanged(int)),this->SliderBlue,SLOT(setValue(int)));
  70.    connect(this->SliderRed,SIGNAL(valueChanged(int)),this->SpinRed,SLOT(setValue(int)));
  71.    connect(this->SliderGreen,SIGNAL(valueChanged(int)),this->SpinGreen,SLOT(setValue(int)));
  72.    connect(this->SliderBlue,SIGNAL(valueChanged(int)),this->SpinBlue,SLOT(setValue(int)));
  73.    connect(this->SliderRed,SIGNAL(valueChanged(int)),this,SLOT(setRed(int)));
  74.    connect(this->SliderGreen,SIGNAL(valueChanged(int)),this,SLOT(setGreen(int)));
  75.    connect(this->SliderBlue,SIGNAL(valueChanged(int)),this,SLOT(setBlue(int)));
  76.    connect(this,SIGNAL(setRGB(int,int,int)),this,SLOT(getRGB(int,int,int)));
  77.  
  78.  
  79.  
  80.    emit setRGB(this->red,this->green,this->blue); //Enviamos una señal para cambiar el color.
  81.  
  82.    }
  83.  
  84. void Ejemplo::setAlpha(int change)
  85. {
  86.    this->alpha = change;
  87.    emit setRGB(this->red,this->green,this->blue); //Enviamos una señal para cambiar el color.
  88.  
  89.    }
  90.  
  91. void Ejemplo::setRed(int change)
  92. {
  93.    this->red = change;
  94.    emit setRGB(this->red,this->green,this->blue); //Enviamos una señal para cambiar el color.
  95.  
  96.    }
  97.  
  98. void Ejemplo::setGreen(int change)
  99. {
  100.    this->green = change;
  101.    emit setRGB(this->red,this->green,this->blue); //Enviamos una señal para cambiar el color.
  102.  
  103.    }
  104.  
  105. void Ejemplo::setBlue(int change)
  106.  
  107. {
  108.    this->blue = change;
  109.    emit setRGB(this->red,this->green,this->blue); //Enviamos una señal para cambiar el color.
  110.    }
  111.  
  112. void Ejemplo::getRGB(int red, int green, int blue)
  113. {
  114. QColor *Background = new QColor(red,green,blue,255);
  115. QPalette *Paleta = new QPalette;
  116. Paleta->setColor(QPalette::Background,Background->convertTo(QColor::Rgb));
  117. this->setPalette(*Paleta);
  118. }
  119.  
  120.  

Código
  1. //main.cpp
  2. #include <QtGui/QApplication>
  3. #include "ejemplo.h"
  4.  
  5. int main(int argc, char *argv[])
  6. {
  7.    QApplication a(argc, argv);
  8.    Ejemplo w;
  9.    w.show();
  10.    return a.exec();
  11. }
  12.  
24  Foros Generales / Sugerencias y dudas sobre el Foro / Varios Casos de Spam en: 23 Junio 2010, 03:19 am
Buenas Noches, disculpen pero he visto que en estas semanas en el foro varios usuarios van posteando siempre el mismo mensaje... me parece que son cuentas creadas por el mismo usuario para hacer spam. Aqui les dejo el link refiriendome al ultimo caso.

http://foro.elhacker.net/desafios_wargames/tienes_cosas_por_hacer_en_internet_y_necesitas_dinero_en_paypalalertpay-t297493.0.html
25  Foros Generales / Foro Libre / IRC de elhacker.net en: 19 Mayo 2010, 14:57 pm
Tanto tiempo un grupo de usuarios solicitando un chat... dan el chat y ahora nadie entra, que sucede? :xD parece como si fueran las fantasias de algunos que al obtenerlas ya pierden interes. Siempre somos los mismos.

ESPERAMOS A LOS USUARIOS QUE SOLICITABAN EL CHAT OFICIAL.
26  Foros Generales / Foro Libre / Piropea a Bianc4 en: 15 Mayo 2010, 00:03 am
Bianc4, la nueva integrante de la comunidad... moderadora de nuestro Chat en IRC te queremos dedicar los mejores piropos...

Dejen Sus Piropos a Bianc4:

bianc4 quisiera hacerte un BufferOverflow para meterte mi exploit.
27  Seguridad Informática / Análisis y Diseño de Malware / [Taller] Introduccion al Diseño de Rutinas de Encriptacion en: 4 Noviembre 2009, 08:51 am
[Taller] Introduccion al Diseño de Rutinas de Encriptacion


Contenido

1.   Introducción
1.1 Concepto de Encriptacion

2.   Tipos de Encriptacion.
2.1 Encriptacion Por Sustitucion.
2.2 Encriptacion por Llaves Corredizas
2.3 Encriptacion por Llaves Largas
2.4 Encriptacion por Transposicion

3.   Despedida


1. Introduccion


En este taller sobre diseño de rutinas de encriptacion bajo Assembler debido a su simplicidad para ser añadidos a proyectos en C/C++ y Delphi. Para seguir el taller no se necesitara mas que conocimientos basicos sobre Assembler.

Tambien es recomendado el conocimiento basico del formato PE, especificamente los flag de la sección, debido a que seran necesario para la desencriptacion en memoria del codigo del programa.

De cada Tipo de encriptacion dare 2 ejemplos (a menos que crea que no es necesario), uno sencillo  para que se familiaricen con el metodo y otro metodo un poco mas complejo para que capten una idea del uso que se podria dar.


1.1 Concepto de Encriptacion

La encriptacion no es mas que el metodo utilizado para volver ilegible una sección de codigo que consideremos importante. La encriptacion debe de ser lo mas robusta posible complicando asi el analisis de dicha rutina.

2. Tipos de Encriptacion

Se podria decir que existen miles de rutinas de encriptacion pero la gran mayoria se basa en la combinacion de 2 o mas de los principales tipos de encriptacion. por ejemplo la mezcla una encriptacion simple con una encriptacion de transposicion podria ser robusta. Todo depende de las ganas de creacion del programador y el empeño que este quiera añadir a la rutina diseñada.

Los tipos de encriptacion que voy a tratar en este taller son:

  • Encriptacion por Sustitucion (Substitution Encryption).
  • Encriptacion por Llaves Corredizas (Sliding Key Encryption).
  • Encriptacion por llaves largas (Long Key Encryption).
  • Encriptacion por Transposicion (Transposition Encryption).


2.1-Encriptacion por Sustitucion.


Se podria decir que es uno de los metodos mas utilizados para encriptacion, A cada byte se agregar, reducir, rotar, etc. para la creacion de un nuevo caracter que sera el sustituto del caracter anterior. Para descifrar dicha encriptacion tan solo es necesario la realizacion de las operaciones de encriptacion pero con el orden inverso, por ejemplo si rotaste a la derecha un X numero de bits para descifrar debes rotar a la izquierda igual numero de bits.

La operacion mas utilizada para este tipo de encriptacion es el metodo XOR, debido a que la misma rutina de encriptacion funciona para la desencriptacion.

Codigo Ejemplo1:
Código
  1. mov ecx,(fin_codigovir - ini_codigovir)/2 ; Tomamos el numero de words de longitud del codigo a cifrar
  2. mov esi,ini_codigovir ; Pasamos a ESI el principio del codigo a cifrar
  3. mov edi,esi ; Copiamos en EDI el valor de ESI (principio de codigo a cifrar)
  4. mov bx,0F432h ; Pasamos la llave a bx
  5.  
  6. encrypt_routine:        ; Inicio de la rutina de encriptacion
  7. lodsw ; Movemos a AX el vamor de [ESI] y sumamos 2 a ESI
  8. xor ax,bx        ; XOR a AX con respecto a BX
  9. stosw ; Movemos a [EDI] el valor de AX y sumamos 2 a EDI
  10. loop encrypt_routine

En este ejemplo pasado al ser utilizado el Metodo XOR puede ser utilizado tanto para encriptacion como para desencriptacion.Esto que parece una ventaja para el programador es una desventaja para la encriptacion que este esta realizando en su codigo.

Codigo Ejemplo2(Encriptacion): Quedara de parte del usuario que lee el taller deducir que hace el codigo (Tomenlo como ejercicio mental xD)


Código
  1. mov ecx,(fin_codigovir - ini_codigovir)/2
  2. mov esi,ini_codigovir
  3. mov edi,esi
  4. mov bx,0F432h
  5.  
  6. encrypt_routine:
  7. lodsw
  8. rol al,bh
  9. add al,bl
  10. ror ah,bl
  11. add ah,bh
  12. xor ax,bx
  13. stosw
  14. loop encrypt_routine
  15.  
  16.  
Codigo Ejemplo2(Desencriptacion):Lo mismo de la rutina de  encriptacion (Ejercicio Mental xD)

Código
  1. mov ecx,(fin_codigovir - ini_codigovir)/2
  2. mov esi,ini_codigovir
  3. mov edi,esi
  4. mov bx,0F432h
  5.  
  6. decrypt_routine:
  7. lodsw
  8. ror al,bh
  9. sub al,bl
  10. rol ah,bl
  11. sub ah,bh
  12. xor ax,bx
  13. stosw
  14. loop encrypt_routine
  15.  
  16.  

2.2 Encriptacion por Llaves Corredizas

En el tipo de encriptacion de llave corrediza, en la encriptacion de cada byte la llave experimenta un cambio en su valor. Es una especie de encriptacion simple que dentro de su rutina realiza cambios a la llave de encriptacion.

Codigo Ejemplo1:

Código
  1. mov ecx,(fin_codigovir - ini_codigovir)/2 ; Tomamos el numero de words de longitud del codigo a cifrar
  2. mov esi,ini_codigovir ; Pasamos a ESI el principio del codigo a cifrar
  3. mov edi,esi ; Copiamos en EDI el valor de ESI (principio de codigo a cifrar)
  4. mov bx,0F432h ; Pasamos la llave a bx
  5.  
  6. encrypt_routine: ; Inicio de la rutina de encriptacion
  7. lodsw ; Movemos a AX el vamor de [ESI] y sumamos 2 a ESI
  8. xor ax,bx ; XOR a AX con respecto a BX
  9. stosw ; Movemos a [EDI] el valor de AX y sumamos 2 a EDI
  10. dec bx ; Modificamos el valor de la llave almacenada en bx
  11. loop encrypt_routine
  12.  
  13.  
Al igual que en el ejemplo pasado al ser utilizado el Metodo XOR puede ser utilizado tanto para encriptacion como para desencriptacion.

Codigo Ejemplo2(Encriptacion):Otra vez lo mismo (Ejercicio Mental xD)


Código
  1. mov ecx,(fin_codigovir - ini_codigovir)/2
  2. mov esi,ini_codigovir
  3. mov edi,esi
  4. mov bx,0F432h
  5.  
  6. encrypt_routine:
  7. lodsw
  8. rol al,bh
  9. add al,bl
  10. ror ah,bl
  11. add ah,bh
  12. xor ax,bx
  13. rol bx,bl
  14. dec bx
  15. not bx
  16. stosw
  17. loop encrypt_routine
  18.  
  19.  
Codigo Ejemplo2(Desencriptacion):Me canse de Escribir... a partir de ahora solo pondre (Ejercicio Mental xD)
Código
  1. mov ecx,(fin_codigovir - ini_codigovir)/2
  2. mov esi,ini_codigovir
  3. mov edi,esi
  4. mov bx,0F432h
  5.  
  6. decrypt_routine:
  7. lodsw
  8. ror al,bh
  9. sub al,bl
  10. rol ah,bl
  11. sub ah,bh
  12. xor ax,bx
  13. rol bx,bl
  14. dec bx
  15. not bx
  16. stosw
  17. loop encrypt_routine
  18.  

2.3-Encriptacion por Llaves Largas

En este metodo se toma una sección de datos o codigo mayor al tamaño de un registro para realizar una llave, dicho tamaño estara definido por el programador, por lo tanto la llave puede medir desde 4 bytes hasta donde crea necesario el programador de la rutina de encriptacion.

Codigo Ejemplo1:
Código
  1. mov ecx,(fin_codigovir - ini_codigovir)/2 ; Tomamos el numero de words de longitud del codigo a cifrar
  2. mov esi,ini_codigovir ; Pasamos a ESI el principio del codigo a cifrar
  3. mov edi,esi ; Copiamos en EDI el valor de ESI (principio de codigo a cifrar)
  4. mov ebx,offset ini_llave ; Movemos a ebx la direccion del inicio de la llave
  5. mov dx,fin_llave-ini_llave ; Movemos a dx el tamaño de la llave
  6.  
  7. encrypt_routine: ; Inicio de la rutina de encriptacion
  8. lodsw ; Movemos a AX el vamor de [ESI] y sumamos 2 a ESI
  9. xor ax,bx ; XOR a AX con respecto a BX
  10. add bx,2 ; Nos movemos 1 word dentro de la llave (2bytes)
  11. cmp bx,dx ; Comparamos si bx y dx son iguales
  12. jne cont: ; Si no son iguales continuamos la rutina
  13. mov ebx,offset ini_llave; Si son iguales llegamos al final de la llave, por lo tanto debemos volver al inicio
  14. cont:
  15. stosw ; Movemos a [EDI] el valor de AX y sumamos 2 a EDI
  16. loop encrypt_routine
  17.  
Este tipo de encriptacion no necesita la explicacion de un codigo con un cierto mayor grado de complejidad debido a que simplemente el registro va tomando valores de una llave de gran longitud y la rutina de encriptacion solo esta realizando una encriptacion simple con diferentes valores como llave.

2.4-Encriptacion por Transposicion

Este metodo invierte cada par de Word en la sección de codigo que queremos cifrar, es un metodo muy debil, se podria decir que el mas debil de todos pero combinado con otro de los metodos es un serio dolor de cabeza para quien trate de desencriptarlo manualmente.

Codigo Ejemplo1:
Código
  1. mov ecx,(fin_codigovir - ini_codigovir)/2 -;Tomamos el numero de words de longitud del codigo a cifrar
  2. mov esi,ini_codigovir ; Pasamos a ESI el principio del codigo a cifrar
  3. mov edi,esi ; Copiamos en EDI el valor de ESI (principio de codigo a cifrar)
  4.  
  5. encrypt_routine:
  6. lodsw ; Movemos a AX el valor de [ESI] y sumamos 2 a ESI
  7. mov bx,ax ; Guardamos en BX el valor de AX
  8. lodsw ; Movemos a AX el valor de [ESI] y sumamos 2 a ESI
  9. stosw ; Movemos a [EDI] el valor de AX y sumamos 2 a EDI
  10. mov ax,bx ; Recuperamos el valor que guardamos previamente en BX y lo retornamos a AX
  11. stosw ; Movemos a [EDI] el valor de AX y sumamos 2 a EDI
  12. loop encrypt_routine
  13.  
Como ven no es una rutina de otro mundo y muy debil trabajando sola, debido a que no hace una sustitucion de bytes y con solo alterar el orden de los bytes de word en word ya esta descifrado. Al igual que en el metodo XOR esta rutina puede cifrar o descifrar sin necesidad de modificacion alguna.

3. Despedida

Bueno eso es todo, cualquier toda en lo que concierne al tema pueden dejar sus preguntas en el foro o contactarme via MSN/E-mail que con gusto le respondere las preguntas que tengan. Todo tipo de criticas son aceptadas (Contructivas, Destructivas, Exageradas, Ignorantes, etc.).

Espero que esto sirva de ayuda para aquellos que se motiven en hacer o diseñar sus propias rutinas de encriptacion.

Páginas: 1 2 [3]
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines