Python(30):非对称加密算法RSA的使用(openssl生成RSA公私钥对)
Python(30):非对称加密算法RSA的使用(openssl生成RSA公私钥对)
1、openssl生成RSA公私钥对
1.1、生成RSA公私钥对命令
[root@loaclhost ~]# openssl
OpenSSL> genrsa -out rsa_private_key.pem 1024
Generating RSA private key, 1024 bit long modulus
..++++++
.....++++++
e is 65537 (0x10001)
OpenSSL> pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform pem -nocrypt -out rsa_private_key_8.pem
OpenSSL> rsa -in rsa_private_key_8.pem -pubout -out rsa_public_key.pem
1.2、公钥
-----BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCfNHu9aoeNUTAZH3GCP2CQaSOg
XNx0tImsIaCWBEQK3/fvUx8f17hIOtttCMrrTPWefUdcUxLIZ+xzqeU/eISsz9Ym
kguImd1+bMkGIYiHBKmF5Uww2jGSU738c+AUuRKpixZP+VPekLY+KbOH7NkE2U/L
XGbDeMXeiqQ22UmOSQIDAQAB
-----END PUBLIC KEY-----
1.3、私钥
-----BEGIN RSA PRIVATE KEY-----
MIICXAIBAAKBgQCfNHu9aoeNUTAZH3GCP2CQaSOgXNx0tImsIaCWBEQK3/fvUx8f
17hIOtttCMrrTPWefUdcUxLIZ+xzqeU/eISsz9YmkguImd1+bMkGIYiHBKmF5Uww
2jGSU738c+AUuRKpixZP+VPekLY+KbOH7NkE2U/LXGbDeMXeiqQ22UmOSQIDAQAB
AoGACXx2Fw4+73Oz+vs9pzYhidlJ7yc5V5beUSxbxjSQ3VkFC/SW+S3AZEVlh7Sr
aqPWStBKLT0h9GEE3Mt1xndm6FEVUebboPxDekNU46NnzmF82olzOZbDQuK3LIZT
rKoGMmUD6SlYo9B7DpP3gCYTOb9c6OzHRjcJuHPNWdlyH4UCQQDOrBUupe9vyC4D
iOHIym7dcVj5+O459OzhnXli1WvMhhYpr9QwVC7cRVJk6ZsQgSj+3NmZBx0S0DzC
Ux1fUnOTAkEAxTQZX+M3OrRSIMzUSEI0prZe/B+ZSwXMUpcWu830Zlz0MbhrDSAg
Y67vHE1cAfLIFQOLUWwr+6Fb7hcrhJZYMwJAGB1uL04/XPyvmcv8BHDSdNZH+or4
SRzyEvVL96NNe8TdiymwCZ+ZBCy2i33SkR9xCCP+4+M3mj1gCZCnKbs2LwJBAJ/I
d+reoohZRNY4wKQPqLOPvuSQAdfsycH9k7j1xloOZPnIUEzhQ/0g57LJ54vYmE+W
gJKnj/ehpWgDtAoI+0sCQCXMKPQb2yt2Ca5Ew7R8W2mFo3AyuiYa/FWyeBHZ3x6h
Lqd69roKtGGkB1/rNrPze6/Kqkyjas2urie8cqbzw0A=
-----END RSA PRIVATE KEY-----
IYGlvJCzjUd/9fPFZsxsJEgoCN49ssoqigJxpehNNOMQxEr1z4HdN5BQFypfHQFWCDhs8AZjLIIhnMDMzvI6eilVFEF/HnQowMhdI2xvKnJDD1czwtobdtOc92oJqkV5hiWdaiG3RYS+wY9OrExQGXt/5i1MO3EDaU79GaZf/f60UUTATBW1Sm4jQ4yC65jZeOhZ6UBRlLrCdX/eHhIC5rcqG75d8Xl+2iNW2jtgbXeo5aExz6bG7kwlViS3T4raZvnFZUafZqi5kQEZqAxe1CHxs34XU0riRTuM/k4nDOYIC5IHcXKRNxsDYuKhEBMEcvhh6XgFa/uO2JEeEu3mvg==
2、Python调用RSA加解密
安装:pip install pycryptodome
引用:
from Crypto.PublicKey import RSA from Crypto.Cipher import PKCS1_v1_5 as PKCS1_cipher
2.1、Python代码
from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5 as PKCS1_cipher
import base64def rsa_encrypt(public_key_str,plain_data):#pubkey = RSA.import_key(public_key_str)pubkey = RSA.importKey(public_key_str) #读入公钥rsa = PKCS1_cipher.new(pubkey) #生成对象## 通过生成的对象加密明文,注意,在python3中加密的数据必须是bytes类型的数据,不能是str类型的数据cipher_text = base64.b64encode(rsa.encrypt(bytes(plain_data.encode('utf-8'))))cipher_data=cipher_text.decode('utf-8')return cipher_datadef rsa_decrypt(private_key_str, cipher_data):pri_key = RSA.importKey(private_key_str) #导入私钥cipher = PKCS1_cipher.new(pri_key) #生成对象# 将密文解密成明文,返回的是一个bytes类型数据,需要自己转换成strplain = cipher.decrypt(base64.b64decode(cipher_data.encode("utf8")), 0)plain_data = plain.decode('utf-8')return plain_datapublic_key ="-----BEGIN PUBLIC KEY-----\n"+"MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCfNHu9aoeNUTAZH3GCP2CQaSOgXNx0tImsIaCWBEQK3/fvUx8f17hIOtttCMrrTPWefUdcUxLIZ+xzqeU/eISsz9YmkguImd1+bMkGIYiHBKmF5Uww2jGSU738c+AUuRKpixZP+VPekLY+KbOH7NkE2U/LXGbDeMXeiqQ22UmOSQIDAQAB"+"\n-----END PUBLIC KEY-----\n"
plain_text="Hello World!"
cipher_text =rsa_encrypt(public_key, plain_text)
print(cipher_text)private_key ="-----BEGIN RSA PRIVATE KEY-----\n"+"MIICXAIBAAKBgQCfNHu9aoeNUTAZH3GCP2CQaSOgXNx0tImsIaCWBEQK3/fvUx8f17hIOtttCMrrTPWefUdcUxLIZ+xzqeU/eISsz9YmkguImd1+bMkGIYiHBKmF5Uww2jGSU738c+AUuRKpixZP+VPekLY+KbOH7NkE2U/LXGbDeMXeiqQ22UmOSQIDAQABAoGACXx2Fw4+73Oz+vs9pzYhidlJ7yc5V5beUSxbxjSQ3VkFC/SW+S3AZEVlh7SraqPWStBKLT0h9GEE3Mt1xndm6FEVUebboPxDekNU46NnzmF82olzOZbDQuK3LIZTrKoGMmUD6SlYo9B7DpP3gCYTOb9c6OzHRjcJuHPNWdlyH4UCQQDOrBUupe9vyC4DiOHIym7dcVj5+O459OzhnXli1WvMhhYpr9QwVC7cRVJk6ZsQgSj+3NmZBx0S0DzCUx1fUnOTAkEAxTQZX+M3OrRSIMzUSEI0prZe/B+ZSwXMUpcWu830Zlz0MbhrDSAgY67vHE1cAfLIFQOLUWwr+6Fb7hcrhJZYMwJAGB1uL04/XPyvmcv8BHDSdNZH+or4SRzyEvVL96NNe8TdiymwCZ+ZBCy2i33SkR9xCCP+4+M3mj1gCZCnKbs2LwJBAJ/Id+reoohZRNY4wKQPqLOPvuSQAdfsycH9k7j1xloOZPnIUEzhQ/0g57LJ54vYmE+WgJKnj/ehpWgDtAoI+0sCQCXMKPQb2yt2Ca5Ew7R8W2mFo3AyuiYa/FWyeBHZ3x6hLqd69roKtGGkB1/rNrPze6/Kqkyjas2urie8cqbzw0A="+"\n-----END RSA PRIVATE KEY-----\n"
decrypt_data =rsa_decrypt(private_key,cipher_text)
print(decrypt_data)
2.2、执行结果
"D:\Program Files\Python386\python.exe" D:/python_project/apiTest/venv/src/common/common.py
MNkriQhmq7Y1L4fGQ5zdAuoxpvRJHrBIRjRZDhTebxTVPoJ1UJqIGekZVi36W+lJkd57az9tj3HpRZS2WLd52CvKpnCyv5yhQcxduCPMrekINwz1mUj1ZaNVFiRPdE6aj5P+jVPPZWkd8GNu346PU6pQb4mq49RejfevnN8xT8E=
Hello World!
Process finished with exit code 0
参考:https://blog.csdn.net/qq_62789540/article/details/124400910
相关文章:

