题目描述:

解答出来了上一个题目的你现在可是春风得意,你们走向了下一个题目所处的地方 你一看这个题目傻眼了,这明明是一个数学题啊!!!可是你的数学并不好。扭头看向小鱼,小鱼哈哈一笑 ,让你在学校里面不好好听讲现在傻眼了吧~来我来!三下五除二,小鱼便把这个题目轻轻松松的搞定了。flag格式为cyberpeace{小写的你解出的答案}

附件内容:

在一次RSA密钥对生成中,假设p=473398607161,q=4511491,e=17

求解出d

前置知识:

非对称加密算法--RSA加密原理

————————————————————————

公钥密码算法(非堆成密钥算法):产生一对可以互逆变换的密钥Kd与Ke,但是即使知道Kd,还是无法得知Ke,这样就可将Kd公开,但只有接收方知道Ke。在此情况下,任何人均可利用Kd加密,而只有知道Ke的接收方才能解密;或是只有接收方一人才能加密(加密与解密其实都是一种动作),任何人均能解密。

简单地概述一下\(RSA\)算法加密/解密的过程:

import:

\(N\):公钥\(1\)   \(d\):公钥\(2\)   \(e\):私钥

\(A\):密文   \(B\):明文   \(φ()\):欧拉函数

  • 公钥在同一加密规则下对于所有人来说都是已知的,加密只需公钥

  • 首先约定私钥 \(e\,\)需满足:\(1 < e < φ(N)\) 且 \(gcd(e,N) = 1\) (互质,否则无解)

  • 公钥 \(d\) 由 \(d*e≡1\,(mod\,φ(N))\) ① 计算出,此时称 \(d\) 是 \(e\) 的模反元素

  • 为了增加破解(分解因数)的难度,\(N\) 一般为两个大质数的乘积(即 \(p\) 和 \(q\))

加密公式: \(A^d ≡ B\;(\;mod\;N\;)\,\,\)   解密公式: \(B^e ≡ A\;(\;mod\;N\;)\,\,\)

数字签名: \(A^e ≡ B\;(\;mod\;N\;)\,\,\)   验证签名: \(B^d ≡ A\;(\;mod\;N\;)\,\,\)

我们知道当 \(p\) 和 \(q\) 都为质数时,\(φ(N) = φ (p*q) = (p-1) * (q-1)\)

故 ① 式变为:\(d * e\,\%\,(p-1)*(q-1)\,= 1\)

即 \(d*e*x-(p-1)*(q-1)*y=1\) 其中: \(x,y∈N\)

easy_RSA 这道题就是模拟了计算公钥的过程,我们可以使用扩展欧几里得算法解决。

C++ 代码如下:

#include <bits/stdc++.h>
#define ll long long
using namespace std;
void exgcd (ll a,ll b,ll &d,ll &y,ll &gcd) {
if (!b) { d=1,y=0,gcd=a; return; }
else { exgcd(b,a%b,y,d,gcd),y-=d*(a/b); }
}
int main()
{
const ll p=473398607161,q=4511491,e=17;
const ll eu=(p-1)*(q-1);
ll d,y,gcd,mo;
exgcd(e,eu,d,y,gcd);
mo=eu/gcd,d=(d%mo+mo)%mo;
cout<<d;
return 0;
}

