python加密算法代码_python实现字符串加密成纯数字

本文实例为大家分享了python实现字符串加密成纯数字的具体代码,供大家参考,具体内容如下

说明:

该加密算法仅仅是做一个简单的加密,安全性就不谈了,哈哈.

算法流程:

1.字符串以utf8编码成字节数组

2.把每一个字节转换成十进制数字字符串('0'~'255')

3.在每个十进制数字字符串之前加上一个长度位(长度位固定只占1个字符)

4.进行数字替换,例如:(0-1,1-9,2-3,3-8,4-7,5-6,6-2,7-4,8-5,9-0)

代码实现:

加密:

#加密

def encrypt(srcStr,password='1938762450'):

#将字符串转换成字节数组

data=bytearray(srcStr.encode('utf-8'))

#把每个字节转换成数字字符串

strList=[str(byte) for byte in data]

#给每个数字字符串前面加一个长度位

strList=[str(len(s))+s for s in strList]

#进行数字替换

for index0 in range(len(strList)):

tempStr = ""

for index in range(len(strList[index0])):

tempStr+=password[int(strList[index0][index])]

strList[index0]=tempStr

return "".join(strList)

解密:

#解密

def decrypt(srcStr,password='1938762450'):

#数字替换还原

tempStr=""

for index in range(len(srcStr)):

tempStr+=str(password.find(srcStr[index]))

#去掉长度位,还原成字典

index=0

strList=[]

while True:

#取长度位

length=int(tempStr[index])

#取数字字符串

s=tempStr[index+1:index+1+length]

#加入到列表中

strList.append(s)

#增加偏移量

index+=1+length

#退出条件

if index>=len(tempStr):

break

data=bytearray(len(strList))

for i in range(len(data)):

data[i]=int(strList[i])

return data.decode('utf-8')

测试:

if __name__ == '__main__':

ret=encrypt('id:123,time:7200,key:123456789987654321','1938762450')

print('密文:',ret)

ret=decrypt(ret,'1938762450')

print('原文:',ret)

运行结果:

19101530364080887746957603.jpg

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会尽力回答你的问题。 首先,让我们来了解一下移位 XOR 加密算法的原理。这种加密算法是通过将明文中的每个字符与一个密钥中的对应字符进行异或操作来实现的。具体来说,如果明文为 M,密钥为 K,加密后的密文为 C,那么加密过程如下: * 对于明文中的每个字符 M[i],将其与密钥中对应的字符 K[i%len(K)] 进行异或操作,得到密文中的对应字符 C[i]。 解密过程与加密过程类似,只需要将密钥中的字符和密文中的字符进行异或操作即可。 接下来,我们来看一下如何使用 Python 实现移位 XOR 加密算法的还原过程。假设我们已经得到了加密后的密文 C 和密钥 K,那么还原过程如下: ```python def decrypt(ciphertext, key): plaintext = "" for i in range(len(ciphertext)): # 对每个密文字符和密钥字符进行异或操作 plainchar = chr(ord(ciphertext[i]) ^ ord(key[i % len(key)])) plaintext += plainchar return plaintext ``` 在上面的代码中,我们首先定义了一个 decrypt 函数,它接受两个参数:密文和密钥。然后,我们使用一个 for 循环遍历密文中的每个字符,并将其与密钥中对应的字符进行异或操作,最终得到还原后的明文。 注意,在 Python 中,我们可以使用 ord 函数将字符转换为 ASCII 码,使用 chr 函数将 ASCII 码转换回字符。另外,由于 Python 中的字符串是不可变的,这里我们使用一个空字符串 plaintext 来逐步构建还原后的明文。 希望这个答案能够帮到你!如果你有其他问题,可以继续问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值