本文使用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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Java AES加密解密的简单实现方法,包括了Java AES加密解密的简单实现方法的使用技巧和注意事项,需要的朋友参考一下 废话不多说,直接上代码 以上这篇Java AES加密解密的简单实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
本文向大家介绍python实现RSA加密(解密)算法,包括了python实现RSA加密(解密)算法的使用技巧和注意事项,需要的朋友参考一下 RSA是目前最有影响力的公钥加密算法,它能够抵抗到目前为止已知的绝大多数密码攻击,已被ISO推荐为公钥数据加密标准。 今天只有短的RSA钥匙才可能被强力方式解破。到2008年为止,世界上还没有任何可靠的攻击RSA算法的方式。只要其密钥的长度足够长,用RSA加密
本文向大家介绍python实现移位加密和解密,包括了python实现移位加密和解密的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python实现移位加密和解密的具体代码,供大家参考,具体内容如下 代码很简单,就不多做解释啦。主要思路是将字符串转为Ascii码,将大小写字母分别移位密钥表示的位数,然后转回字符串。需要注意的是,当秘钥大于26的时候,我使用循环将其不断减去26,直到密钥
本文向大家介绍PHP实现的简单对称加密与解密方法实例小结,包括了PHP实现的简单对称加密与解密方法实例小结的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP实现的简单对称加密与解密方法。分享给大家供大家参考,具体如下: 方法一:YII自带的加密方法 方法二: 方法三: 方法四: PS:关于加密解密感兴趣的朋友还可以参考本站在线工具: 文字在线加密解密工具(包含AES、DES、RC4等)
本文向大家介绍Python实现AES加密,解密的两种方法,包括了Python实现AES加密,解密的两种方法的使用技巧和注意事项,需要的朋友参考一下 第一种 第二种 以上就是Python实现AES加密,解密的两种方法的详细内容,更多关于Python实现AES加密,解密的资料请关注呐喊教程其它相关文章!
配置 在使用 Lumens 的加解密前,你应该先把 .env 文件中的 APP_KEY 选项设置为 32 位随机字符串。如果没有适当地设置这个值,所有被 Lumen 加密的值都将是不安全的。 基本用法 加密一个值 你可以使用 Crypt 门面来加密一个值。所有的加密值都使用 OpenSSL 和 AES-256-CBC 来进行加密。 此外, 所有加密过的值都会使用消息认证码 (MAC)来进行签名,以