crypto/crittografia/unicode.py
Rnhmjoj 916515e5e2 Miglioramenti vari
* Sostituito il test di primalità con il Miller-Rabin (k=64) (più
veloce ma non deterministico)
* Utlizzati generatori in sostituzione alle tuple (più veloce)
* Sostituita la concatenazione di stringhe con join (più veloce)
* Correzioni per PEP8
2013-12-06 19:57:21 +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):
"""
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) + 1)
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, primo, n):
"""
Numero di Gödel
Specificare un numero primo di partenza e
la lunghezza della stringa.
"""
decifrata = []
for i in primi.primi(primo, n):
lettera = -1
while self.numero % i == 0:
self.numero /= i
lettera += 1
decifrata.append(chr(lettera % max))
return 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)