RSA 非对称加密:

2024-06-06 14:12
文章标签 加密 rsa 非对称

本文主要是介绍RSA 非对称加密:,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

非对称加密 RSA 拥有两个密钥, 分别为 公钥 和 私钥,   服务器端拥有公钥和私钥, 二客户端,只有公钥, 这个公钥可以随便传,即使被截获也没有关系, 加密使用公钥, 而解密, 只能用私钥

生成公钥和私钥:

生成的公钥和私钥, 需要保存到一个文件之中

from Crypto.PublicKey import RSA  # 用来管理密钥rsa_key = RSA.generate(2048)  # 生成公钥和私钥# 获取私钥
private_key = rsa_key.export_key()# 获取公钥
public_key = rsa_key.public_key().export_key()with open("rsa_public_pem.txt", "wb") as f:f.write(public_key)with open("rsa_private_key_pem.txt", "wb") as f:f.write(private_key)

加密:

from Crypto.Cipher import PKCS1_v1_5
from Crypto.PublicKey import RSA
import base64message = "我爱python编程, 励志成为一名伟大的爬虫大佬!"f = open("rsa_public_pem.txt", "r", encoding="utf-8")# 使用公钥创建一个 密钥
rsa_key = RSA.import_key(f.read())# 使用创建的密钥来创建一个rsa 加密对象
rsa = PKCS1_v1_5.new(rsa_key)# 加密数据
miwen = rsa.encrypt(message.encode("utf-8"))# 使用b64 编码
result = base64.b64encode(miwen).decode("utf-8")
print(result)

解密:

from Crypto.Cipher import PKCS1_v1_5
from Crypto.PublicKey import RSA
import base64# 准备密文
miwen = "ToumbsMmQphEDsgdW5AKaHgpEY1tU93MDL9t9zrjn/xsohIoi2fVfwcsqcyv28JJvJLEeZJ7EAV18rGNP6p+k1WkQHMERIez/NRjNvBWIuoZdb+HGqWQQB5yiOS9nFo6DY1muYrYBPJpUJ0+eXfH8N8+07hGLvJlpYtM4OqfMVC45+dYx9FBWNwHsRG8V0kHPDPCzMN06oFqIXjHulFFFvJ/GkEqaLENCmI713Jy5L7jQh0ff2u0YSIHujTYMvhzgEKt4ZoMr0yH4WcRpdYCLjnlhIW/GpV1gy8dXNQ7n80z/JJtsmuQ4VcquGx4LkEVnIhB62lMuUaVn1NliEBPdg=="# 读取私钥
f = open("rsa_private_key_pem.txt", "r", encoding="utf-8")# 导入私钥
rsa_key = RSA.import_key(f.read())# 使用私钥创建rsa对象
rsa = PKCS1_v1_5.new(rsa_key)# 解密
mingwen = rsa.decrypt(base64.b64decode(miwen), None)print(mingwen.decode())

这篇关于RSA 非对称加密:的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1036338

相关文章

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

使用Python制作一个PDF批量加密工具

《使用Python制作一个PDF批量加密工具》PDF批量加密‌是一种保护PDF文件安全性的方法,通过为多个PDF文件设置相同的密码,防止未经授权的用户访问这些文件,下面我们来看看如何使用Python制... 目录1.简介2.运行效果3.相关源码1.简介一个python写的PDF批量加密工具。PDF批量加密

研究人员在RSA大会上演示利用恶意JPEG图片入侵企业内网

安全研究人员Marcus Murray在正在旧金山举行的RSA大会上公布了一种利用恶意JPEG图片入侵企业网络内部Windows服务器的新方法。  攻击流程及漏洞分析 最近,安全专家兼渗透测试员Marcus Murray发现了一种利用恶意JPEG图片来攻击Windows服务器的新方法,利用该方法还可以在目标网络中进行特权提升。几天前,在旧金山举行的RSA大会上,该Marcus现场展示了攻击流程,

3.比 HTTP 更安全的 HTTPS(工作原理理解、非对称加密理解、证书理解)

所谓的协议 协议只是一种规则,你不按规则来就无法和目标方进行你的工作 协议说白了只是人定的规则,任何人都可以定协议 我们不需要太了解细节,这些制定和完善协议的人去做的,我们只需要知道协议的一个大概 HTTPS 协议 1、概述 HTTPS(Hypertext Transfer Protocol Secure)是一种安全的超文本传输协议,主要用于在客户端和服务器之间安全地传输数据

ja-netfilter的前世今生和非对称加密的欺骗原理

文章目录 ja-netfilter起源官网插件插件配置文件插件的综合应用更多用法 非对称加密欺骗原理非对称加密和数字证书激活过程和欺骗手段分析代码示例第一步:生成自签名证书脚本第二步:使用自签名证书对产品激活信息进行签名 样例数据样例激活码(注:用于代码演示,直接粘贴到JetBrains 家 IDE 中无法完成激活!不用试,肯定提示无效,无法激活!!)样例power.conf(配合ja-ne

Linux加密框架设计与实现

本文转自网络文章,内容均为非盈利,版权归原作者所有。 转载此文章仅为个人收藏,分享知识,如有侵权,马上删除。 原文作者:原文作者是独孤九贱大佬 原文地址:http://bbs.chinaunix.net/thread-3627341-1-1.html

Android的登陆MD5加密

1:导入代码 public class MD5Util {private static final String TAG = "MD5Util";/**** MD5加码 生成32位md5码*/public static String string2MD5(String inStr) {Log.e(TAG, "string2MD5: -------------------------");Mess

超级 密码加密 解密 源码,支持表情,符号,数字,字母,加密

超级 密码加密 解密 源码,支持表情,符号,数字,字母,加密 可以将表情,动物,水果,表情,手势,猫语,兽语,狗语,爱语,符号,数字,字母,加密和解密 可以将文字、字母、数字、代码、标点符号等内容转换成新的文字形式,通过简单的文字以不同的排列顺序来表达不同的内容 源码截图: https://www.httple.net/152649.html

如何实现加密功能

文章目录 1. 概念介绍2. 方法与功能2.1 基本用法2.2 加密算法 3. 示例代码4. 内容总结 我们在上一章回中介绍了"FlutterCacheManager组件"相关的内容,本章回中将介绍一个加密工具包.闲话休提,让我们一起Talk Flutter吧。 1. 概念介绍 加密主要是为了保护一些重要数据,我们在实际项目中会用到加密工具,因此在本章回中介绍一个加密工具

详解BitLocker模式及加密数据和解密方法及无法访问解决之道

BitLocker主要有两种工作模式:TPM模式和U盘模式,同时为了实现更高程度的安全,我们还可以同时启用这两种模式。 BitLocker 自动设备加密在全新安装体验 (OOBE) 期间启动。 但是,只有在用户使用 Microsoft 帐户或 Azure Active Directory 帐户登录后,才会启用(提供)保护。 在此之前,保护已暂停,数据不受保护。 使用本地帐户不会启用 BitLoc