Kryptografia z Pythonem - Affine Cipher

Szyfr afiniczny to połączenie szyfru multiplikatywnego i algorytmu szyfru Cezara. Podstawowa implementacja szyfru afinicznego jest pokazana na poniższym obrazku -

W tym rozdziale zaimplementujemy szyfr afiniczny, tworząc odpowiednią klasę, która zawiera dwie podstawowe funkcje do szyfrowania i deszyfrowania.

Kod

Możesz użyć następującego kodu, aby zaimplementować szyfr afiniczny -

class Affine(object):
   DIE = 128
   KEY = (7, 3, 55)
   def __init__(self):
      pass
   def encryptChar(self, char):
      K1, K2, kI = self.KEY
      return chr((K1 * ord(char) + K2) % self.DIE)
		
   def encrypt(self, string):
      return "".join(map(self.encryptChar, string))
   
   def decryptChar(self, char):
      K1, K2, KI = self.KEY
      return chr(KI * (ord(char) - K2) % self.DIE)
   
   def decrypt(self, string):
      return "".join(map(self.decryptChar, string))
		affine = Affine()
print affine.encrypt('Affine Cipher')
print affine.decrypt('*18?FMT')

Wynik

Po zaimplementowaniu szyfru afinicznego można zaobserwować następujące dane wyjściowe -

Dane wyjściowe wyświetlają zaszyfrowaną wiadomość dla zwykłej wiadomości tekstowej Affine Cipher i odszyfrowana wiadomość dla wiadomości wysłanej jako dane wejściowe abcdefg.