Testowanie prostego szyfru podstawieniowego

W tym rozdziale skupimy się na testowaniu szyfru podstawieniowego przy użyciu różnych metod, które pomagają generować losowe ciągi, jak podano poniżej -

import random, string, substitution
def main():
   for i in range(1000):
      key = substitution.getRandomKey()
      message = random_string()
      print('Test %s: String: "%s.."' % (i + 1, message[:50]))
      print("Key: " + key)
      encrypted = substitution.translateMessage(message, key, 'E')
      decrypted = substitution.translateMessage(encrypted, key, 'D')
      
      if decrypted != message:
         print('ERROR: Decrypted: "%s" Key: %s' % (decrypted, key))
         sys.exit()
      print('Substutition test passed!')

def random_string(size = 5000, chars = string.ascii_letters + string.digits):
   return ''.join(random.choice(chars) for _ in range(size))
if __name__ == '__main__':
   main()

Wynik

Możesz obserwować dane wyjściowe jako losowo generowane ciągi, które pomagają w generowaniu losowych zwykłych wiadomości tekstowych, jak pokazano poniżej -

Po pomyślnym zakończeniu testu możemy obserwować komunikat wyjściowy Substitution test passed!.

W ten sposób możesz zhakować szyfr podstawieniowy w systematyczny sposób.