Python(30):非对称加密算法RSA的使用(openssl生成RSA公私钥对)
Python(30):非对称加密算法RSA的使用(openssl生成RSA公私钥对) 1、openssl生成RSA公私钥对 1.1、生成RSA公私钥对命令 [rootloaclhost ~]# openssl OpenSSL> genrsa -out rsa_private_key.pem 1024 Generating RSA private key, 1024 bit long modulus .. ...…...
Java学习笔记-day04-NIO核心依赖多路复用小记
NIO允许一个线程同时处理多个连接,而不会因为一个连接的阻塞而导致其他连接被阻塞。核心是依赖操作系统的多路复用机制。 操作系统的多路复用机制 多路复用是一种操作系统的 I/O 处理机制,允许单个进程(或线程)同时监视多个输入…...

Java+springboot+vue智慧校园源码,数据云平台Web端+小程序教师端+小程序家长端
技术架构: Javaspringbootvue element-ui小程序电子班牌:Java Android演示自主版权。 智慧校园电子班牌人脸识别系统全套源码,包含:数据云平台Web端小程序教师端小程序家长端电子班牌 学生端。 电子班牌系统又称之为智慧班牌&am…...

算法日志的存在核心在于搭建自检系统
"相信每一个人执行与日志有关的任务都会遇到这样难题吧?长达几万行的日志,如果我们单纯用肉眼去一个个排查,那么恐怕所耗费的时间是以天为计量单位了。当然这是一种比较夸张的情况,根据我的项目经验,正常情况是十…...
【2023开发组一等奖】定位家乡味——北京市老乡探店寻味系统
作品介绍 1 需求分析 中国人的身上都系着两根线,一条线牵引着我们去远方,一条线牵引着我们归故乡。在当今社会,我们因为各种各样的原因背起行囊远离故乡去往千里之外的远方,而那暗涌在血脉的乡愁总会使我们在看到家乡菜的时候,心底溢出一种不可言说的温暖。那么,当你在异…...

