密码学 - RSA签名算法

实验九 RSA签名算法-

一、实验目的

通过实验掌握GMP开源软件的用法,理解RSA数字签名算法,学会RSA数字签名算法程序设计,提高一般数字签名算法的设计能力。

二、实验要求

(1)基于GMP开源软件,实现RSA签名算法。

(2)要求有对应的程序调试记录和验证记录。

三、实验内容

1.密钥生成算法

这一步骤将为每个用户生成公钥和相应私钥,执行如下操作:

(1) 产生两个不同的大素数p和q。

(2)计算n=pq和φ=(p-1)(q-1)。

(3)选择一个随机数e(1<e<q),满足ged(e,p)=1。

(4)使用扩展欧几里得算法计算d(1<d<q)使得ed = l(modp)。

(5)那么用户得公钥为(n,e),私钥为d。

2.签名生成算法

假设用户A对消息m∈M签名,执行操作如下:

(1)存在一个函数R(* ),将消息m映射为范围[0,n-1]的一个数m,即m=R(m)。

(2)计算s=m“modn。

(3)A对消息m的签名为s。

(4)恢复消息m=R~'(m)。

四、算法实现:

RSA签名算法可以分为三个部分:生成密钥、签名和解签名。关键函数

生成满足gcd(e,p)=1的随机数e(1<e<φ):实现该功能的函数为void e_ gen(mpz_ _t e, mpz_ t fn),第一个参数e为函数的输出。函数过程为:设立flag=1,然后在while循环内部,使用void random_ num(mpz_ .t ran_num, mpz_ t m, mpz_ .t n)函数产生在[2, φ-1]的随机数字e,接着求该数字e与φ(n)的最大公约数,判断该最大公约数是否等于1。如果等于1,则flag=0, while循环结束;否则,继续做循环。循环结束即输出满足需求的随机数e(1<e<<φ)。函数的实现代码如下:

1.密钥生成算法:

#include <iostream>
#include <cmath>// 函数声明
int gcd(int a, int b);
int modInverse(int a, int m);int main() {// 步骤1: 产生两个不同的大素数p和qint p = 61; // 替换为实际生成的素数int q = 53; // 替换为实际生成的素数// 步骤2: 计算n=pq和φ=(p-1)(q-1)int n = p * q;int phi = (p - 1) * (q - 1);// 步骤3: 选择一个随机数e(1<e<φ),满足gcd(e, φ) = 1int e = 17; // 替换为实际选择的e// 步骤4: 使用扩展欧几里得算法计算d(1<d<φ)使得(ed ≡ 1 (mod φ))int d = modInverse(e, phi);// 输出公钥和私钥std::cout << "公钥 (n, e): (" << n << ", " << e << ")" << std::endl;std::cout << "私钥 d: " << d << std::endl;return 0;
}// 辅助函数: 计算最大公约数
int gcd(int a, int b) {if (b == 0)return a;return gcd(b, a % b);
}// 辅助函数: 计算模反元素
int modInverse(int a, int m) {for (int x = 1; x < m; x++) {if ((a * x) % m == 1) {return x;}}return -1; // 如果不存在模反元素
}

 

2.签名生成算法

#include <iostream>
#include <cmath>// 函数声明
int modPow(int base, int exponent, int modulus);int main() {// 用户A对消息m签名int m = 42; // 替换为实际的消息// 步骤1: 将消息m映射为范围[0, n-1]的数int n = 3233; // 替换为实际的nm = m % n;// 步骤2: 计算s = m^e mod nint e = 17; // 替换为实际的eint s = modPow(m, e, n);// 步骤3: A对消息m的签名为sstd::cout << "用户A对消息m的签名为: " << s << std::endl;return 0;
}// 辅助函数: 计算模幂运算
int modPow(int base, int exponent, int modulus) {int result = 1;base = base % modulus;while (exponent > 0) {if (exponent % 2 == 1)result = (result * base) % modulus;exponent = exponent >> 1;base = (base * base) % modulus;}return result;
}

 

五、实验心得:

        密钥生成是整个RSA系统的基础。通过选择两个不同的大素数,计算出n和φ,再选择合适的e和使用扩展欧几里得算法计算d,最终得到公钥和私钥。这个过程中,对数论知识的理解是至关重要的,尤其是关于素数和模运算的概念。

        签名生成算法涉及到对消息的映射、模幂运算等步骤。通过将消息映射到指定范围,然后使用指定的指数进行模幂运算,得到消息的签名。这一过程实际上是数字签名的核心,确保了消息的完整性和真实性。

 

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

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

相关文章

高级运维学习(十六)Prometheus 监控

