Cifrario ADFGVX - Settembre 2021
L’obiettivo del progetto è sviluppare una semplice applicazione che consenta di cifrare file utilizzando una variante del Cifrario ADFGVX.
Nel cifrario proposto, la chiave è costituita da tre elementi:
- una permutazione dei valori tra 0 e 255 organizzati in una matrice 16x16 (che chiameremo “matrice di conversione” K)
- una permutazione di valori da 0 a 15 (detta vettore colonne, C)
- una permutazione di valori da 0 a 15 (detta vettore righe, R)
- Leggo primo byte da un file (byte b alla posizione k).
- Cerco il byte nella matrice K e salvo la posizione (i,j).
- Modifico il byte con la formula C[(i+k)%16] *16 + R[(j+k)%16].
- Aggiungo nel file di output il byte modificato.
- Leggo primo byte da un file (byte b alla posizione k).
- Divido il byte in 2 nibble (4 bit) v1 e v2.
- Cerco la posizione di v1 in C (i) e v2 in R (j).
- Calcolo byte decodificato alla posizione K[(j-k)%16][(i-k)%16].
- Generare lista L degli elementi da permutare (0-15 per C e R / 0-255 per K).
- Generare lista vuota L'
- Assegnare alla variabile c il valore di input s (c = s).
- Fino a quando L non è vuota: a. v = L[c]. b. Rimuovo v da L. c. Aggiungo v alla fine della lista L'. d. c = (c+k)%N dove N è il numero degli elementi presenti in L.
- Salvare su un file: a. Sequenza di 8 byte che rappresenta il vettore C. b. Sequenza di 8 byte che rappresenta il vettore R. c. Sequenza di 256 byte che rappresenta la matrice K.