python des,aes,rsa加解密的实现


Posted in Python onJanuary 16, 2021

AES加解密

AES 只是个基本算法,实现 AES 有几种模式,主要有 ECB、CBC、CFB 和 OFB  CTR,直接上代码,此处为AES加密中的CBC模式,EBC模式与CBC模式相比,不需要iv。

import base64from Crypto.Cipher import AES
from binascii import b2a_hex, a2b_hex
 
 
unpad = lambda s: s[:-ord(s[len(s) - 1:])]
class AES3:
  def __init__(self, key):
    self.key = key
    self.mode = AES.MODE_CBC
    self.iv = self.key

  def _pad(self, text):
    key_len = len(self.key)
    pad = text + (key_len - len(text) % key_len) * chr(key_len - len(text) % key_len)
    return pad

  def _unpad(self, text):
    pad = ord(text[-1:])
    return text[0:-pad]

  # 加密函数
  def encrypt(self, text):
    length = 16
    count = len(text)
    if count % length != 0:
      add = length - (count % length)
    else:
      add = 0
    text = text + ('\0' * add)
    cryptor = AES.new(self.key.encode("utf8"), self.mode, self.iv.encode("utf8"))
    self.ciphertext = cryptor.encrypt(bytes(text, encoding="utf8"))
    # AES加密时候得到的字符串不一定是ascii字符集的,输出到终端或者保存时候可能存在问题,使用base64编码
    return base64.b64encode(b2a_hex(self.ciphertext)).decode('utf-8')

  # 解密函数
  def decrypt(self, text):
    decode = base64.b64decode(text)
    cryptor = AES.new(self.key.encode("utf8"), self.mode, self.iv.encode("utf8"))
    plain_text = unpad(cryptor.decrypt(decode))
    return a2b_hex(plain_text) .decode('utf8')

RSA公钥加密,私钥解密

from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5 as Cipher_pkcs1_v1_5
from Crypto.Signature import PKCS1_v1_5 as Signature_pkcs1_v1_5
import base64

# 私钥
private_key = '''-----BEGIN RSA PRIVATE KEY-----
5353dfggd
-----END RSA PRIVATE KEY-----
'''

# 公钥
public_key = '''-----BEGIN PUBLIC KEY-----
hfgghftetet
-----END PUBLIC KEY-----'''
def rsa_encrypt(message):
  """校验RSA加密 使用公钥进行加密"""
  cipher = Cipher_pkcs1_v1_5.new(RSA.importKey(public_key))
  cipher_text = base64.b64encode(cipher.encrypt(message.encode())).decode()
  return cipher_text


def rsa_decrypt(text):
  """校验RSA加密 使用私钥进行解密"""
  cipher = Cipher_pkcs1_v1_5.new(RSA.importKey(private_key))
  retval = cipher.decrypt(base64.b64decode(text), 'ERROR').decode('utf-8')
  return retval

DES加解密

from pyDes import *
import base64
class Des3(object):
  def __init__(self, key, iv):
    # 这里密钥key长度必须为16/24, ,偏移量ivs
    self.key = key
    self.mode = CBC
    self.iv = iv

  # 加密函数,如果text不是16的倍数【加密文本text必须为16的倍数!】,那就补足为16的倍数
  def encrypt(self, text):
    des3 = triple_des(self.key, self.mode, self.iv, pad=None, padmode=PAD_PKCS5)
    data = des3.encrypt(text)
    data = base64.b64encode(data)
    return data.decode('utf-8')

  # 解密后,去掉补足的空格用strip() 去掉
  def decrypt(self, data):
    des3 = triple_des(self.key, self.mode, self.iv, pad=None, padmode=PAD_PKCS5)
    data = base64.b64decode(data)
    text = des3.decrypt(data)
    return text.decode('hex')

