crypto/crittografia/unicode.py

115 lines
2.6 KiB
Python
Raw Normal View History

2013-08-04 21:40:54 +02:00
from .numeri import *
2013-07-15 15:34:50 +02:00
max = 2**(16)
class codifica:
2012-12-25 23:19:52 +01:00
def __init__(self, valore):
2013-08-04 21:40:54 +02:00
"""
Inizializzazione
Fornire una stringa da crittografare.
"""
self.stringa = valore
2013-07-15 15:34:50 +02:00
def rot13(self):
2013-08-04 21:40:54 +02:00
"""
Cifrario ROT13
"""
2013-07-15 15:34:50 +02:00
rotazione = str.maketrans(
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ",
"nopqrstuvwxyzabcdefghijklmNOPQRSTUVWXYZABCDEFGHIJKLM"
2013-07-15 15:34:50 +02:00
)
return str.translate(self.stringa, rotazione)
def vigenère(self, verme):
2013-08-04 21:40:54 +02:00
"""
Cifrario di vigenère
Fornire una chiave alfabetica di lunghezza
minore della stringa. (verme)
"""
2013-07-15 15:34:50 +02:00
cifrata = ""
for i in range(len(self.stringa)):
cifrata += chr((ord(self.stringa[i]) + ord(verme[i % len(verme)])) % max)
return cifrata
def gödel(self, primo):
2013-08-04 21:40:54 +02:00
"""
Numero di Gödel
Specificare un numero primo di partenza.
"""
2013-07-15 15:34:50 +02:00
cifrata = 1
sequenza = primi.lista(primo, len(self.stringa))
for i in range(len(self.stringa)):
cifrata *= sequenza[i]**(ord(self.stringa[i]) + 1)
return cifrata
def vernam(self, pad=()):
2013-08-04 21:40:54 +02:00
"""
Cifrario di Vernam
Se non si fornisce un one-time-pad ne viene generato
uno in automatico.
"""
2013-07-15 15:34:50 +02:00
cifrata = ""
if pad is ():
2013-07-15 15:34:50 +02:00
pad = generatore.onetimepad(len(self.stringa))
for i in range(len(self.stringa)):
cifrata += chr((ord(self.stringa[i]) + pad[i]) % max)
return cifrata, pad
class decodifica:
2012-12-25 23:19:52 +01:00
def __init__(self, valore):
2013-08-04 21:40:54 +02:00
"""
Inizializzazione
Fornire una stringa o un numero (di gödel) da decrittografare.
"""
if str(valore).isnumeric():
self.numero = valore
else:
self.stringa = valore
2013-07-15 15:34:50 +02:00
def rot13(self):
2013-08-04 21:40:54 +02:00
"""
Cifrario ROT13
"""
2013-07-15 15:34:50 +02:00
rotazione = str.maketrans(
"nopqrstuvwxyzabcdefghijklmNOPQRSTUVWXYZABCDEFGHIJKLM",
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
2013-07-15 15:34:50 +02:00
)
return str.translate(self.stringa, rotazione)
def vigenère(self, verme):
2013-08-04 21:40:54 +02:00
"""
Cifrario di vigenère
Fornire la chiave usata per crittografare la stringa. (verme)
"""
2013-07-15 15:34:50 +02:00
decifrata = ""
for i in range(len(self.stringa)):
decifrata += chr((ord(self.stringa[i]) - ord(verme[i % len(verme)])) % max)
return decifrata
def gödel(self, primo, n):
2013-08-04 21:40:54 +02:00
"""
Numero di Gödel
Specificare un numero primo di partenza e
la lunghezza della stringa.
"""
2013-07-15 15:34:50 +02:00
decifrata = ""
for i in primi.lista(primo,n):
lettera = -1
while self.numero % i == 0:
self.numero /= i
lettera += 1
decifrata += chr(lettera % max)
return decifrata
def vernam(self, pad):
2013-08-04 21:40:54 +02:00
"""
Cifrario di Vernam
Fornire il one-time-pad usato per crittografare la stringa.
"""
2013-07-15 15:34:50 +02:00
cifrata = ""
for i in range(len(self.stringa)):
cifrata += chr((ord(self.stringa[i]) - pad[i]) % max)
return cifrata