-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDesempaquetarCompostela.java
126 lines (99 loc) · 4.6 KB
/
DesempaquetarCompostela.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
import java.io.*;
import java.security.*;
import java.security.spec.*;
import javax.crypto.*;
import javax.crypto.interfaces.*;
import javax.crypto.spec.*;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import java.util.HashMap;
import java.util.Map;
import java.util.Arrays;
/**
* @author Samuel Ramilo Conde
* @author Esteban Puentes Silveira
* @code https://github.com/VirtualEvan/SSI_Cryptography
*/
public class DesempaquetarCompostela {
public static SecretKey descifrarRSA(byte[] claveEncriptada, String nombreClave) throws Exception{
Security.addProvider(new BouncyCastleProvider()); // Cargar el provider BC
//Descifrar clave encriptada
byte[] bufferClave = Utils.desencriptarConPrivada( claveEncriptada, nombreClave);
//Crear SKF (Transformacion de SecretKeys)
SecretKeyFactory secretKeyFactoryDES = SecretKeyFactory.getInstance("DES");
DESKeySpec DESspec = new DESKeySpec(bufferClave);
SecretKey claveDES = secretKeyFactoryDES.generateSecret(DESspec);
return claveDES;
}
public static String descifrarDatos(SecretKey claveDES, byte[] datosCifrados) throws Exception{
// Cargar el provider BC
Security.addProvider(new BouncyCastleProvider());
//Crear el cifrador
Cipher cifrador = Cipher.getInstance("DES/ECB/PKCS5Padding");
//Cifrador en modo descifrado
cifrador.init(Cipher.DECRYPT_MODE, claveDES);
byte[] bufferPlano = cifrador.doFinal(datosCifrados);
String datos = new String(bufferPlano);
return datos;
}
public static void mensajeAyuda() {
System.out.println("Desempaquetador de Compostela");
System.out.println("\tSintaxis: java GenerarClaves [nombre de la compostela] [nombre clave privada oficina] [nombre clave publica peregrino]");
System.out.println();
}
public static final void main(String args[]){
if (args.length != 3) {
mensajeAyuda();
System.exit(1);
}
System.out.println();
System.out.println("DESEMPAQUETAR COMPOSTELA *************************************************");
Paquete compostelaVirtual = PaqueteDAO.leerPaquete( args[0]+".paquete" );
try {
byte[] claveEncriptada = compostelaVirtual.getContenidoBloque( "CLAVE_ENCRIPTADA" );
byte[] datosCifrados = compostelaVirtual.getContenidoBloque( "DATOS_CIFRADOS" );
byte[] firmaEncriptada = compostelaVirtual.getContenidoBloque( "FIRMA_DIGITAL" );
compostelaVirtual.eliminarBloque( "CLAVE_ENCRIPTADA" );
compostelaVirtual.eliminarBloque( "DATOS_CIFRADOS" );
compostelaVirtual.eliminarBloque( "FIRMA_DIGITAL" );
SecretKey claveDES = descifrarRSA( claveEncriptada, args[1] );
String datosPeregrino = descifrarDatos( claveDES, datosCifrados );
byte[] firmaPeregrinoDesencriptada = Utils.desencriptarConPublica( firmaEncriptada, args[2] );
byte[] firmaPeregrinoGenerada = Utils.generarFirma( datosPeregrino );
System.out.println( "***COMPORBANDO PEREGRINO***" );
System.out.println(datosPeregrino);
if( Arrays.equals(firmaPeregrinoDesencriptada,firmaPeregrinoGenerada) ) {
System.out.println( "LOS DATOS NO HAN SIDO ALTERADOS" );
}
else {
System.out.println( "ERROR: DATOS ALTERADOS" );
}
System.out.println( "***COMPORBANDO ALBERGUES***" );
int count = 0;
while( compostelaVirtual.getNombresBloque().size()!=count ){
System.out.println( "Comprobando Actualmente: " +compostelaVirtual.getNombresBloque().get(count).replace( "_DATOS", "" ) );
String datos = new String( compostelaVirtual.getContenidoBloque( compostelaVirtual.getNombresBloque().get(count) ) );
byte[] firmaAlbergueEncriptada = compostelaVirtual.getContenidoBloque( compostelaVirtual.getNombresBloque().get(count + 1) );
byte[] firmaAlbergueDesencriptada = Utils.desencriptarConPublica( firmaAlbergueEncriptada, compostelaVirtual.getNombresBloque().get(count).replace( "_DATOS", "" ) );
//compostelaVirtual.eliminarBloque( compostelaVirtual.getNombresBloque().get(count) );
//compostelaVirtual.eliminarBloque( compostelaVirtual.getNombresBloque().get(count + 1) );
count+=2;
if( Arrays.equals( firmaAlbergueDesencriptada, Utils.generarFirma( datos, firmaPeregrinoDesencriptada ) ) ) {
System.out.println( "LOS DATOS NO HAN SIDO ALTERADOS" );
System.out.println( datos );
}
else {
System.out.println( "ERROR: DATOS ALTERADOS" );
}
}
/*
for (String nombre : compostelaVirtual.getNombresBloque()){
System.out.println( nombre );
}*/
}
catch(Exception e){
System.out.println(e);
}
/*
*/
}
}