crypto/crittografia/unicode.py
Rnhmjoj e88bad83f8 Correzioni varie
* Completata corretamente la fattorizzazione dei numeri di Gödel
* Corretto un errore nell’algoritmo del test di primalità
* Corretto un un problema con l’input del microfono (lo stream si
chiudeva prima di aver effetttivamente registrato)
2013-12-09 22:20:36 +01:00

125 lines
2.7 KiB
Python

from .numeri import *
max = 2 ** 16
class codifica:
def __init__(self, valore):
"""
Inizializzazione
Fornire una stringa da crittografare.
"""
self.stringa = valore
def rot13(self):
"""
Cifrario ROT13
"""
rotazione = str.maketrans(
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ",
"nopqrstuvwxyzabcdefghijklmNOPQRSTUVWXYZABCDEFGHIJKLM"
)
return str.translate(self.stringa, rotazione)
def vigenère(self, verme):
"""
Cifrario di vigenère
Fornire una chiave alfabetica di lunghezza
minore della stringa. (verme)
"""
cifrata = []
for i, lettera in enumerate(self.stringa):
cifrata.append(
chr((ord(lettera) + ord(verme[i % len(verme)])) % max)
)
return "".join(cifrata)
def gödel(self, primo=2):
"""
Numero di Gödel
Specificare un numero primo di partenza.
"""
cifrata = 1
sequenza = primi.primi(primo, len(self.stringa))
for i, lettera in enumerate(self.stringa):
cifrata *= next(sequenza) ** ord(lettera)
return cifrata
def vernam(self, pad=()):
"""
Cifrario di Vernam
Se non si fornisce un one-time-pad ne viene generato
uno in automatico.
"""
cifrata = []
if pad is ():
pad = generatore.onetimepad(len(self.stringa))
for i, lettera in enumerate(self.stringa):
cifrata.append(
chr((ord(lettera) + pad[i]) % max)
)
return "".join(cifrata), pad
class decodifica:
def __init__(self, valore):
"""
Inizializzazione
Fornire una stringa o un numero (di gödel) da decrittografare.
"""
if str(valore).isnumeric():
self.numero = valore
else:
self.stringa = valore
def rot13(self):
"""
Cifrario ROT13
"""
rotazione = str.maketrans(
"nopqrstuvwxyzabcdefghijklmNOPQRSTUVWXYZABCDEFGHIJKLM",
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
)
return str.translate(self.stringa, rotazione)
def vigenère(self, verme):
"""
Cifrario di vigenère
Fornire la chiave usata per crittografare la stringa. (verme)
"""
decifrata = []
for i, lettera in enumerate(self.stringa):
decifrata.append(
chr((ord(lettera) - ord(verme[i % len(verme)])) % max)
)
return "".join(decifrata)
def gödel(self, n, primo=2):
"""
Numero di Gödel
Specificare un numero primo di partenza e
la lunghezza della stringa.
"""
decifrata = []
for i in primi.primi(primo, n):
r, s = 0, self.numero
while s % i == 0:
r += 1
s //= i
decifrata.append(chr(r % max))
return "".join(decifrata)
def vernam(self, pad):
"""
Cifrario di Vernam
Fornire il one-time-pad usato per crittografare la stringa.
"""
cifrata = []
for i, lettera in enumerate(self.stringa):
cifrata.append(
chr((ord(lettera) - pad[i]) % max)
)
return "".join(cifrata)