AES加密

AES加密,对称加密,区块加密,秘钥通常为128bit,明文也是128bit一组,每组按照算法加密,生成128bit密文,每组拼接起来形成最终的密文。
两种模式:ECB和CBC

电码本模式(Electronic Codebook Book (ECB)
这种模式是将整个明文分成若干段相同的小段,然后对每一小段进行加密
密码分组链接模式(Cipher Block Chaining (CBC))
这种模式是先将明文切分成若干小段,然后每一小段与初始块(iv)或者上一段的密文段进行异或运算后,再与密钥进行加密。

以秘钥128bit ECB模式加密说明
1
整体流程:
1次秘钥扩展(由用户输入的秘钥生成往后10次操作每轮的秘钥,加上本次操作,总共实现11轮轮秘钥加)
9次组合(S盒替换,行移位,列混合,轮秘钥加)
1次组合(S盒替换,行移位,轮秘钥加)
总共11轮运算
模板脚本

from Cryptodome.Cipher import AES
key=b'0123456789abcdef'
aes=AES.new(key,AES.MODE_ECB)
en_data=aes.encrypt(b'codes are simple')
print(en_data)
aes2=AES.new(key,AES.MODE_ECB)
de_data=aes2.decrypt(en_data)
print(de_data)
iv=b'9876543219874543'
aes3=AES.new(key,AES.MODE_CBC,iv)
en_data1=aes3.encrypt(b'codes are simple')
print(en_data1)
from Crypto.Cipher import AES
from Crypto.Util.number import *
key = long_to_bytes(0xcb8d493521b47a4cc1ae7e62229266ce)
mi = long_to_bytes(0xbc0aadc0147c5ecce0b140bc9c51d52b46b2b9434de5324bad7fb4b39cdb4b5b)
lun = AES.new(key, mode=AES.MODE_ECB)
flag = lun.decrypt(mi)
print(flag)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值