rsa算法加密解密c语言实验报告,c语言RSA算法实验报告

实验报告(RSA)

管杰

1. 题目和问题陈述

请编写程序实现RSA算法的下述过程

(1) 输入两个素数p=3, q=11;

(2) 计算 n=p x q, fn=(p-1) x (q-1);

(3) 输入e=3 , e是不大于fn且与fn互素的数, e用于对数据进行加密, 得到密文;

(4) 计算d=?, 使(e x d) mod fn = 1 , d用于对密文进行解密,还原出明文, 也就是得公钥(e,n), 私钥(d,n);

(5) 分别输入明文11,05,25, 得到相应的密文输出:11,26,16;

(6) 分别输入密文11,26,16, 得到相应的明文输出:11,05,25。

2. 问题分析,要点及主要数据的设置

程序变量主要有:两个素数p和q, p和q的乘积n,以及f,另外还与f互质的数e.其中p, q, e都是输入的,n, f是简单计算出来的.明文代码用m1,m2,m3来表示,密文代码用c1,c2,c3 来表示.另外求密文求明文和求出d的过程分别使用三个外部函数.分别用find _c和find _m和find _d来表示.

3系统设计,流程图

结束

d=find _d(e ,f)

输出m1 m2 m3

输出c1 c2 c3

M1=find _m(c1)

M2=find _m(c2)

M3=find _(c3)

C1=find _c(m1)

C2=find _c(m2)

C3=find _c(m3)

输入c1 c2 c3

输入m1 m2 m3

n=p*q

f=(p-1)(q-1)

输入p q e

Q

开始

4.C代码

5. 测试结果,拷屏输出

6.总结

(1)首先在理解RSA算法时,仅看老师上课留下来的文档时,没有看懂,还好查点资料,对涉及的数学知识了解了下,大概能了解了起算法.

(2)在算法上只有d的算法较难,其他的还好,但是似乎本题输入的条件过多了,导致本题难度减少很多.还行.

(3)程序在语法上基本没有问题了,算法也在积累中,这次也多次使用调试找出了若干问题,很好.

展开阅读全文

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值