最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

详解AES双向对称加解密的用法介绍

来源:动视网 责编:小采 时间:2020-11-27 14:24:23
文档

详解AES双向对称加解密的用法介绍

详解AES双向对称加解密的用法介绍:这篇文章主要介绍了python实现的AES双向对称加密解密与用法,简单分析了AES加密解密算法的基本概念并结合实例形式给出了AES加密解密算法的相关实现技巧与使用注意事项,需要的朋友可以参考下本文实例讲述了python实现的AES双向对称加密解密与用法。分享给大家供
推荐度:
导读详解AES双向对称加解密的用法介绍:这篇文章主要介绍了python实现的AES双向对称加密解密与用法,简单分析了AES加密解密算法的基本概念并结合实例形式给出了AES加密解密算法的相关实现技巧与使用注意事项,需要的朋友可以参考下本文实例讲述了python实现的AES双向对称加密解密与用法。分享给大家供


这篇文章主要介绍了python实现的AES双向对称加密解密与用法,简单分析了AES加密解密算法的基本概念并结合实例形式给出了AES加密解密算法的相关实现技巧与使用注意事项,需要的朋友可以参考下

本文实例讲述了python实现的AES双向对称加密解密与用法。分享给大家供大家参考,具体如下:

高级加密标准(Advanced Encryption Standard,AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准。2006年,高级加密标准已然成为对称密钥加密中最流行的算法之一。

AES只是个基本算法,实现AES有若干模式。其中的CBC模式因为其安全性而被TLS(就是https的加密标准)和IPSec(win采用的)作为技术标准。简单地说,CBC使用密码和salt(起扰乱作用)按固定算法(md5)产生key和iv。然后用key和iv(初始向量,加密第一块明文)加密(明文)和解密(密文)。

下面介绍python实现的AES加密解密实例,这里采用CBC模式,用到了pycrypto?模块

安装:

pip install Crypto
pip install binascii

实现:

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#@author: rui.xu
#这里使用pycrypto?库
#按照方法:easy_install pycrypto?
from Crypto.Cipher import AES
from binascii import b2a_hex, a2b_hex
class prpcrypt():
 def init(self,key):
 self.key = key
 self.mode = AES.MODE_CBC
 #加密函数,如果text不足16位就用空格补足为16位,
 #如果大于16当时不是16的倍数,那就补足为16的倍数。
 def encrypt(self,text):
 cryptor = AES.new(self.key,self.mode,b'0000000000000000')
 #这里密钥key 长度必须为16(AES-128),
 #24(AES-192),或者32 (AES-256)Bytes 长度
 #目前AES-128 足够目前使用
 length = 16
 count = len(text)
 if count < length:
 add = (length-count)
 # backspace
 text = text + ('' * add)
 elif count > length:
 add = (length-(count % length))
 text = text + ('' * add)
 self.ciphertext = cryptor.encrypt(text)
 #因为AES加密时候得到的字符串不一定是ascii字符集的,
输出到终端或者保存时候可能存在问题 #所以这里统一把加密后的字符串转化为16进制字符串 return b2a_hex(self.ciphertext) #解密后,去掉补足的空格用strip() 去掉 def decrypt(self,text): cryptor = AES.new(self.key,self.mode,b'0000000000000000') plain_text = cryptor.decrypt(a2b_hex(text)) return plain_text.rstrip('') if name == 'main': pc = prpcrypt('keyskeyskeyskeys') #初始化密钥 import sys e = pc.encrypt(sys.argv[1]) #加密 d = pc.decrypt(e) #解密 print "加密:",e print "解密:",d

ValueError: IV must be 16 bytes long windows下默认会报这个错,

cryptor = AES.new(self.key,self.mode,b'0000000000000000')

实例化后面加上后面那个就Ok了

【相关推荐】

1. Python免费视频教程

2. Python基础入门教程

3. Python遇见数据采集视频教程

文档

详解AES双向对称加解密的用法介绍

详解AES双向对称加解密的用法介绍:这篇文章主要介绍了python实现的AES双向对称加密解密与用法,简单分析了AES加密解密算法的基本概念并结合实例形式给出了AES加密解密算法的相关实现技巧与使用注意事项,需要的朋友可以参考下本文实例讲述了python实现的AES双向对称加密解密与用法。分享给大家供
推荐度:
标签: 使用 用法 python
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top