Foros del Web » Programación para mayores de 30 ;) » Java »

desencriptacion

Estas en el tema de desencriptacion en el foro de Java en Foros del Web. Hola a todos, estoy muy interesado en este tema, encontre en una clase encriptadora el siguiente archivo: Código: // Decompiled by Jad v1.5.8e. Copyright 2001 ...
  #1 (permalink)  
Antiguo 20/08/2009, 19:48
 
Fecha de Ingreso: octubre-2008
Mensajes: 140
Antigüedad: 16 años, 2 meses
Puntos: 1
desencriptacion

Hola a todos, estoy muy interesado en este tema, encontre en una clase encriptadora el siguiente archivo:

Código:
// Decompiled by Jad v1.5.8e. Copyright 2001 Pavel Kouznetsov.
// Jad home page: http://www.geocities.com/kpdus/jad.html
// Decompiler options: packimports(5) braces fieldsfirst noctor nonlb space lnc 
// Source File Name:   DesEncrypter.java

package prueba;

import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.security.InvalidAlgorithmParameterException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.spec.InvalidKeySpecException;
import javax.crypto.*;
import javax.crypto.spec.PBEKeySpec;
import javax.crypto.spec.PBEParameterSpec;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;

public class DesEncrypter {

            Cipher ecipher;
            Cipher dcipher;
            byte salt[] = {
/*  27*/        -87, -101, -56, 50, 86, 53, -29, 3
            };
            int iterationCount;

            DesEncrypter(String passPhrase) {
/*  33*/        iterationCount = 19;
/*  38*/        try {
/*  38*/            java.security.spec.KeySpec keySpec = new PBEKeySpec(passPhrase.toCharArray(), salt, iterationCount);
/*  39*/            SecretKey key = SecretKeyFactory.getInstance("PBEWithMD5AndDES").generateSecret(keySpec);
/*  41*/            ecipher = Cipher.getInstance(key.getAlgorithm());
/*  42*/            dcipher = Cipher.getInstance(key.getAlgorithm());
/*  45*/            java.security.spec.AlgorithmParameterSpec paramSpec = new PBEParameterSpec(salt, iterationCount);
/*  48*/            ecipher.init(1, key, paramSpec);
/*  49*/            dcipher.init(2, key, paramSpec);
                }
/*  50*/        catch (InvalidAlgorithmParameterException e) { }
/*  51*/        catch (InvalidKeySpecException e) { }
/*  52*/        catch (NoSuchPaddingException e) { }
/*  53*/        catch (NoSuchAlgorithmException e) { }
/*  54*/        catch (InvalidKeyException e) { }
            }

            public String encrypt(String str) {
                byte enc[];
/*  61*/        byte utf8[] = str.getBytes("UTF8");
/*  64*/        enc = ecipher.doFinal(utf8);
/*  67*/        return (new BASE64Encoder()).encode(enc);
                BadPaddingException e;
/*  68*/        e;
/*  72*/        break MISSING_BLOCK_LABEL_41;
/*  69*/        e;
/*  72*/        break MISSING_BLOCK_LABEL_41;
/*  70*/        e;
/*  72*/        break MISSING_BLOCK_LABEL_41;
/*  71*/        e;
/*  73*/        return null;
            }

            public String decrypt(String str) {
                byte utf8[];
/*  79*/        byte dec[] = (new BASE64Decoder()).decodeBuffer(str);
/*  82*/        utf8 = dcipher.doFinal(dec);
/*  85*/        return new String(utf8, "UTF8");
                BadPaddingException e;
/*  86*/        e;
/*  90*/        break MISSING_BLOCK_LABEL_45;
/*  87*/        e;
/*  90*/        break MISSING_BLOCK_LABEL_45;
/*  88*/        e;
/*  90*/        break MISSING_BLOCK_LABEL_45;
/*  89*/        e;
/*  91*/        return null;
            }
}
Necesito saber como encripta o desencripta esto las contraseñas que transforma "123456" en "sCS61OvmlQo=".

Gracias a todos por su ayuda.
  #2 (permalink)  
Antiguo 21/08/2009, 03:25
 
Fecha de Ingreso: agosto-2009
Mensajes: 67
Antigüedad: 15 años, 4 meses
Puntos: 0
Respuesta: desencriptacion

Hola.

Para eso deberías estudiar bastante.

El cifrado que está usando es un MD5 y un DES, el MD5 es de clave asimétrica, mientras que el DES es simétrico. Encontrarás en Wikipedia el funcionamiento de ambos algoritmos, aunque si lo que quieres es revertir el proceso te aconsejo que, simplemente, no te molestes. Si lo que quieres es comparar una clave con la que se ha guardado encriptada, lo que deberías hacer es encriptar lo que ha introducido el usuario por teclado y comparar ambas encriptadas.


Espero que te sirva.
Un saludo.
  #3 (permalink)  
Antiguo 21/08/2009, 06:37
 
Fecha de Ingreso: octubre-2008
Mensajes: 140
Antigüedad: 16 años, 2 meses
Puntos: 1
Respuesta: desencriptacion

Cita:
Iniciado por tistklehoff Ver Mensaje
Hola.

Para eso deberías estudiar bastante.

El cifrado que está usando es un MD5 y un DES, el MD5 es de clave asimétrica, mientras que el DES es simétrico. Encontrarás en Wikipedia el funcionamiento de ambos algoritmos, aunque si lo que quieres es revertir el proceso te aconsejo que, simplemente, no te molestes. Si lo que quieres es comparar una clave con la que se ha guardado encriptada, lo que deberías hacer es encriptar lo que ha introducido el usuario por teclado y comparar ambas encriptadas.


Espero que te sirva.
Un saludo.
Hola, gracias por contestar. Lo que necesito es justamente comparar los passwords encriptados por ello necesito saber exactamente como es que se encriptan las claves, ademas quisiera saber que papel juega: byte salt[] = {-87, -101, -56, 50, 86, 53, -29, 3};

Gracias por la ayuda.
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 01:56.