python aes new_python AES 加密
pad: ZeroPadding
mode: cbc
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# 这里使用pycrypto库
# 按照方法:easy_install pycrypto
from Crypto.Cipher import AES
import base64
class prpcrypt():
def __init__(self, key, iv):
self.key = key
self.mode = AES.MODE_CBC
self.iv = iv
# 加密函数,如果text不足16位就用空格补足为16位,
# 如果大于16当时不是16的倍数,那就补足为16的倍数。
def encrypt(self, text):
cryptor = AES.new('123454536f667445454d537973576562',
self.mode, IV=self.iv)
# 这里密钥key 长度必须为16(AES-128),
# 24(AES-192),或者32 (AES-256)Bytes 长度
# 目前AES-128 足够目前使用
length = 16
count = len(text)
if count < length:
add = (length - count)
#\0 backspace
text = text + ('\0' * add)
elif count > length:
add = (length - (count % length))
text = text + ('\0' * add)
self.ciphertext = cryptor.encrypt(text)
# 因为AES加密时候得到的字符串不一定是ascii字符集的,输出到终端或者保存时候可能存在问题
# 所以这里统一把加密后的字符串转化为16进制字符串
return base64.b64encode(self.ciphertext)
# 解密后,去掉补足的空格用strip() 去掉
def decrypt(self, text):
cryptor = AES.new(self.key, self.mode, IV=self.iv)
plain_text = cryptor.decrypt(base64.b64decode(text))
return plain_text.rstrip('\0')
if __name__ == '__main__':
pc = prpcrypt('123454536f667445454d537973576562',
'1234577290ABCDEF1264147890ACAE45'[0:16]) # 初始化密钥
e = pc.encrypt('T10515') # 加密
print "加密:", e
d = pc.decrypt(e) # 解密
print "解密:", d
AES:
pad pkcs7
mode cbc
# -*- coding: utf-8 -*-
from Crypto.Cipher import AES
import base64
import os
BS = AES.block_size
pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS)
unpad = lambda s: s[0:-ord(s[-1])]
key = os.urandom(16) # the length can be (16, 24, 32)
text = '123456'
cipher = AES.new(key)
cipher = AES.new('33b21adee1b8620a7ba81aea1a80c724',
AES.MODE_CBC, IV='1234567812345678')
encrypted = cipher.encrypt(pad(text))
encrypted = base64.b64encode(encrypted)
print encrypted # will be something like 'f456a6b0e54e35f2711a9fa078a76d16'
python aes new_python AES 加密相关推荐
- aes加密算法python语言实现_python-AES加密解密
转载https://www.jianshu.com/p/5d27888e7c93#!/xh #!/usr/bin/env python # -*- coding=utf-8 -*- "&qu ...
- php实现aes ecb模式加密,PHP、Python、Java的AES ECB加密实现-Fun言
AES加密 ECB模式 PKCS5填充 128位密码/密码块 ECB模式是将明文按照固定大小的块进行加密的,块大小不足则进行填充,ECB模式没有用到向量. 具体加密算法,请参见米扑博客总结的系列文章: ...
- Python学习笔记——AES 加密/解密
前言: AES,高级加密标准.目前比较流行的对称加密算法.是一种对称加密算法,即加密和解密都用相同的密钥. AES只是个基本算法,实现AES有几种模式,主要有ECB.CBC.CFB等几种模式.CBC模 ...
- AES加密解密的基本原理与Python爬取AES加密接口
大家好,我是小小明,今天我要带大家学习AES加密的基本原理,并爬取一个经过AES加密的接口.一起来学习吧! AES编码解码基础 AES简介 AES(Advanced Encryption Standa ...
- python aes 加盐 加密解密
python aes 加盐 加密解密 爬虫就是在学习的过程,前几天从某网站的js里学到的加密方式,通过下断点弄清加密原理后,用python复现一下,在这里和大家分享下 #--------引入模块--- ...
- Python中的AES加密
文章目录 AES 加密 一.前言 1. 简介 2. 加密模式 3. 环境配置 二.算法实现 AES 加密 一.前言 1. 简介 AES,高级加密标准(Advanced Encryption Stand ...
- python和java中相同的 AES/CFB/NoPadding加密
python和java的AES/CFB/NoPadding加密还是有点区别的 实现相同的加密方式 上代码 python中 def encrypt_(text):key = 'keyxxx'.encod ...
- python aes加密 cbc_【转载】python AES CBC模式加密
今天需要用到AES CBC模式加密,搜索了很久,终于加密成功,记录一下今天的理解. 首先要安装pycrypto库,不知道为什么在windows安装失败,在linux可以正常安装 这里有几点要注意,ke ...
- Python base64 + AES EBC模式加密
""" 先进行Base64加密,再进行AES ecb模式加密:EBC 模式需要补全 """ ''' ECB模式补足16位 ''' def a ...
- Java RSA、AES加解密,Python RSA、AES加解密
需求 python服务发起加密http请求网关,网关验签解密后路由返回加密结果,python服务解密得到明文 请求加密 生成随机字符 s,[a-z][A-z][0-9] 16位 ,例如:s=2zQ6E ...
最新文章
- 解决WAMP搭建PHP环境后后局域网其他机器无法访问的问题
- boost::intrusive::unordered_set用法的测试程序
- innodb_memcache之配置
- 真实,让文学回到原点:关于非虚构写作的思考
- 为什么Kubernetes从节点会join失败
- highcharts中pie统计图获取数据
- ElasticSearch--Jdbc导入插件
- TCP重复ACK与乱序
- go mysql 多并发_MySQL并发处理-Go语言中文社区
- Netty工作笔记0025---SocketChannel API
- kafka监控之kafka-run-class.sh
- kotlin转java_Kotlin 与 Java 代码之间的转换
- 2018华为网络技术大赛
- tensorflow prelu的实现细节
- Redis的集群原理
- 计算机word文档技巧,Word文档操作技巧:同时打开多个文档3种方法-word技巧-电脑技巧收藏家...
- java后台管理系统做Excel导入
- 〖Python接口自动化测试实战篇⑦〗- 接口抓包工具 Fiddler 的使用
- 如何用PS做出火焰文字的效果?
- 如何使用 PyTorch 进行图像分类