python非对称加密模块rsa
一、代码
# 导入rsa库
import rsa.common class RSA(object):
def __init__(self):
self.key= rsa.newkeys(256)
self.pub_key=rsa.PublicKey(self.key[1].n,self.key[1].e)
self.pri_key=rsa.PrivateKey(self.key[1].n,self.key[1].e,self.key[1].d,self.key[1].p,self.key[1].q) # rsa 加密
def rsa_encrypt_bytes(self,bytes_str):
if not isinstance(bytes_str, bytes):
return None
key_length = rsa.common.byte_size(self.key[1].n)
max_msg_length = key_length - 11 count = len(bytes_str) // max_msg_length
if len(bytes_str) % max_msg_length > 0:
count = count + 1 cry_bytes = b'' # rsa加密要以max_msg_length分组, 每组分别加密(加密的数据长度为key_length, 解密时每key_length长度解密然后相加)
for i in range(count):
start = max_msg_length * i
size = max_msg_length
content = bytes_str[start: start + size] # rsa 分组 加密
crypto = rsa.encrypt(content, self.pub_key) cry_bytes = cry_bytes + crypto return cry_bytes # rsa 解密, bytes_string是rsa_encrypt_hex, rsa_encrypt_bytes的返回值
def rsa_decrypt(self,bytes_string):
key_length = rsa.common.byte_size(self.key[1].n)
if len(bytes_string) % key_length != 0:
# 如果数据长度不是key_length的整数倍, 则数据是无效的
return None count = len(bytes_string) // key_length
d_cty_bytes = b'' # 分组解密
for i in range(count):
start = key_length * i
size = key_length
content = bytes_string[start: start + size] # rsa 分组 解密
d_crypto = rsa.decrypt(content, self.pri_key) d_cty_bytes = d_cty_bytes + d_crypto return d_cty_bytes # rsa 加密, 注意: 这里是传递的是16进制字符串
def rsa_encrypt_hex(self,hex_string):
# bytes.fromhex字符串转十六进制方法
return self.rsa_encrypt_bytes(bytes.fromhex(hex_string)) # rsa 库的测试
def test_encrypt_decrypt():
# 产生公钥私钥
(pub, pri) = rsa.newkeys(256) # 构建新的公钥私钥
pubkey = rsa.PublicKey(pri.n, pri.e)
pri_key = rsa.PrivateKey(pri.n, pri.e, pri.d, pri.p, pri.q) message = b'\x00\x00\x00\x00\x01'
# 加密 message
crypto = rsa.encrypt(message, pubkey)
# 解密
d_crypto = rsa.decrypt(crypto, pri_key) print(d_crypto) if __name__ == '__main__':
r=RSA()
bts_str = 'hello world 中文'.encode()
crypto_bytes = r.rsa_encrypt_bytes(bts_str)
d_crypto_bytes = r.rsa_decrypt(crypto_bytes)
print(d_crypto_bytes.decode()) hex_str = '001122334455AAff'
crypto_bytes = r.rsa_encrypt_hex(hex_str)
d_crypto_bytes = r.rsa_decrypt(crypto_bytes)
# bytes.hex()十六进制转字符串方法
print(d_crypto_bytes.hex())
python非对称加密模块rsa的更多相关文章
- 非对称加密算法RSA使用注意事项
原文:非对称加密算法RSA使用注意事项 第一个问题,也是最重要的一个——RSA无法对超过117字节的数据进行加密!切记!其实也勿需要求对更大数据的加密,虽然网上已经有相关解决方案,比如BigInteg ...
- Java进阶(七)Java加密技术之非对称加密算法RSA
Java加密技术(四)--非对称加密算法RSA 非对称加密算法--RSA 基本概念 非对称加密算法是一种密钥的保密方法. 非对称加密算法需要两个密钥:公开密钥(publickey)和私有密钥(priv ...
- 非对称加密算法-RSA算法
一.概述 1.RSA是基于大数因子分解难题.目前各种主流计算机语言都支持RSA算法的实现 2.java6支持RSA算法 3.RSA算法可以用于数据加密和数字签名 4.RSA算法相对于DES/AES等对 ...
- Crypto++应用:非对称加密RSA
1,非对称加密RSA: (1)乙方生成两把密钥(公钥和私钥).公钥是公开的,任何人都可以获得,私钥则是保密的. (2)甲方获取乙方的公钥,然后用它对信息加密. (3)乙方得到加密后的信息,用私钥解密. ...
- python的加密模块(md5,sha,crypt)学习
python的加密模块(md5,sha,crypt)学习 命令行使用python MD5: yinguicai@Cpl-IBP-Product:~/data/work/svn/v1.4.0_dev/A ...
- JAVA 非对称加密算法RSA
非对称加密算法 RSA过程 : 以甲乙双方为例 1.初始化密钥 构建密钥对,生成公钥.私钥保存到keymap中 KeyPairGenerator ---> KeyPair --> RSAP ...
- Java加密技术(四)非对称加密算法RSA
RSA 这样的算法1978年就出现了.它是第一个既能用于数据加密也能用于数字签名的算法.它易于理解和操作.也非常流行.算法的名字以发明者的名字命名:Ron Rivest, AdiShamir ...
- 非对称加密算法RSA 学习
非对称加密算法RSA 学习 RSA加密算法是一种非对称加密算法.RSA是1977年由罗纳德·李维斯特(Ron Rivest).阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Ad ...
- python 加密 解密 签名 验证签名 公钥 私钥 非对称加密 RSA
加密与解密,这很重要,我们已经可以用pypcap+npcap简单嗅探到网络中的数据包了.而这个工具其实可以嗅探到更多的数据.如果我们和别人之间传输的数据被别人嗅探到,那么信息泄漏,信息被篡改,将给我们 ...
随机推荐
- forEach方法
*forEach() * -这个方法只支持ie8以上的浏览器 * -forEach方法需要一个函数作为参数 * -像这种函数,由我们创建但是不由我们调用,我们称为回调函数 * 数组中由几个元素函数就会 ...
- Pregel Master
- Storm设计思想
- jQuery方法-queue()
<!DOCTYPE html> <html> <head lang="en"> <meta charset="utf-8&quo ...
- 过滤器 一 Filter
import javax.servlet.Filter; 前言 过滤器是一个程序,依赖与servlet容器,它先于与之相关的servlet或JSP页面运行在服务器上.过滤器可附加到一个或多个servl ...
- 兼容火狐浏览器的select下拉框样式
经常遇到这样的问题,在使用bootstrap框架的时候select选择框的样式在火狐浏览器上继承的是浏览器本身的样式,跟谷歌等其他的浏览器样式对比很难看,并且很难调整,但是! 好东西来了,现在能调成跟 ...
- Nt函数原型
NTSTATUS NTAPI NtAcceptConnectPort( OUT PHANDLE PortHandle, IN PVOID PortIdentifier, IN PPORT_MESSAG ...
- 全局唯一标识符(GUID,Globally Unique Identifier)
全局唯一标识符(GUID,Globally Unique Identifier)是一种由算法生成的二进制长度为128位的数字标识符.GUID主要用于在拥有多个节点.多台计算机的网络或系统中.在理想情况 ...
- c# ToString()格式大全(转)
stringstr1 =string.Format("{0:N1}",56789); //result: 56,789.0stringstr2 =str ...
- day28-描述符应用与类的装饰器
#!/usr/bin/env python# -*- coding:utf-8 -*-# ------------------------------------------------------- ...