37-数据类型,一元运算符typeof,字符串string,布尔Boolean,未定义undefined,空null,数组Array
<body><script>// 0.1加0.2不等于0.3,正确的运算方法如下console.log(0.10.2);var x 0.1;var y 0.2;console.log((x*10y*10)/10);</script> </body> 简单数据类型(5种):数字number,字符串s…...

zabbix部署
zabbix部署 部署zabbix服务被监测主机部署zabbix-agent2 使用版本 组件版本centos7.9zabbix5.0php7.2.24MariaDB5.5.68 部署zabbix服务 关闭防火墙和selinux [rootnode ~]# systemctl status firewalld ● firewalld.service - firewalld - dynamic firewall daemonLoaded: …...

深入理解Java源码:提升技术功底,深度掌握技术框架,快速定位线上问题
为什么要看源码: 1、提升技术功底: 学习源码里的优秀设计思想,比如一些疑难问题的解决思路,还有一些优秀的设计模式,整体提升自己的技术功底 2、深度掌握技术框架: 源码看多了,对于一个新技术…...

寒假前端第一次作业
1、用户注册: <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>用户注册</title> …...

【LabVIEW FPGA入门】创建第一个LabVIEW FPGA程序
本教程仅以compactRIO(FPGA-RT)举例 1.系统配置 1.1软件安装 FPGA-RT 1. LabVIEW Development System (Full or Professional) 2. LabVIEW Real-Time Module 3. LabVIEW FPGA Module 4. NI-RIO drivers 1.2硬件配置 1.使用线缆连接CompactRIO至主机…...

【STM32】STM32学习笔记-USART串口数据包(28)
00. 目录 文章目录 00. 目录01. 串口简介02. HEX数据包03. 文本数据包04. HEX数据包接收05. 文本数据包接收06. 预留07. 附录 01. 串口简介 串口通讯(Serial Communication)是一种设备间非常常用的串行通讯方式,因为它简单便捷,因此大部分电子设备都支持…...

Java网络爬虫--HttpClient
目录标题 技术介绍有什么优点?怎么在项目中引入? 请求URLEntityUtils 类GET请求带参数的GET请求POST请求 总结 技术介绍 HttpClient 是 Apache Jakarta Common 下的子项目,用来提供高效的、功能丰富的、支持 HTTP 协议的客户端编程工具包。相…...

若依项目的table列表中对每一个字段增加排序按钮(单体版和前后端分离版)
一、目标:每一个字段都添加上下箭头用来排序 只需要更改前端代码,不需要更改后端代码,后面会讲解原理 二、单体版实现方式: 1.在options中添加sortable:true 2.在需要排序的字段中添加sortable:true 三、前后端分离版 1.el-table上添加@sort-change=“handleSortChange”…...
Linux自动化部署脚本
1:最近项目部署比较频繁终于熬不住了 就有下面的这东西 #!/bin/sh #报错停止运行 set -e # 获取tomcat的PID TOMCAT_PID$(ps -ef | grep tomcat | grep -v grep | awk {print $2}) # tomcat的启动文件位置 START_TOMCAT/mnt/tomcat/bin/startup.sh # 项目文件部署位置 PROJECT…...
lvgl修改图片大小上限
在lvgl中读取图片文件时,被读取的图片具有上限,也就是2048像素。这会造成两个非预期的结果: 超过2048像素的部分会被裁去。表示图片的结构体lv_img_t中的w和h变量值是图片像素被2048求余。例如,当一个图片高为2048像素时…...

