古典密码学——代换密码 Substitution Cipher

另一个比较有名的古典密码*是代换密码。

古典密码学——代换密码 Substitution Cipher

在移位密码中,加密和解密都是代数运算,但是在代换密码中,可以认为P和C是26个英文字母,并且可以认为加密和解密的过程直接看作是在一个字母表上的置换。

任意取一置换古典密码学——代换密码 Substitution Cipher,即可得到加密函数,见下表(小写字母表示明文,大写字母表示密文): 

古典密码学——代换密码 Substitution Cipher

按照上表有古典密码学——代换密码 Substitution Cipher,等等。而解密函数则是相应的逆置换。

古典密码学——代换密码 Substitution Cipher

 

代码实现(Python 3)

def substitution_cipher_encrypt(message:str):
    SYMBOLS_PLAINTEXT = 'abcdefghijklmnopqrstuvwxyz'
    SYMBOLS_CIPHERTEXT= 'XNYAHPOGZQWBTSFLRCVMUEKJDI'
    translated = ''

    message = message.lower()
    for symbol in message:
        if symbol in SYMBOLS_PLAINTEXT:
            symbolIndex = SYMBOLS_PLAINTEXT.find(symbol)
            translated = translated + SYMBOLS_CIPHERTEXT[symbolIndex]
        else:
            translated = translated + symbol
    print(translated)

def substitution_cipher_decrypt(message:str):
    SYMBOLS_CIPHERTEXT= 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
    SYMBOLS_PLAINTEXT = 'dlryvohezxwptbgfjqnmuskaci'
    translated = ''

    message = message.upper()
    for symbol in message:
        if symbol in SYMBOLS_CIPHERTEXT:
            symbolIndex = SYMBOLS_CIPHERTEXT.find(symbol)
            translated = translated + SYMBOLS_PLAINTEXT[symbolIndex]
        else:
            translated = translated + symbol
    print(translated)
上一篇:Java对象的访问定位


下一篇:2021-11-11