RSA破解

转载请注明出处:http://www.jianshu.com/p/64dcc0133394

题目:

You are given an oracle-access to a function dec(c) that inverts the RSA N,d function: on input c it computes m = c^d mod N for all but one ciphertext. We call this ciphertext a challenge-ciphertext c∗. The parameters (N, e, d, c∗ ) are fixed. You’ll find all public parameters in the file ‘params.txt‘. Your task is to decrypt the challenge c∗ .

To accomplish the task you should follow the instruction below (Important! You will need to have the GMP library installed on your machine (www.gmplib.org):

Instructions (for Linux):

  1. Download the two files ‘dec.o’ and ‘dec.h’ from the web-page.

It provides the function

   char∗ dec ( const char ∗ c_inp )

that returns the decryption of a ciphertext c_inp given as a string for fixed (N, d). You

can also provide a ciphertext of the GMP long int type by calling

   char∗ dec ( mpz t ∗ c_inp )
  1. To use the above function, either create your own .cpp file and include ‘dec.h’ as a

header or download the template file ‘hw1.cpp’ from the web-site. To compile this .cpp

file with the ‘dec.o’ run in terminal

  g++ hw1 . cpp dec . o −lgmp

Don’t forget to link it with the GMP library!

  1. As the result, you should get a .out file which you can then execute.

As this is an attack on a public key cryptosystem and you are given e, you should implement the corresponding encryption function by yourself. You should submit both the resulting

m = dec(c∗ ) and your code.

Instructions (for Windows):

  1. Find a machine with Linux.

  2. Follow the instructions above.

看了上面的题目,我们再来分析一下RSA破解的过程:

思路

基本的RSA算法容易受到选择密文攻击,选择密文攻击攻击RSA利用了RSA如下的性质:
E(PU,M1) × E(PU,M2) = E(PU,[M1 × M2)
利用选择密文攻击(CCA),可以用如下方式解密C=Memod n。

  1. 计算X = (C × 2e)mod n
  2. 将X作为选择明文提交,并收到Y = Xdmod n。

因此:
X = (C mod n) × (2e mod n) = (Me mod n) × (2 e mod n) = (2M)e mod n

因此:
Y = (2M) mod n
就这样,我们获得了M。

代码过程

#include <stdio.h>
#include <stdlib.h>
#include <gmp.h>
#include "dec.h"
using namespace std;
const char* N_str = "10715086071862673209484250490600018105614048117055336074437503883703510511249361224931983788156958581275946729175531469002933770824382865926730400902798743137187335810705309884635534159797732259520594337385186897629868362414475309001507719259272508669419676508606630823351242964205044695669333236417591";
const char* e_str = "10335071977839588495324343307012721241868030345867699233451500809021555989403028103743221782417440900848403102247012012875905268518785845678756696925714007988778268752026049276281025329038071087021446834856566687537729918372863729292015978809506607411711073716898691660211835403800810547133032654209857";
const char *c_star_s = "775789568255447714013247918834475198679653917741675336925599335265205597974556878796619688391490153400553690715156825186410083467239441867930362368759072824742512821423959166270736914130604102452801162684877374802075310241079026986641176079329871431448404341153307957496668749957011118721172866996397";
const char *m_text_s = "2";

int main()
{
        char *char_M;
      mpz_t n,e,C,C_temp,c1,c2,M,m1,m2;
        // n = N_str, e = e_str
        mpz_init_set_str(n,N_str,10);
        mpz_init_set_str(e,e_str,10);
        mpz_init(C); 
        mpz_init(C_temp);
        // c1 = c_str_s
        mpz_init_set_str(c1,c_star_s,10);
        mpz_init(c2);
        mpz_init(M);
        mpz_init(m1);
        // m2 = m_text_s
        mpz_init_set_str(m2,m_text_s,10);

        /*The key arithmetic of program is CCA: E(PU,M1)*E(PU,M2)=E(PU,[M1*M2]) [See on the P208 of Textbook]*/
        mpz_powm(c2,m2,e,n);// c2 = m2^e mod n, m2 = "2"
        mpz_mul(C_temp,c1,c2);// C_temp = (c1 * c2)
        mpz_mod(C,C_temp,n); // C = (C_temp)mod n = (c1 * c2)mod n = (c1 * 2^e)mod n 
        /*Access the dec(c_cipher) oracle providing by dec.h*/
        char_M = dec(C);// char_M = dec(C) = (C^d)mod n
        mpz_init_set_str(M,char_M,10);// M = char_M
        mpz_divexact(m1,M,m2); // M = (m1 * m2)mod n ---> m1 is the result

        // m1 is the result
        gmp_printf ("The m of c_star_s is %Zd\n\n",m1);
        
        // clean and exit
        mpz_clear(n);
        mpz_clear(e);
        mpz_clear(C);
        mpz_clear(C_temp);
        mpz_clear(c1);
        mpz_clear(c2);
        mpz_clear(M);
        mpz_clear(m1);
        mpz_clear(m2);
        return 0;
}

源代码及文件

链接: https://pan.baidu.com/s/1boWr3wr 密码: c7f4

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • **2014真题Directions:Read the following text. Choose the be...
    又是夜半惊坐起阅读 9,460评论 0 23
  • PLEASE READ THE FOLLOWING APPLE DEVELOPER PROGRAM LICENSE...
    念念不忘的阅读 13,466评论 5 6
  • 书正说的“咱伯”,指的就是三踅的爹。三踅的爹当过国民党的军需,活着的时候就爱告状,告夏天义重用了李上善,重用了秦安...
    姜辣素阅读 316评论 0 0
  • 拔丝红薯做了一整个下午,做完出来,发现糖并没有熬好,或许是水放多,糖太少了,有丝,但是拔的不是很多。 把成品图发给...
    真爱521阅读 307评论 0 0
  • 一切的付出都是理所当然, 想到就要得到 。 寄生于大树的藤蔓, 渺小,可怜, 毫不吝啬向世人宣告独爱阳光。 娇花让...
    叶抽抽阅读 180评论 2 1