以上就是python des,aes,rsa加解密的实现的详细内容,更多关于python des,aes,rsa加解密的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
在Python中操作时间之strptime()方法的使用
Dec 30 Python
Python for Informatics 第11章 正则表达式(一)
Apr 21 Python
Python之web模板应用
Dec 26 Python
python3+PyQt5图形项的自定义和交互 python3实现page Designer应用程序
Jul 20 Python
解决pandas read_csv 读取中文列标题文件报错的问题
Jun 15 Python
关于 Python opencv 使用中的 ValueError: too many values to unpack
Jun 28 Python
windows安装TensorFlow和Keras遇到的问题及其解决方法
Jul 10 Python
Python获取好友地区分布及好友性别分布情况代码详解
Jul 10 Python
Pytorch GPU显存充足却显示out of memory的解决方式
Jan 13 Python
pyinstaller打包单文件时--uac-admin选项不起作用怎么办
Apr 15 Python
浅谈tensorflow使用张量时的一些注意点tf.concat,tf.reshape,tf.stack
Jun 23 Python
如何用python识别滑块验证码中的缺口
Apr 01 Python
python math模块的基本使用教程
Jan 16 #Python
详解Python模块化编程与装饰器
Jan 16 #Python
删除pycharm鼠标右键快捷键打开项目的操作
Jan 16 #Python
基于pycharm 项目和项目文件命名规则的介绍
Jan 15 #Python
python制作抽奖程序代码详解
Jan 15 #Python
python中PyQuery库用法分享
Jan 15 #Python
python中pdb模块实例用法
Jan 15 #Python
You might like
PHP 循环列出目录内容的函数代码
2010/05/26 PHP
php实现cookie加密的方法
2015/03/10 PHP
php断点续传之文件分割合并详解
2016/12/13 PHP
JQuery防止退格键网页后退的实现代码
2012/03/23 Javascript
JS设置获取cookies的方法
2014/01/26 Javascript
分享一款基于jQuery的视频播放插件
2014/10/09 Javascript
node.js中的dns.getServers方法使用说明
2014/12/08 Javascript
jQuery实现仿Google首页拖动效果的方法
2015/05/04 Javascript
浅谈document.write()输出样式
2015/05/07 Javascript
js+html5绘制图片到canvas的方法
2015/06/05 Javascript
深入分析JSON编码格式提交表单数据
2015/06/25 Javascript
JS判断当前页面是否在微信浏览器打开的方法
2015/12/08 Javascript
分享jQuery插件的学习笔记
2016/01/14 Javascript
JavaScript判断变量是否为数组的方法(Array)
2016/02/24 Javascript
javaScript生成支持中文带logo的二维码(jquery.qrcode.js)
2017/01/03 Javascript
简单的渐变轮播插件
2017/01/12 Javascript
jQuery插件form-validation-engine正则表达式操作示例
2017/02/09 Javascript
vue.js事件处理器是什么
2017/03/20 Javascript
JS中Promise函数then的奥秘探究
2018/07/30 Javascript
JS实现深度优先搜索求解两点间最短路径
2019/01/17 Javascript
vue style width a href动态拼接问题的解决
2020/08/07 Javascript
Python利用Beautiful Soup模块修改内容方法示例
2017/03/27 Python
python下10个简单实例代码
2017/11/15 Python
Python交互环境下实现输入代码
2018/06/22 Python
django中账号密码验证登陆功能的实现方法
2019/07/15 Python
Tensorflow训练MNIST手写数字识别模型
2020/02/13 Python
Python3标准库之dbm UNIX键-值数据库问题
2020/03/24 Python
python 使用openpyxl读取excel数据
2021/02/18 Python
使用Html5实现异步上传文件,支持跨域,带有上传进度条
2016/09/17 HTML / CSS
Coach澳大利亚官方网站:美国著名时尚奢侈品牌
2017/05/24 全球购物
就业推荐表自我鉴定
2014/03/21 职场文书
校运会口号
2014/06/18 职场文书
大学生年度个人总结
2015/02/15 职场文书
初中体育课教学反思
2016/02/16 职场文书
Redis持久化与主从复制的实践
2021/04/27 Redis
CSS 实现多彩、智能的阴影效果
2021/05/12 HTML / CSS