Kryptografia z Pythonem - szyfr Cezara

W ostatnim rozdziale zajmowaliśmy się szyfrowaniem odwrotnym. W tym rozdziale szczegółowo omówiono szyfr Cezara.

Algorytm szyfru Cezara

Algorytm szyfru Cezara ma następujące cechy -

  • Technika szyfrowania Cezara to prosta i łatwa metoda techniki szyfrowania.

  • Jest to prosty szyfr podstawieniowy.

  • Każda litera zwykłego tekstu jest zastępowana literą z pewną ustaloną liczbą pozycji w dół alfabetu.

Poniższy diagram przedstawia działanie algorytmu szyfru Cezara -

Programowa implementacja algorytmu szyfru Cezara jest następująca:

def encrypt(text,s):
result = ""
   # transverse the plain text
   for i in range(len(text)):
      char = text[i]
      # Encrypt uppercase characters in plain text
      
      if (char.isupper()):
         result += chr((ord(char) + s-65) % 26 + 65)
      # Encrypt lowercase characters in plain text
      else:
         result += chr((ord(char) + s - 97) % 26 + 97)
      return result
#check the above function
text = "CEASER CIPHER DEMO"
s = 4

print "Plain Text : " + text
print "Shift pattern : " + str(s)
print "Cipher: " + encrypt(text,s)

Wynik

Możesz zobaczyć szyfr Cezara, czyli wyjście, jak pokazano na poniższym obrazku -

Wyjaśnienie

Przez zwykły tekst przechodzi się pojedynczo.

  • Dla każdego znaku w podanym zwykłym tekście przekształć podany znak zgodnie z regułą w zależności od procedury szyfrowania i deszyfrowania tekstu.

  • Po wykonaniu tych kroków generowany jest nowy ciąg, nazywany zaszyfrowanym tekstem.

Hakowanie algorytmu szyfru Cezara

Zaszyfrowany tekst można zhakować na różne sposoby. Jedną z takich możliwości jestBrute Force Technique,co wymaga wypróbowania każdego możliwego klucza deszyfrującego. Ta technika nie wymaga dużego wysiłku i jest stosunkowo prosta dla hakera.

Implementacja programu do hakowania algorytmu szyfru Cezara jest następująca -

message = 'GIEWIVrGMTLIVrHIQS' #encrypted message
LETTERS = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'

for key in range(len(LETTERS)):
   translated = ''
   for symbol in message:
      if symbol in LETTERS:
         num = LETTERS.find(symbol)
         num = num - key
         if num < 0:
            num = num + len(LETTERS)
         translated = translated + LETTERS[num]
      else:
         translated = translated + symbol
print('Hacking key #%s: %s' % (key, translated))

Rozważ zaszyfrowany tekst zaszyfrowany w poprzednim przykładzie. Następnie wynik z możliwymi metodami hakowania za pomocą klucza i przy użyciu techniki ataku brute force jest następujący -