python简单加密算法_python实现简单加密解密机制

本文使用python实现一个简单的加密解密机制。

描述:结合26个字母、以一个单词作为秘钥,使用python实现简单的加密解密机制

秘钥:大写的英文字符串

明文:包含空格、大小写字母、数字等的字符串

代码实现:

# -*- coding: utf-8 -*-

import os,sys

reload(sys)

sys.setdefaultencoding('utf8')

import string

def suanfa(key):

alp = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'

jiami_key = {}

jiemi_key = {}

list0 = list(alp)

list1 = list(key)

list2 = list(alp)

for n in list1:

for m in list2:

if m == n:

list2.remove(m)

alp1 = ''.join(list2)

key1 = key + alp1

list3 = list(key1)

a = 0

if a < len(list0):

for m in list0:

jiami_key[m] = list3[a]

a = a + 1

b = 0

if b < len(list3):

for n in list3:

jiemi_key[n] = list0[b]

b = b + 1

#print jiami_key

#print jiemi_key

return jiami_key, jiemi_key

def bianma(key_dic, data):

list_data = list(data)

data1 = []

for a in list_data:

if a == ' ':

data1.append(a)

elif a.islower():

a = a.upper()

if key_dic.has_key(a):

x = key_dic[a]

data1.append(x.lower())

elif a.isupper():

if key_dic.has_key(a):

x = key_dic[a]

data1.append(x)

else:

data1.append(a)

data2 = ''.join(data1)

#print data2

return data2

def main():

key = 'ZDFKJMNX'

data = 'a bdcd sFDGDSGFDG113243 3'

print "秘钥:" + key

print "明文:" + data

jiami_key, jiemi_key = suanfa(key)

miwen = bianma(jiami_key, data)

mingwen = bianma(jiemi_key, miwen)

print "加密明文所得的密文:" + miwen

print "解密密文所得的明文:" + mingwen

return True

if __name__ == "__main__":

main()

运行结果:

# python jiami.py

秘钥:ZDFKJMNX

明文:a bdcd sFDGDSGFDG113243 3

加密明文所得的密文:z dkfk qMKNKQNMKN113243 3

解密密文所得的明文:a bdcd sFDGDSGFDG113243 3

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

本文标题: python实现简单加密解密机制

本文地址: http://www.cppcns.com/jiaoben/python/254643.html

好的,我会尽力回答你的问题。 首先,让我们来了解一下移位 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、付费专栏及课程。

余额充值