En la sección anterior, presentamos el uso de algunas clases de cifrado y descifrado. Juntémoslas para hacer una prueba simple. El código es el siguiente.
Actividad principal:
Copie el código de código de la siguiente manera:
paquete com.home.testdes;
importar android.os.Bundle;
importar android.util.Log;
importar android.app.Activity;
clase pública MainActivity extiende Actividad {
@Anular
vacío protegido onCreate (paquete saveInstanceState) {
super.onCreate(savedInstanceState);
DESUtil u = nuevo DESUtil();
String mi = u.getEnc("Te amo");
Log.i("Después del cifrado", mi);
Cadena ming = u.getDec(mi);
Log.i("Después del descifrado", ming);
}
}
Herramientas de cifrado y descifrado:
Copie el código de código de la siguiente manera:
paquete com.home.testdes;
importar java.security.Key;
importar java.security.spec.AlgorithmParameterSpec;
importar javax.crypto.Cipher;
importar javax.crypto.SecretKeyFactory;
importar javax.crypto.spec.DESKeySpec;
importar javax.crypto.spec.IvParameterSpec;
importar android.util.Base64;
/**
* Utilice herramientas de cifrado y descifrado DES
*
* @autor Administrador
*
*/
clase pública DESUtil {
clave privada clave;// valor clave de la clave
byte privado[] DESkey;
byte privado[] DESIV = { 0x12, 0x34, 0x56, 0x78, (byte) 0x90, (byte) 0xAB,
(byte) 0xCD, (byte) 0xEF };
private AlgorithmParameterSpec iv = null;// Interfaz de parámetros del algoritmo de cifrado
DESUtil público() {
intentar {
this.DESkey = "abcdefghijk".getBytes("UTF-8");//Establecer la clave
DESKeySpec keySpec = new DESKeySpec(DESkey);//Establecer parámetros clave
iv = new IvParameterSpec(DESIV); // Establecer vector
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");//Obtener la fábrica de claves
key = keyFactory.generateSecret(keySpec);//Obtener el objeto clave
} captura (Excepción e) {
e.printStackTrace();
}
}
/**
* Cadena cifrada, entrada de texto sin formato, salida de texto cifrado
*
* @param cadena de entrada
* Texto sin formato para cifrar
* @return cadena cifrada
*/
cadena pública getEnc (cadena cadena de entrada) {
byte[] byteMi = nulo;
byte[] byteMing = nulo;
Cadena cadena de salida = "";
intentar {
byteMing = inputString.getBytes("UTF-8");
byteMi = this.getEncCode(byteMing);
byte[] temp = Base64.encode(byteMi, Base64.DEFAULT);
cadena de salida = nueva cadena (temperatura);
} captura (Excepción e) {
} finalmente {
byteMing = nulo;
byteMi = nulo;
}
devolver cadena de salida;
}
/**
* Descifrar cadena e ingresar texto sin formato como texto cifrado y salida
*
* @param cadena de entrada
* La cadena que necesita ser descifrada
* @return cadena descifrada
*/
cadena pública getDec (cadena cadena de entrada) {
byte[] byteMing = nulo;
byte[] byteMi = nulo;
Cadena strMing = "";
intentar {
byteMi = Base64.decode(inputString.getBytes(), Base64.DEFAULT);
byteMing = this.getDesCode(byteMi);
strMing = nueva cadena (byteMing, "UTF8");
} captura (Excepción e) {
} finalmente {
byteMing = nulo;
byteMi = nulo;
}
devolver cadena;
}
/**
* El cifrado utiliza la entrada de texto sin formato byte[] y la salida de texto cifrado byte[]
*
* @param bt
* Código de bytes a cifrar
* @return código de bytes cifrado
*/
byte privado[] getEncCode(byte[] bt) {
byte[] byteFina = nulo;
cifrado cifrado;
intentar {
// Obtener instancia de cifrado
cifrado = Cipher.getInstance("DES/CBC/PKCS5Padding");
cifrado.init(Cipher.ENCRYPT_MODE, clave, iv);
byteFina = cifrado.doFinal(bt);
} captura (Excepción e) {
e.printStackTrace();
} finalmente {
cifrado = nulo;
}
devolver byteFina;
}
/**
* El descifrado utiliza la entrada de texto cifrado byte[] y la salida de texto plano byte[]
*
* @param bt
* Código de bytes a descifrar
* @return código de bytes descifrado
*/
byte privado[] getDesCode(byte[] bt) {
cifrado cifrado;
byte[] byteFina = nulo;
intentar {
// Obtener instancia de cifrado
cifrado = Cipher.getInstance("DES/CBC/PKCS5Padding");
cifrado.init(Cipher.DECRYPT_MODE, clave, iv);
byteFina = cifrado.doFinal(bt);
} captura (Excepción e) {
e.printStackTrace();
} finalmente {
cifrado = nulo;
}
devolver byteFina;
}
}