python实现AES的加密解密

前言

    好久没有写技术方面的博客了,校招进了一个金融支付公司,做的都是跟技术相关性不太强的工作,实在干的不顺心,申请去上海分公司做大数据/AI的开发了,第一个任务就是用flask把数据加密,然后存进ceph里面,虽然flask,ceph以前都没怎么听过,但是还是觉得做技术比较顺心,一周大概就能上手了,专门研究了下AES算法,分享一下。

正文

    首先介绍下AES(Advanced Encryption Standard),你只要知道它就是一种美国人搞的对称加密算法(自行百度对称和非对称加密算法),已经被多方分析且广为全世界所使用,目前是比较安全安全的,下面是AES加密解密的一个流程图:

                                                                       图1 AES加密解密流程图

 

     AES为分组密码,何为分组密码呢?就是把明文P分成一组一组的,每组的长度相等,每次加密一组数据,直到加密完整个明文。在AES标准规范中,分组长度只能是128位,也就是说,每个分组为16个字节(每个字节8位)。密钥的长度可以使用128位、192位或256位。密钥的长度不同,推荐加密轮数也不同。(一般常用的就是128位,我也用128位)

例子

def encrypt(data):
    #1.加密数据
    # 密钥key 长度必须为16(AES-128)、24(AES-192)、或32(AES-256)Bytes 长度.
    # 目前AES-128足够用
    key = b'\'   #这个自己设置,我就不放了
    # 生成长度等于AES块大小的不可重复的密钥向量
    iv = Random.new().read(AES.block_size)
    # 使用key和iv初始化AES对象, 使用MODE_CFB模式
    mycipher = AES.new(key, AES.MODE_CFB, iv)
    # 加密的明文长度必须为16的倍数,如果长度不为16的倍数,则需要补足为16的倍数
    # 将iv(密钥向量)加到加密的密文开头,一起传输
    ciphertext = iv + mycipher.encrypt(data)
    return ciphertext


# 解密
def dencrypt(self,ciphertext):
    key = b''
    mydecrypt = AES.new(key, AES.MODE_CFB, ciphertext[:16])
    decrypttext = mydecrypt.decrypt(ciphertext[16:])
    return decrypttext

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是Python实现AES加密解密算法程序的示例代码: ```python import base64 from Crypto.Cipher import AES # 定义加密函数 def aes_encrypt(key, data): # 将密钥和数据分别进行base64编码 key = base64.b64encode(key.encode('utf-8')).decode('utf-8') data = base64.b64encode(data.encode('utf-8')).decode('utf-8') # 使用CBC模式加密 cipher = AES.new(key.encode('utf-8'), AES.MODE_CBC, b'0000000000000000') # 加密数据 encrypted_data = cipher.encrypt(data.encode('utf-8')) # 将加密后的数据进行base64编码 encrypted_data = base64.b64encode(encrypted_data).decode('utf-8') return encrypted_data # 定义解密函数 def aes_decrypt(key, encrypted_data): # 将密钥进行base64编码 key = base64.b64encode(key.encode('utf-8')).decode('utf-8') # 将加密后的数据进行base64解码 encrypted_data = base64.b64decode(encrypted_data) # 使用CBC模式解密 cipher = AES.new(key.encode('utf-8'), AES.MODE_CBC, b'0000000000000000') # 解密数据 decrypted_data = cipher.decrypt(encrypted_data).decode('utf-8') # 将解密后的数据进行base64解码 decrypted_data = base64.b64decode(decrypted_data).decode('utf-8') return decrypted_data # 测试加密解密函数 if __name__ == '__main__': key = '1234567890abcdef' # 密钥长度必须为16、24或32个字符 data = '这是一条测试数据' encrypted_data = aes_encrypt(key, data) print('加密后的数据:', encrypted_data) decrypted_data = aes_decrypt(key, encrypted_data) print('解密后的数据:', decrypted_data) ``` 需要注意的是,上述示例代码中使用的是AES加密算法中的CBC模式,密钥长度必须为16、24或32个字符。如果需要使用其他模式或密钥长度,需要根据具体情况进行修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值