c语言中使用openssl对rsa私钥解密
单次加密数据的最大长度(block_len),由RSA秘钥模长RSA_size()和填充模式有关
填充模式:RSA_PKCS1_PADDING, block_len=RSA_size() - 11填充模式:RSA_PKCS1_OAEP_PADDING,block_len=RSA_size() - 41填充模式:RSA_NO_PADDING(不填充),block_len=RSA_size()
本示例用RSA_PKCS1_PADDING填充,所以一次加密117字节,一次解密128字节,超过的字符需要循环解密。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<openssl/rsa.h>
#include<openssl/pem.h>
#include<openssl/err.h>
#include<openssl/bio.h>
#include<openssl/evp.h>char* prikey="-----BEGIN RSA PRIVATE KEY-----\n\
MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGB\
ALr1s+g6od9C0Jj/a+oEhSUGLOoM8QwAJlTkVTLeKrvEtZCP\
4AQRvsmH7akOo86ja2o33qK+p54AFoKr0T0GaQP6NfsklipK\
N0azBIiwo/tTlwOJUjW3fLQMMNRX/9ZtIYMGSPIOL4FdYJhT\
oJC/dPZ1khaJvf7Oi0rxPuMNVekZAgMBAAECgYBWi9smi83X\
TlTGHqdUA5enFf7AshD73y3fanvOOm5J0bvDGfc3qwdIv7XS\
5sYJqDjXSNm1ONDbIWtKPkN0Hn2J3wDMKzECvvlc+Jb9n1Sm\
7HblKI5PqB3578lcYUQ0M1fIa4AbUBPruInAkAOwuUWvfzmt\
gVky19BXDZNnS+UmAQJBAP389aYz/NfKMSvEq7zht8IQsqXA\
VQinoRLWGTg8uWTd6OZktuBxm9qQDSugIHQlS99PZrSL2xXf\
45bfYKWq7nkCQQC8cNJ+MBr787VmaHdaUK7K32S5NtgJ3g1O\
Nyuzuwi3fj/+PDxB2SMOSWMX5j10N2iGSQ9ctVpXlfaVtQPw\
LaehAkEAvyyU9enxqbct9aTOI5i+SNtqrGotVxtdmSD/0J2c\
ajjB4hDyudOpnQSKdUjMxL+B8W8Bfmo6mKdx1hEC3Q/g+QJB\
AKAlvi5yEazInQTwiWafJT3TBxYFTytrpKExcBmqPak8SYR2\
irtnn0xYADhiex3WrSVa2AxxL9s53ruygCtRkaECQCUkMs3i\
e2OUKa8MQBhup7cbhXiSunO354Xnc4ddjbgPLwW7tGoWEezi\
jNsiJ6XBSMcx6zifs1ybCbeDvdaT/Jo=\
\n-----END RSA PRIVATE KEY-----\n";typedef struct{unsigned char *data; //解密数据int len; //解密数据长度
}decrypt_data_t;static void crypt_rsa_decrypt(unsigned char *endata,int enlen,decrypt_data_t *out_data){RSA *rsa;BIO *bio;if((bio = BIO_new_mem_buf(prikey, -1)) == NULL) //从字符串读取RSA公钥{printf("BIO_new_mem_buf failed!\n");}if((rsa=PEM_read_bio_RSAPrivateKey(bio,NULL,NULL,NULL))==NULL){printf("PEM_read_bio_RSAPrivateKey failed!");}int key_len = RSA_size(rsa);int ret=0,pos=0;int blocklen = 128;out_data->data = (unsigned char *)malloc(enlen+1);memset(out_data->data,0,enlen+1);unsigned char *sub_str = (unsigned char *)malloc(key_len+1);unsigned char *out_str = (unsigned char *)malloc(key_len+1);memset(sub_str,0,key_len+1);memset(out_str,0,key_len+1);while(enlen-pos >0){if(enlen-pos >blocklen){memset(sub_str,0,key_len+1);memcpy(sub_str,endata+pos,blocklen);ret = RSA_private_decrypt(blocklen,(unsigned char *)sub_str,(unsigned char*)out_str,rsa,RSA_PKCS1_PADDING);printf("RSA_private_decrypt ret:%d\n",ret);pos +=blocklen;if(ret >0){ memcpy(out_data->data+out_data->len,out_str,ret);out_data->len += ret;}}else{ memset(sub_str,0,key_len+1);memcpy(sub_str,endata+pos,enlen-pos);ret = RSA_private_decrypt(enlen-pos,(unsigned char *)sub_str,(unsigned char*)out_str,rsa,RSA_PKCS1_PADDING);printf("RSA_private_decrypt ret:%d\n",ret);pos = enlen;if(ret >0){ memcpy(out_data->data+out_data->len,out_str,ret);out_data->len += ret;} }}if(sub_str){free(sub_str);sub_str = NULL;}if(out_str){free(out_str);out_str = NULL;}RSA_free(rsa);BIO_free_all(bio);}
相关文章:
c语言中使用openssl对rsa私钥解密
单次加密数据的最大长度(block_len),由RSA秘钥模长RSA_size()和填充模式有关 填充模式:RSA_PKCS1_PADDING, block_lenRSA_size() - 11填充模式:RSA_PKCS1_OAEP_PADDING,block_lenRSA_size() - 4…...
mysql中数据是如何被用B+树查询到的
innoDB是按照页为单位读写的 那页中有很多行数据,是怎么执行查询的呢,首先我们肯定,是以单向列表形式存储的,提高了增删的效率,但是查询效率低。所以实际上对页中的行数据进行了优化,能以二分的方式进行查…...
Redisson 分布式锁的最佳实践
Redisson 分布式锁的最佳实践 第一、添加依赖第二、添加redisson配置类第三、添加测试类测试结果扩展知识redisson锁中lock方法和tryLock方法有什么区别锁续约 注意事项 引言 在现代分布式系统中,处理并发问题是至关重要的。分布式锁是解决这类问题的关键工具之一。…...
ArkTS声明式开发范式
装饰器 用来装饰类、结构体、方法以及变量,赋予其特殊的含义,如上述示例中 Entry 、 Component 、 State 都是装饰器。 Component 表示这是个自定义组件; Entry 则表示这是个入口组件; State 表示组件中的状态变量,…...
史诗级云故障敲响警钟,应用保障不能没有“连续键”!
近日,知名云服务商出现一次史诗级的云故障:全球所有区域/所有服务同时异常,故障持续长达3小时之多,云上众多应用受到极大影响。 如今,在一个充满不确定性和复杂性的数字化时代,哪怕是顶级云服务商亦不能避…...
SSH连接远程服务器报错:WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED 解决方法
一.错误描述 报错信息里提示了路径信息/root/.ssh/known_hosts:20 二.解决方案 方法一 输入以下指令: ssh-keygen -R XXX(需要连接远程服务器的ip) 按照我的例子ip:10.165.7.136,会返回以下信息: 重新尝试连接: 输…...
数据库——查询连续的月份
一、GP或PGSQL with recursive t(n) as (select date(2023-01-01) union all select n1 from t where n < now()) select to_char(n, yyyy-mm) as ny from t group by ny order by ny 二、Hive select add_months(FROM_UNIXTIME(unix_timestamp(SUBSTR(start_date, 1, 7…...
git代码提交命令(如何提交代码)
# 提交暂存区到仓库区 $ git commit -m [message]# 提交暂存区的指定文件到仓库区 $ git commit [file1] [file2] ... -m [message]# 提交工作区自上次commit之后的变化,直接到仓库区 $ git commit -a# 提交时显示所有diff信息 $ git commit -v# 使用一次新的commit…...
jmeter中调用python代码
1、安装pyinstaller pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pyinstaller 2、将py脚本打包 pyinstaller -F venv/get_image/OCR_jmeter_api.py 3、jmeter中添加OS Process Sampler并调用dist下的程序 4、执行jmeter...
当当网获得dangdang商品详情商品列表API 测试请求入口
item_get-获得dangdang商品详情 获取商品详情 item_search-按关键字搜索dangdang商品 获取商品列表 公共参数 名称类型必须描述keyString是调用key(必须以GET方式拼接在URL中)secretString是调用密钥api_nameString是API接口名称(包括在请…...
git如何查看配置,修改配置,设置配置
# 显示当前的Git配置 $ git config --list# 编辑Git配置文件 $ git config -e [--global]# 设置提交代码时的用户信息 $ git config [--global] user.name "[name]" $ git config [--global] user.email "[email address]"...
交通流合成数据生成原理及实现代码
移动数据是设备的地理位置,通过正常活动被动产生。 它具有从交通规划到迁移预测的重要应用。 由于移动数据稀有且难以收集,研究人员已开始探索综合生成移动数据的解决方案。 在本文中,我将讨论一种用于合成移动数据的简单解决方案。 该合成数…...
leetcode 240. 搜索二维矩阵 II
2023.11.22 本题最先想到的是暴力法和二分法,暴力法就不写了,写一下二分法的解法,java代码如下: class Solution {public boolean searchMatrix(int[][] matrix, int target) {for(int[] row : matrix){int left 0;int right r…...
a标签超链接 —— 实现点击前中后变色
浅浅记录下 <style type"text/css"> a:link {color: yellow; /*未访问链接颜色*/ }a:visited {color: red; /*已访问链接颜色*/ }a:hover {color: blue; /*鼠标移动到链接颜色*/text-decoration: underline; }a:active {color: orange; /*鼠标点击时颜色*/ }a…...
【好玩的开源项目】Linux系统之部署proxx扫清黑洞小游戏
【好玩的开源项目】Linux系统之部署proxx扫清黑洞小游戏 一、proxx小游戏介绍1.1 proxx小游戏简介1.2 开源地址 二、本地环境介绍2.1 本地环境规划2.2 本次实践介绍 三、检查本地环境3.1 检查本地操作系统版本3.2 检查系统内核版本 四、部署Node.js环境4.1 下载Node.js安装包4.…...
IDEA-SVN合并分支到主干
IDEA-SVN合并branch分支到主干master 1.选择VCS的 Integrate Project 2.选择分支合并 Source1 是合并后的分支 , 主分支 master Source2 是被合并的分支 , 分支 branch Try merge 可以尝试是否可以能够被合并,并且无冲突 3.合并完成后当前项目会出现需要提交的内容,检查一…...
kettle如何写日志
var subject"自定义日志输出"; //实例化工厂类 var logFactory new org.pentaho.di.core.logging.LogChannelFactory(); //实例化日志channel对象 var log logFactory.create(subject); //日志输出 log.logMinimal("XXXXXXXXXXXXXXXXXXXXXXXX-preRows"acc…...
新能源车将突破2000万辆,汉威科技为电池安全保驾护航
近年来,我国新能源汽车销量持续突破新高。据中汽协数据,1~10月,国内新能源汽车销量达728万辆,同比增长37.8%,市场占有率达到30.4%。随着第四季度车市传统旺季的到来,新能源消费需求将进一步释放,…...
基于文心一言AI大模型,编写一段python3程序以获取华为分布式块存储REST接口的实时数据
本文尝试基于文心一言AI大模型,编写一段python3程序以获取华为分布式块存储REST接口的实时数据。 一、用文心一言AI大模型将需求转化为样例代码 1、第一次对话:“python3写一段从rest服务器获取数据的样例代码” 同时生成了以下注解 这段代码首先定义…...
2022-4-11 南科大现代控制与最优估计
CLEAR_LAB B站视频 矩阵的分块矩阵操作 diagonal 对角阵 identity matrix 单位矩阵 矩阵克罗内克积...
为什么你的SSD用久了会变慢?深入浅出聊聊TLC/QLC闪存的Vt分布挑战
为什么你的SSD用久了会变慢?深入解析TLC/QLC闪存的电压分布困局 当你发现新买的固态硬盘(SSD)在连续使用几个月后,拷贝大文件时速度从500MB/s跌到300MB/s,游戏加载时间明显变长,这很可能不是心理作用。这种…...
AAEON de next-RAP8-EZBOX嵌入式系统解析与工业应用
1. 项目概述:AAEON de next-RAP8-EZBOX嵌入式系统解析在工业自动化和边缘计算领域,对高性能、紧凑型计算设备的需求持续增长。AAEON最新推出的de next-RAP8-EZBOX正是针对这一需求设计的解决方案。这款超紧凑嵌入式系统搭载了Intel Core i7-1365UE 10核R…...
终极智能导航神器:autojump让终端操作效率翻倍
终极智能导航神器:autojump让终端操作效率翻倍 【免费下载链接】autojump A cd command that learns - easily navigate directories from the command line 项目地址: https://gitcode.com/gh_mirrors/au/autojump autojump是一款革命性的终端导航工具&…...
出轨小三就会净身出户?告诉你出轨离婚财产分割的5个真相
“我老公出轨了,我要让他净身出户!”这是我在咨询室里听到最多的一句话。每当我无奈地告诉当事人“法律不支持净身出户”时,对方往往难以置信——为什么出轨的人还能分走一半财产?今天,湖南长沙知名婚姻家事律师、高评…...
Qwen3-4B-Thinking-Gemini-Distill行业落地:教育科技公司AI助教系统集成实践
Qwen3-4B-Thinking-Gemini-Distill行业落地:教育科技公司AI助教系统集成实践 1. 模型概述与教育场景价值 Qwen3-4B-Thinking-2507-Gemini-Distill是一款专为教育场景优化的AI推理模型,基于阿里千问3官方思考版(Qwen3-4B-Thinking-2507&…...
告别线束混乱:如何用一块TC1016接口卡搭建精简的ECU产线测试工装(含UDS诊断与Bootloader实例)
告别线束混乱:如何用一块TC1016接口卡搭建精简的ECU产线测试工装(含UDS诊断与Bootloader实例) 在汽车电子产线测试和售后诊断领域,工程师们常常面临设备繁多、线束杂乱、测试效率低下的痛点。传统测试台架往往需要多台单功能设备堆…...
ESP32S3驱动ST7701S RGB屏实战:从LVGL绑定到颜色校准的完整避坑指南
ESP32S3驱动ST7701S RGB屏全流程实战:从底层配置到LVGL优化的深度解析 在嵌入式开发领域,显示驱动往往是连接硬件与用户体验的关键桥梁。当ESP32S3遇上ST7701S这款性价比突出的RGB接口屏幕时,如何高效稳定地驱动它成为许多开发者面临的现实挑…...
CloudCompare 2025保姆级避坑指南:10个新手最常踩的雷区与高效解决路径
CloudCompare 2025保姆级避坑指南:10个新手最常踩的雷区与高效解决路径 第一次打开CloudCompare时,面对密密麻麻的工具栏和复杂的点云数据,很多新手会感到手足无措。作为一款功能强大的开源点云处理软件,CloudCompare在三维建模、…...
升级鸿蒙6后,大家担心的痛点都搞定啦!真香!
朋友们,被用户追着说“还不去适配鸿蒙”的产品经理委托我发篇贴。 最近我在各大极客论坛看到好多鸿蒙6先锋用户在担心:鸿蒙6是真流畅,但你们升级后最怕的不是“卡”,而是“空”——书架空了、网盘空了、连看视频的快乐都没了。 …...
codex模拟autosota方案
结论:先别急着自己构建完整 AutoSOTA agent 系统。 你现在最该做的是搭一个 AutoSOTA-lite 工作流:复现基线 -> 生成优化想法 -> 实现单个改动 -> 跑实验 -> 审核有效性 -> 记录报告。 Agent 可以以后自动化;现在最值钱的是 评…...