阻止持久性攻击改善网络安全
MITRE ATT&CK框架是一个全球可访问的精选知识数据库,其中包含基于真实世界观察的已知网络攻击技术和策略。持久性是攻击者用来访问系统的众多网络攻击技术之一;在获得初始访问权限后,他们继续在很长一段时间内保持立足点,以窃取数据、修改…...
MFC与Qt多个控件响应统一响应消息处理
就目前使用C开发框架来说,今天来讲述下MFC框架下与Qt框架下,如何让多个控件响应统一消息处理方法。 功能:假设有5个按钮,需要响应同一个处理函数,该如何实现呢? Qt方式 开发环境:win10 VS201…...
Camunda rest api鉴权
对于rest api 不能没有限制的任何人随意调用,需要提供账号信息。 一:工作流引擎增加过滤器 /*** 对/engine-rest/*进行鉴权,防止非法攻击* 客户端调用需要配置用户凭证否则报错401* camunda.bpm.client.basic-auth.username* camunda.bpm.cl…...

【PostgreSQL】在DBeaver中实现序列、函数、视图、触发器设计
【PostgreSQL】在DBeaver中实现序列、函数、触发器、视图设计 基本配置一、序列1.1、序列使用1.1.1、设置字段为主键,数据类型默认整型1.1.2、自定义序列,数据类型自定义 1.2、序列延申1.2.1、理论1.2.2、测试1.2.3、小结 二、函数2.1、SQL直接创建2.1.1…...

PyQt5-小总结
之前学习PyQt5,然后那段时间想做一个桌面小程序,后来由于学习内容较多就做了一小部分,但是可以进行页面跳转。大家如果是初学者对Python感兴趣而且刚学数据库时可以看看代码,可能会有点启发。 效果: 登录进来是这&…...
云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...
React Native 导航系统实战(React Navigation)
导航系统实战(React Navigation) React Navigation 是 React Native 应用中最常用的导航库之一,它提供了多种导航模式,如堆栈导航(Stack Navigator)、标签导航(Tab Navigator)和抽屉…...

Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)
目录 一、👋🏻前言 二、😈sinx波动的基本原理 三、😈波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、🌊波动优化…...
Python Einops库:深度学习中的张量操作革命
Einops(爱因斯坦操作库)就像给张量操作戴上了一副"语义眼镜"——让你用人类能理解的方式告诉计算机如何操作多维数组。这个基于爱因斯坦求和约定的库,用类似自然语言的表达式替代了晦涩的API调用,彻底改变了深度学习工程…...
Kafka主题运维全指南:从基础配置到故障处理
#作者:张桐瑞 文章目录 主题日常管理1. 修改主题分区。2. 修改主题级别参数。3. 变更副本数。4. 修改主题限速。5.主题分区迁移。6. 常见主题错误处理常见错误1:主题删除失败。常见错误2:__consumer_offsets占用太多的磁盘。 主题日常管理 …...
go 里面的指针
指针 在 Go 中,指针(pointer)是一个变量的内存地址,就像 C 语言那样: a : 10 p : &a // p 是一个指向 a 的指针 fmt.Println(*p) // 输出 10,通过指针解引用• &a 表示获取变量 a 的地址 p 表示…...
Leetcode33( 搜索旋转排序数组)
题目表述 整数数组 nums 按升序排列,数组中的值 互不相同 。 在传递给函数之前,nums 在预先未知的某个下标 k(0 < k < nums.length)上进行了 旋转,使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nu…...
Vue 模板语句的数据来源
🧩 Vue 模板语句的数据来源:全方位解析 Vue 模板(<template> 部分)中的表达式、指令绑定(如 v-bind, v-on)和插值({{ }})都在一个特定的作用域内求值。这个作用域由当前 组件…...
API网关Kong的鉴权与限流:高并发场景下的核心实践
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 引言 在微服务架构中,API网关承担着流量调度、安全防护和协议转换的核心职责。作为云原生时代的代表性网关,Kong凭借其插件化架构…...
0x-3-Oracle 23 ai-sqlcl 25.1 集成安装-配置和优化
是不是受够了安装了oracle database之后sqlplus的简陋,无法删除无法上下翻页的苦恼。 可以安装readline和rlwrap插件的话,配置.bahs_profile后也能解决上下翻页这些,但是很多生产环境无法安装rpm包。 oracle提供了sqlcl免费许可,…...