Prometheus概述 Prometheus是一个开源系统监控和警报工具包&#xff0c;最初由 SoundCloud构建。也是一款监控软件&#xff0c;也是一个时序数据库。Prometheus 将其指标收集并存储为时间序列数据&#xff0c;即指标信息与记录时的时间戳以及称为标签的可选键值对一起存储。主…

Python 框架学习 Django篇 (九) 产品发布、服务部署

我们前面编写的所有代码都是在windows上面运行的&#xff0c;因为我们还处于开发阶段 当我们完成具体任务开发后&#xff0c;就需要把我们开发的网站服务发布给真正的用户 通常来说我们会选择一台公有云服务器比如阿里云ecs&#xff0c;现在的web服务通常都是基于liunx操作系统…

Apache和Nginx实现虚拟主机的3种方式

目录 首先介绍一下Apache和nginx&#xff1a; Nginx和Apache的不同之处&#xff1a; 虚拟主机 准备工作 Apache实现&#xff1a; 方法1&#xff1a;使用不同的ip来实现 方法2&#xff1a;使用相同的ip&#xff0c;不同的端口来实现 方法3&#xff1a;使用相同的ip&…

PyCharm因安装了illuminated Cloud插件导致加载项目失败

打开Pycharm时会有弹窗提示&#xff1a; The license for Illuminated Cloud is invalid or has expired. All Illuminated Cloud features will be disabled. 这个弹窗会导致你加载项目一直失败&#xff0c;close project 也关不掉&#xff0c;我都是用任务管理器杀死进程的…

【C++】:内存管理 || 泛型编程 || 函数模板 || 类模板 || 内存泄漏(后期结合智能指针详讲)

&#x1f440;1.operator new与operator delete函数 operator new与operator delete函数&#xff08;重点&#xff09; new和delete是用户进行动态内存申请和释放的操作符&#xff0c;operator new 和operator delete是系统提供的全局函数&#xff0c;new在底层调用operator n…

酷开科技智能大屏OS Coolita亮相第134届中国进出口商品交易会

作为中国外贸的“风向标”和“晴雨表”&#xff0c;广交会因其历史长、规模大、商品种类全、到会客商多、成交效果好&#xff0c;被称为“中国第一展”&#xff0c;它见证了中国改革开放的时代大潮与对外贸易的蓬勃发展。 2023年10月15日&#xff0c;第134届中国进出口商品交易…

11.13 牛客刷题8/10

11.13 信号完整性 指针地址 的加减&#xff0c;注意 最后转为16进制

Presentation Prompter 5.4.2(mac屏幕提词器)

Presentation Prompter是一款演讲辅助屏幕提词器软件&#xff0c;旨在帮助演讲者在公共演讲、主持活动或录制视频时更加流畅地进行演讲。以下是Presentation Prompter的一些特色功能&#xff1a; 提供滚动或分页显示&#xff1a;可以将演讲稿以滚动或分页的形式显示在屏幕上&a…

nav2 调节纯追踪算法

纯追踪算法 纯追踪基础 The core idea is to find a point on the path in front of the robot and find the linear and angular velocity to help drive towards it. 核心思想是在机器人前方的路径上找到一个点&#xff0c;并找到一个合适的线速度和角速度&#xff0c;以驱…

PNAS | 蛋白质结构预测屈服于机器学习

今天为大家介绍的是来自James E. Rothman的一篇短文。今年的阿尔伯特拉斯克基础医学研究奖表彰了AlphaFold的发明&#xff0c;这是蛋白质研究历史上的一项革命性进展&#xff0c;首次提供了凭借序列信息就能够准确预测绝大多数蛋白质的三维氨基酸排列的实际能力。这一非凡的成就…

双H桥直流马达步进电机驱动芯片SS8833E

由工采网代理的率能SS8833E是一款适用于有刷直流或双极步进电机的集成电机驱动芯片&#xff1b;采用eTSSOP16封装&#xff1b;该器件集成了两个PNMOS H桥和电流调节电路&#xff1b;电机输出电流可以由外部脉宽调制器&#xff08;PWM&#xff09;或内部PWM电流控制器控制。 工…

20231108在Ubuntu22.04下编译安装cmake-3.27.7.tar.gz

20231108在Ubuntu22.04下编译安装cmake-3.27.7.tar.gz 2023/11/8 17:28 缘起&#xff0c;编译cv180zb的时候提示说cmake的版本低&#xff01; OBJCOPY platform/generic/firmware/payloads/test.bin OBJCOPY platform/generic/firmware/fw_dynamic.bin OBJCOPY platfor…