openssl+ RSA + linux 签名开发实例(C++)

文章目录

  • 一、openssl+RSA理论基础
  • 二、openssl RSA 签名开发实例

一、openssl+RSA理论基础

RSA签名是一种非对称加密算法,用于在信息传输过程中验证消息的完整性和真实性。以下是RSA签名的理论基础的主要知识点:

  1. RSA密钥对: RSA使用一对公钥和私钥,其中公钥用于加密,私钥用于解密。签名是私钥操作,验证是公钥操作。

  2. 数学基础:

    • 大素数: RSA的安全性基于两个大素数的乘积难以分解。生成密钥时,需要选择两个大素数。
    • 欧拉函数: RSA使用欧拉函数(Euler’s totient function)来计算与大素数乘积的正整数个数。
  3. 生成密钥对: 在RSA中,首先需要生成一对公钥和私钥。密钥生成包括选择两个大素数、计算模数和选择公钥的指数。

  4. 公钥和私钥的使用:

    • 加密和解密: 公钥用于加密,私钥用于解密。
    • 签名和验证: 私钥用于签名,公钥用于验证签名。
  5. 数字签名过程:

    • 消息哈希: 对要签名的消息进行哈希运算,通常使用SHA-256等哈希算法。
    • 私钥签名: 使用私钥对消息的哈希值进行加密,形成数字签名。
  6. 数字签名验证过程:

    • 消息哈希: 对接收到的消息进行哈希运算,得到消息的哈希值。
    • 公钥验证: 使用公钥对数字签名进行解密,得到解密后的哈希值。
    • 比较哈希值: 将解密后的哈希值与原始消息的哈希值进行比较。如果相同,则验证通过。
  7. 安全性考虑: RSA的安全性依赖于大数分解问题的难解性,即从大数的乘积中分解出原始的大素数的难度。选择足够大的密钥长度对抗分解攻击。

  8. 常见的RSA算法参数:

    • 密钥长度: 常见的RSA密钥长度包括1024、2048、3072、4096等。较长的密钥长度通常提供更高的安全性,但也需要更多的计算资源。
  9. 填充方案: 在实际应用中,为增加安全性,通常使用填充方案(如PKCS#1 v1.5或OAEP)对消息进行填充。

  10. 注意事项: RSA算法的计算量相对较大,因此在实际应用中通常用于加密短消息或对称密钥的加密。

理解这些理论基础有助于正确实现RSA签名和验证的过程,并在使用时保证安全性。

二、openssl RSA 签名开发实例

以下是使用OpenSSL库进行RSA签名的简单C++示例代码。请注意,这个示例中使用的密钥长度是2048位,你可以根据需要选择不同的密钥长度。

#include <iostream>
#include <openssl/rsa.h>
#include <openssl/pem.h>
#include <openssl/err.h>// 用于读取PEM格式的私钥文件
RSA* readPrivateKey(const char* privateKeyFile) {FILE* file = fopen(privateKeyFile, "r");if (!file) {perror("Error opening private key file");return nullptr;}RSA* rsa = PEM_read_RSAPrivateKey(file, nullptr, nullptr, nullptr);fclose(file);if (!rsa) {ERR_print_errors_fp(stderr);}return rsa;
}// 对消息进行RSA签名
bool signMessage(const char* message, RSA* privateKey, unsigned char* signature, unsigned int* signatureLength) {EVP_PKEY* pkey = EVP_PKEY_new();EVP_PKEY_set1_RSA(pkey, privateKey);EVP_MD_CTX* ctx = EVP_MD_CTX_new();if (!ctx) {perror("Error creating context");EVP_PKEY_free(pkey);return false;}if (EVP_DigestSignInit(ctx, nullptr, EVP_sha256(), nullptr, pkey) != 1) {perror("Error initializing sign context");EVP_MD_CTX_free(ctx);EVP_PKEY_free(pkey);return false;}if (EVP_DigestSignUpdate(ctx, message, strlen(message)) != 1) {perror("Error updating sign context");EVP_MD_CTX_free(ctx);EVP_PKEY_free(pkey);return false;}if (EVP_DigestSignFinal(ctx, signature, signatureLength) != 1) {perror("Error finalizing sign context");EVP_MD_CTX_free(ctx);EVP_PKEY_free(pkey);return false;}EVP_MD_CTX_free(ctx);EVP_PKEY_free(pkey);return true;
}int main() {// 读取私钥const char* privateKeyFile = "private_key.pem";RSA* privateKey = readPrivateKey(privateKeyFile);if (!privateKey) {std::cerr << "Error loading private key" << std::endl;return 1;}// 待签名的消息const char* message = "Hello, RSA!";// 计算签名unsigned char signature[2048];  // 2048是RSA密钥长度unsigned int signatureLength;if (signMessage(message, privateKey, signature, &signatureLength)) {std::cout << "Signature created successfully" << std::endl;// 在实际应用中,可以将签名保存或发送给其他方进行验证} else {std::cerr << "Error creating signature" << std::endl;}// 释放资源RSA_free(privateKey);return 0;
}

请确保替换private_key.pem为你实际使用的私钥文件。这个示例中的签名结果保存在signature数组中,你可以根据实际需要将签名保存到文件或发送给其他方进行验证。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/165590.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pcie-2-rj45速度优化

背景: 目前用iperf3打流传输速率达不到要求,千兆实际要求跑到800M以上: 优化方案: 1.优化defconfig: 首先编译user版本验证看是否正常 debug版本关闭CONFIG_SLUB_DEBUG_ON宏控。 2.找FAE ,通过更换驱动,或者更新驱动来优化 3.绑定大核: 以8125网卡为例,udp…

【Unity】IBeginDragHandler、IDragHandler 和 IEndDragHandler 介绍

IBeginDragHandler、IDragHandler 和 IEndDragHandler 介绍 IBeginDragHandler、IDragHandler 和 IEndDragHandler 是 Unity 引擎中的三个接口&#xff0c;用于处理 UI 元素的拖放事件。这些接口通常结合使用&#xff0c;构成了 Unity 引擎的拖放事件系统。 IBeginDragHandler…

java--权限修饰符

1.什么是权限修饰符 就是是用来限制类中的成员(成员变量、成员方法、构造器、代码块...)能够被访问的范围。 2.权限修饰符有几种&#xff1f;各自的作用是什么&#xff1f; private<缺省<protected<public(范围由小到大)

什么年代了,还不会 CI/CD 么?

目录 什么是 CI/CD&#xff1f; CI/CD 对业务有哪些好处&#xff1f; 一&#xff1a;确保卓越的代码质量 二&#xff1a;更快的发布速度 → 更快的交付 三&#xff1a;自动化降低成本 四&#xff1a;故障隔离 五&#xff1a;简化回滚 六&#xff1a;持续反馈 七&#…

设计模式——行为型模式(二)

6.8 迭代器模式 6.8.1 概述 定义:提供一个对象来顺序访问聚合对象中的一系列数据,而不暴露聚合对象的内部表示。 6.8.2 结构 迭代器模式主要包含以下角色: 抽象聚合(Aggregate)角色:定义存储、添加、删除聚合元素以及创建迭代器对象的接口。具体聚合(ConcreteAggreg…

C# Onnx PP-Vehicle 车辆分析(包含:车辆检测,识别车型和车辆颜色)

目录 效果 模型信息 mot_ppyoloe_s_36e_ppvehicle.onnx vehicle_attribute_model.onnx 项目 代码 下载 其他 C# Onnx PP-Vehicle 车辆分析&#xff08;包含&#xff1a;车辆检测&#xff0c;识别车型和车辆颜色&#xff09; 效果 模型信息 mot_ppyoloe_s_36e_ppvehi…

009 OpenCV 二值化 threshold

一、环境 本文使用环境为&#xff1a; Windows10Python 3.9.17opencv-python 4.8.0.74 二、二值化算法 2.1、概述 在机器视觉应用中&#xff0c;OpenCV的二值化函数threshold具有不可忽视的作用。主要的功能是将一幅灰度图进行二值化处理&#xff0c;以此大幅降低图像的数…

ASP.NET Core 启用CORS

浏览器的安全阻止一个域的本地页面请求另外不同域的本地页面&#xff0c;这个限制叫同源策略&#xff0c;这个安全特性用来阻止恶意站点从别的网站读取数据 例如假如我有一个页面叫A.html https://foo.example/A.html 现在页面A.html有一个ajax代码尝试读取B.html的HTML的源…

【PyQt】(自定义类)阴影遮罩

写了一个感觉有些用的小玩具。 用于给控件添加阴影遮罩(强调主控件的同时屏蔽其余控件的点击) 自定义阴影遮罩Mask&#xff1a; from PyQt5.QtCore import QPoint,QRect,Qt,QPoint,QSize from PyQt5.QtWidgets import QWidget,QLabel,QPushButton,QVBoxLayout from PyQt5.QtGu…

leetcode:合并两个有序链表

题目描述 题目链接&#xff1a;21. 合并两个有序链表 - 力扣&#xff08;LeetCode&#xff09; 题目分析 这个算法思路很简单&#xff1a;就是直接找小尾插 定义一个tail和head&#xff0c;对比两个链表结点的val&#xff0c;小的尾插到tail->next&#xff0c;如果一个链表…

每日一题:LeetCode-589.N叉树的前序遍历序列构造二叉树

每日一题系列&#xff08;day 01&#xff09; 前言&#xff1a; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f308; &#x1f50e…

企业微信身份验证

本篇主要是在上一篇获取第三方凭证基础上&#xff0c;用户通过三方网站自定义授权登录后获取用户信息&#xff0c;以实现用户绑定登录功能。 构造第三方应用授权链接 如果第三方应用需要在打开的网页里面携带用户的身份信息&#xff0c; 第一步需要构造如下的链接来获取授权c…

马养殖场建设VR模拟实训教学平台具有灵活性和复用性

为保障养殖场生物安全&#xff0c;避免疫病传播&#xff0c;学生出入养殖场受时间和地域的限制&#xff0c; 生产实习多以参观为主&#xff0c;通过畜牧企业技术人员的讲解&#xff0c;学生被动了解生产过程。为了解决畜牧养殖实训难的问题&#xff0c;借助VR技术开展畜牧养殖虚…

通过云服务器部署JavaWeb项目

文章目录 搭建Java运行环境部署项目更改部分项目代码打包项目把war包上传到webapps目录下验证程序 搭建Java运行环境 搭建环境的部分比较复杂&#xff0c;为了让大家的思路更加清晰特别总结为一篇博客点击查看 部署项目 更改部分项目代码 打包项目 把war包上传到webapps目录…

大洋钻探系列之三IODP 342航次是干什么的?(下)

上文简要地介绍IODP342航次的总体情况&#xff0c;本文以航次1个钻孔&#xff08;U1403&#xff09;为例&#xff0c;更为详细地系统展示大洋钻探航次的工作和成果。 ​编辑​ 站位叠加多波束影像的成果图见下图&#xff0c;从图中的颜色效果可以看出&#xff0c;此多波束的成…

归并排序算法

文章目录 归并排序一、归并排序思路二、归并排序算法模板三、题目代码 归并排序 一、归并排序思路 二、归并排序算法模板 void merge_sort(int q[], int l, int r) {if (l > r) return;int mid l r >> 1;//中间值merge_sort(q, l, mid);merge_sort(q, mid 1, r);…

大数据分析与应用实验任务九

大数据分析与应用实验任务九 实验目的 进一步熟悉pyspark程序运行方式&#xff1b; 熟练掌握pysaprkRDD基本操作相关的方法、函数&#xff0c;解决基本问题。 实验任务 进入pyspark实验环境&#xff0c;打开命令行窗口&#xff0c;输入pyspark&#xff0c;完成下列任务&am…

Redis入门教程

1. 什么是NoSql NoSQL一词最早出现于1998年&#xff0c;是Carlo Strozzi开发的一个轻量、开源、不提供SQL功能的关系数据库。2009年&#xff0c;Last.fm的Johan Oskarsson发起了一次关于分布式开源数据库的讨论&#xff0c;来自Rackspace的Eric Evans再次提出了NoSQL的概念&am…

onnx导出报错 | IndexError: index_select(): Index is supposed to be a vector

解决方案&#xff1a; 在torch.onnx.export钟添加do_constant_foldingFalse&#xff0c;如下 torch.onnx.export(model,(None, text),text_fp32_onnx_path,input_names[text],output_names[unnorm_text_features],export_paramsTrue,opset_version13,verboseTrue,do_constant_…

编程参考 - C++ Code Review: 一个计算器的项目

GitHub - jroelofs/calc: Toy Calculator Toy Calculator 1&#xff0c;拿到一个project&#xff0c;第一眼看&#xff0c;没有配置文件&#xff0c;说明没有引入持续集成系统&#xff0c;continuous integration system。 2&#xff0c;然后看cmake文件&#xff0c;使用的子…