adworld easy_RSA | RSA算法的更多相关文章

  1. 信息安全-5:RSA算法详解(已编程实现)[原创]

    转发注明出处:http://www.cnblogs.com/0zcl/p/6120389.html 背景介绍 1976年以前,所有的加密方法都是同一种模式: (1)甲方选择某一种加密规则,对信息进行加 ...

  2. RSA算法原理

    一直以来对linux中的ssh认证.SSL.TLS这些安全认证似懂非懂的.看到阮一峰博客中对RSA算法的原理做了非常详细的解释,看完之后茅塞顿开,关于RSA的相关文章如下 RSA算法原理(一) RSA ...

  3. C#RSA算法实现+如何将公钥为XML格式转为PEM格式,给object-C使用

    .net中,处于安全的考虑,RSACryptoServiceProvider类,解密时只有同时拥有公钥和私钥才可以.原因是公钥是公开的,会被多人持有.这样的数据传输是不安全的.C#RSA私钥加密,公钥 ...

  4. [已解决] 快速理解RSA算法

    RSA算法基础详解 http://www.cnblogs.com/hykun/p/RSA.html RSA算法原理(一) http://www.ruanyifeng.com/blog/2013/06/ ...

  5. 公钥私钥和RSA算法

    1, RSA算法原理(一) http://www.ruanyifeng.com/blog/2013/06/rsa_algorithm_part_one.html 2, RSA算法原理(二) http: ...

  6. 跨越千年的RSA算法

    转载自http://www.matrix67.com/blog/archives/5100 数论,数学中的皇冠,最纯粹的数学.早在古希腊时代,人们就开始痴迷地研究数字,沉浸于这个几乎没有任何实用价值的 ...

  7. (转)RSA算法原理(二)

      作者: 阮一峰 日期: 2013年7月 4日 上一次,我介绍了一些数论知识. 有了这些知识,我们就可以看懂RSA算法.这是目前地球上最重要的加密算法. 六.密钥生成的步骤 我们通过一个例子,来理解 ...

  8. (转) RSA算法原理(一)

    最近用到了RSA加密算法,虽然有现成的,但是想看看它的原理,翻到此文,感觉写得很好,通俗易懂,转了.   作者: 阮一峰 日期: 2013年6月27日 如果你问我,哪一种算法最重要? 我可能会回答&q ...

  9. springmvc使用RSA算法加密表单

    今天被吐槽在客户端用js对密码进行md5加密其实也不见得安全.这种做法其实不见得有什么作用,学过计算机网络都知道,在网上抓一个包是很简单的事,就算别人抓包抓不到你原始密码,用这个md5后的密码一样可以 ...

随机推荐

  1. Netty学习(1):IO模型之BIO

    概述 Netty其实就是一个异步的.基于事件驱动的框架,其作用是用来开发高性能.高可靠的IO程序. 因此下面就让我们从Java的IO模型来逐步深入学习Netty. IO模型 IO模型简单来说,就是采用 ...

  2. Codeforces_723

    A.取中间那个点即可. #include<bits/stdc++.h> using namespace std; ]; int main() { ios::sync_with_stdio( ...

  3. WeChall_Training: Encodings I (Training, Encoding)

    We intercepted this message from one challenger to another, maybe you can find out what they were ta ...

  4. SpringBoot项目版本升级:从1.5.3升级到2.1.8版本

    SpringBoot项目版本升级:从1.5.3升级到2.1.8版本 前言 简单记录一次本人在自己的SpringBoot项目project-template中,把1.5.3版本升级到2.1.8版本时升级 ...

  5. The 2019 University of Jordan Collegiate Programming Contest

    链接:https://codeforc.es/gym/102267 A. Picky Eater 直接比较 int main(){ int x ,y; scanf("%d %d" ...

  6. 《Python学习手册 第五版》 -第5章 数值类型

    本章是承接第四章整体说明之后,将对”数值类型“展开详细的说明 数值类型这一章主要通过一下几个内容来讲解: 1.数值类型有哪些? 2.表达式运算符:有哪些?有什么规范? 3.数值的显示格式 接下来,从第 ...

  7. 如何高效地远程部署?自动化运维利器 Fabric 教程

    关于 Python 自动化的话题,在上一篇文章中,我介绍了 Invoke 库,它是 Fabric 的最重要组件之一.Fabric 也是一个被广泛应用的自动化工具库,是不得不提的自动化运维利器,所以,本 ...

  8. 【5min+】 对象映射只有AutoMapper?试试Mapster

    系列介绍 [五分钟的dotnet]是一个利用您的碎片化时间来学习和丰富.net知识的博文系列.它所包含了.net体系中可能会涉及到的方方面面,比如C#的小细节,AspnetCore,微服务中的.net ...

  9. JS代码格式化时间戳

    一.[24小时制]yyyy-MM-dd HH:mm:ss new Date().toJSON() // 2019-12-13T13:12:32.265Z 通过上面的方法,基本就可以将日期格式化,然后稍 ...

  10. Redis中RDB和AOF持久化区别和联系

    RDB和AOF持久化   ​RDB持久化 RDB是什么? 原理是redis会单独创建(fork) 一个与当前进程一模一 样的子进程来进行持久化,这个子进程的所有数据(变量.环境变量,程序程序计数器等) ...