时间:2022-09-24 10:19:23 | 栏目:Python代码 | 点击:次
在本章中,让我们了解XOR过程及其在Python中的编码以及乘法密码的教程
XOR算法的加密和解密转换ASCII字节格式的纯文本,并使用XOR过程将其转换为指定的字节.它为用户提供以下优势 :
您可以使用以下代码执行XOR过程 :
def xor_crypt_string(data, key = 'awesomepassword', encode = False, decode = False): from itertools import izip, cycle import base64 if decode: data = base64.decodestring(data) xored = ''.join(chr(ord(x) ^ ord(y)) for (x,y) in izip(data, cycle(key))) if encode: return base64.encodestring(xored).strip() return xored secret_data = "XOR procedure" print("The cipher text is") print xor_crypt_string(secret_data, encode = True) print("The plain text fetched") print xor_crypt_string(xor_crypt_string(secret_data, encode = True), decode = True)
XOR流程的代码为您提供以下输出 :
注意 : XOR加密用于加密数据,并且难以通过强力方法破解,即通过生成随机加密密钥以匹配正确的密文.
使用凯撒密码技术时,加密和解密符号涉及使用简单的加法或减法基本过程将值转换为数字.
如果使用乘法转换为密文,它被称为环绕情况.考虑使用的字母和相关数字如下所示 :
这些数字将用于乘法过程,相关密钥为7.在这种场景中用于生成乘法密码的基本公式如下 :
(Alphabet Number * key)mod(total number of alphabets)
通过输出获取的数字映射到上面提到的表格和相应的字母作为加密字母.
def unshift(key, ch): offset = ord(ch) - ASC_A return chr(((key[0] * (offset + key[1])) % WIDTH) + ASC_A)
注意 : 乘法密码的优点是它可以使用非常大的密钥,如8,953,851.计算机需要相当长的时间才能通过大多数900万个密钥进行暴力破解.