其他分享
首页 > 其他分享> > 古典密码学——代换密码 Substitution Cipher

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

作者:互联网

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

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

任意取一置换,即可得到加密函数,见下表(小写字母表示明文,大写字母表示密文): 

按照上表有,等等。而解密函数则是相应的逆置换。

 

代码实现(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)

标签:CIPHERTEXT,PLAINTEXT,symbol,SYMBOLS,Cipher,Substitution,translated,message,密码学
来源: https://www.cnblogs.com/vicky2021/p/15636371.html