亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? fgintrsa.pas

?? 經典算法RSA,從其他地方得來的
?? PAS
字號:
{License, info, etc
 ------------------

This implementation is made by Walied Othman, to contact me
mail to Walied.Othman@Student.KULeuven.ac.be or
Triade@ace.Ulyssis.Student.KULeuven.ac.be,
always mention wether it 's about the FGInt for Delphi or for
FreePascal, or wether it 's about the 6xs, preferably in the subject line.
If you 're going to use these implementations, at least mention my
name or something and notify me so I may even put a link on my page.
This implementation is freeware and according to the coderpunks'
manifesto it should remain so, so don 't use these implementations
in commercial software.  Encryption, as a tool to ensure privacy
should be free and accessible for anyone.  If you plan to use these
implementations in a commercial application, contact me before
doing so, that way you can license the software to use it in commercial
Software.  If any algorithm is patented in your country, you should
acquire a license before using this software.  Modified versions of this
software must contain an acknowledgement of the original author (=me).
This implementaion is available at
http://ace.ulyssis.student.kuleuven.ac.be/~triade/

copyright 2000, Walied Othman
This header may not be removed.
}

Unit FGIntRSA;

Interface

Uses Windows, SysUtils, Controls, FGInt;

Procedure RSAEncrypt(P : String; Var exp, modb : TFGInt; Var E : String);
Procedure RSADecrypt(E : String; Var exp, modb, d_p, d_q, p, q : TFGInt; Var D : String);
Procedure RSASign(M : String; Var d, n, dp, dq, p, q : TFGInt; Var S : String);
Procedure RSAVerify(M, S : String; Var e, n : TFGInt; Var valid : boolean);


Implementation


{$H+}




// Encrypt a string with the RSA algorithm, P^exp mod modb = E

Procedure RSAEncrypt(P : String; Var exp, modb : TFGInt; Var E : String);
Var
   i, j, modbits : longint;
   PGInt, temp, zero : TFGInt;
   tempstr1, tempstr2, tempstr3 : String;
Begin
   Base2StringToFGInt('0', zero);
   FGIntToBase2String(modb, tempstr1);
   modbits := length(tempstr1);
   convertBase256to2(P, tempstr1);
   tempstr1 := '111' + tempstr1;
   j := modbits - 1;
   While (length(tempstr1) Mod j) <> 0 Do tempstr1 := '0' + tempstr1;

   j := length(tempstr1) Div (modbits - 1);
   tempstr2 := '';
   For i := 1 To j Do
   Begin
      tempstr3 := copy(tempstr1, 1, modbits - 1);
      While (copy(tempstr3, 1, 1) = '0') And (length(tempstr3) > 1) Do delete(tempstr3, 1, 1);
      Base2StringToFGInt(tempstr3, PGInt);
      delete(tempstr1, 1, modbits - 1);
      If tempstr3 = '0' Then FGIntCopy(zero, temp) Else FGIntMontgomeryModExp(PGInt, exp, modb, temp);
      FGIntDestroy(PGInt);
      tempstr3 := '';
      FGIntToBase2String(temp, tempstr3);
      While (length(tempstr3) Mod modbits) <> 0 Do tempstr3 := '0' + tempstr3;
      tempstr2 := tempstr2 + tempstr3;
      FGIntdestroy(temp);
   End;

   While (tempstr2[1] = '0') And (length(tempstr2) > 1) Do delete(tempstr2, 1, 1);
   ConvertBase2To256(tempstr2, E);
   FGIntDestroy(zero);
End;


// Decrypt a string with the RSA algorithm, E^exp mod modb = D
// provide nil for exp.Number if you want a speedup by using the chinese
// remainder theorem, modb = p*q, d_p*e mod (p-1) = 1 and
// d_q*e mod (q-1) where e is the encryption exponent used

Procedure RSADecrypt(E : String; Var exp, modb, d_p, d_q, p, q : TFGInt; Var D : String);
Var
   i, j, modbits : longint;
   EGInt, temp, temp1, temp2, temp3, ppinvq, qqinvp, zero : TFGInt;
   tempstr1, tempstr2, tempstr3 : String;
Begin
   Base2StringToFGInt('0', zero);
   FGIntToBase2String(modb, tempstr1);
   modbits := length(tempstr1);
   convertBase256to2(E, tempstr1);
   While copy(tempstr1, 1, 1) = '0' Do delete(tempstr1, 1, 1);
   While (length(tempstr1) Mod modbits) <> 0 Do tempstr1 := '0' + tempstr1;
   If exp.Number = Nil Then
   Begin
      FGIntModInv(q, p, temp1);
      FGIntMul(q, temp1, qqinvp);
      FGIntDestroy(temp1);
      FGIntModInv(p, q, temp1);
      FGIntMul(p, temp1, ppinvq);
      FGIntDestroy(temp1);
   End;

   j := length(tempstr1) Div modbits;
   tempstr2 := '';
   For i := 1 To j Do
   Begin
      tempstr3 := copy(tempstr1, 1, modbits);
      While (copy(tempstr3, 1, 1) = '0') And (length(tempstr3) > 1) Do delete(tempstr3, 1, 1);
      Base2StringToFGInt(tempstr3, EGInt);
      delete(tempstr1, 1, modbits);
      If tempstr3 = '0' Then FGIntCopy(zero, temp) Else
      Begin
         If exp.Number <> Nil Then FGIntMontgomeryModExp(EGInt, exp, modb, temp) Else
         Begin
            FGIntMontgomeryModExp(EGInt, d_p, p, temp1);
            FGIntMul(temp1, qqinvp, temp3);
            FGIntCopy(temp3, temp1);
            FGIntMontgomeryModExp(EGInt, d_q, q, temp2);
            FGIntMul(temp2, ppinvq, temp3);
            FGIntCopy(temp3, temp2);
            FGIntAddMod(temp1, temp2, modb, temp);
            FGIntDestroy(temp1);
            FGIntDestroy(temp2);
         End;
      End;
      FGIntDestroy(EGInt);
      tempstr3 := '';
      FGIntToBase2String(temp, tempstr3);
      While (length(tempstr3) Mod (modbits - 1)) <> 0 Do tempstr3 := '0' + tempstr3;
      tempstr2 := tempstr2 + tempstr3;
      FGIntdestroy(temp);
   End;

   If exp.Number = Nil Then
   Begin
      FGIntDestroy(ppinvq);
      FGIntDestroy(qqinvp);
   End;
   While (Not (copy(tempstr2, 1, 3) = '111')) And (length(tempstr2) > 3) Do delete(tempstr2, 1, 1);
   delete(tempstr2, 1, 3);
   ConvertBase2To256(tempstr2, D);
   FGIntDestroy(zero);
End;


// Sign strings with the RSA algorithm, M^d mod n = S
// provide nil for exp.Number if you want a speedup by using the chinese
// remainder theorem, n = p*q, dp*e mod (p-1) = 1 and
// dq*e mod (q-1) where e is the encryption exponent used


Procedure RSASign(M : String; Var d, n, dp, dq, p, q : TFGInt; Var S : String);
Var
   MGInt, SGInt, temp, temp1, temp2, temp3, ppinvq, qqinvp : TFGInt;
Begin
   Base256StringToFGInt(M, MGInt);
   If d.Number <> Nil Then FGIntMontgomeryModExp(MGInt, d, n, SGInt) Else
   Begin
      FGIntModInv(p, q, temp);
      FGIntMul(p, temp, ppinvq);
      FGIntDestroy(temp);
      FGIntModInv(q, p, temp);
      FGIntMul(q, temp, qqinvp);
      FGIntDestroy(temp);
      FGIntMontgomeryModExp(MGInt, dp, p, temp1);
      FGIntMul(temp1, qqinvp, temp2);
      FGIntCopy(temp2, temp1);
      FGIntMontgomeryModExp(MGInt, dq, q, temp2);
      FGIntMul(temp2, ppinvq, temp3);
      FGIntCopy(temp3, temp2);
      FGIntAddMod(temp1, temp2, n, SGInt);
      FGIntDestroy(temp1);
      FGIntDestroy(temp2);
      FGIntDestroy(ppinvq);
      FGIntDestroy(qqinvp);
   End;
   FGIntToBase256String(SGInt, S);
   FGIntDestroy(MGInt);
   FGIntDestroy(SGInt);
End;


// Verify digitally signed strings with the RSA algorihthm,
// If M = S^e mod n then ok:=true else ok:=false

Procedure RSAVerify(M, S : String; Var e, n : TFGInt; Var valid : boolean);
Var
   MGInt, SGInt, temp : TFGInt;
Begin
   Base256StringToFGInt(S, SGInt);
   Base256StringToFGInt(M, MGInt);
   FGIntMod(MGInt, n, temp);
   FGIntCopy(temp, MGInt);
   FGIntMontgomeryModExp(SGInt, e, n, temp);
   FGIntCopy(temp, SGInt);
   valid := (FGIntCompareAbs(SGInt, MGInt) = Eq);
   FGIntDestroy(SGInt);
   FGIntDestroy(MGInt);
End;

End.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜精品免费在线| 亚洲人成网站在线| 在线综合+亚洲+欧美中文字幕| 99国产精品久久久久| av在线播放一区二区三区| 国产精一区二区三区| 国内外精品视频| 国产成人精品一区二区三区四区| 精品一二线国产| 国产精品主播直播| 丁香桃色午夜亚洲一区二区三区| 国产福利精品导航| jlzzjlzz亚洲女人18| 一本色道久久综合狠狠躁的推荐 | 26uuu国产在线精品一区二区| 欧美一区二区在线不卡| 欧美一级生活片| 精品成人免费观看| 久久久久国产精品厨房| 国产精品视频看| 伊人色综合久久天天| 亚洲成人一二三| 精东粉嫩av免费一区二区三区| 国产suv精品一区二区三区| 成人一二三区视频| 欧美三区在线观看| 欧美精品一区二区在线观看| 国产精品入口麻豆原神| 亚洲一区影音先锋| 老汉av免费一区二区三区| 国产精品456露脸| 欧美亚洲国产bt| 精品国产乱码久久久久久浪潮| 日本一区二区在线不卡| 亚洲国产成人91porn| 久久99精品国产麻豆婷婷洗澡| av色综合久久天堂av综合| 欧美三级中文字幕在线观看| 久久亚洲精华国产精华液 | 久久99久国产精品黄毛片色诱| 国产精品99久久久久久久女警| 91丝袜美腿高跟国产极品老师 | 国产精品乱码一区二区三区软件| 亚洲va欧美va人人爽午夜| 国产精品一级片在线观看| 欧美三级日韩三级国产三级| 精品999久久久| 亚洲三级在线免费观看| 久久成人免费电影| 欧美一a一片一级一片| 国产亚洲成aⅴ人片在线观看| 无码av中文一区二区三区桃花岛| 99久久99久久综合| 日本一区免费视频| 久久国产婷婷国产香蕉| 欧美日韩激情一区| 中文字幕一区二区5566日韩| 国精产品一区一区三区mba视频 | 久久精品久久99精品久久| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 欧美日韩国产精选| 综合自拍亚洲综合图不卡区| 国产成人午夜高潮毛片| 2欧美一区二区三区在线观看视频| 亚洲一区视频在线| 色八戒一区二区三区| 国产精品福利影院| 成人网在线播放| 亚洲国产精品99久久久久久久久| 狠狠网亚洲精品| 欧美大片一区二区| 久久av老司机精品网站导航| 欧美肥妇free| 青青青伊人色综合久久| 4438成人网| 美女一区二区三区| 欧美精品三级在线观看| 日韩国产精品91| 欧美一二三四在线| 久久福利视频一区二区| 亚洲精品在线免费观看视频| 国产在线精品一区二区夜色| 欧美精品一区二区三区久久久| 精品在线免费视频| 国产三级精品视频| 99免费精品在线观看| 亚洲精品乱码久久久久久久久| 一本到不卡免费一区二区| 一区二区三区在线看| 欧美日韩免费高清一区色橹橹| 日韩精彩视频在线观看| 日韩小视频在线观看专区| 精品亚洲成av人在线观看| 国产欧美一区二区三区在线老狼| 丁香激情综合五月| 亚洲午夜免费福利视频| 欧美岛国在线观看| 99久久伊人网影院| 亚洲mv大片欧洲mv大片精品| 日韩精品一区二区三区中文精品| 国产乱码精品1区2区3区| 亚洲美女在线国产| 4438x成人网最大色成网站| 国产在线播放一区二区三区| 最新成人av在线| 欧美一区二区三区视频在线| 国产精品456| 午夜国产不卡在线观看视频| 337p日本欧洲亚洲大胆精品| 91首页免费视频| 久久综合综合久久综合| 亚洲男人的天堂一区二区| 欧美成人在线直播| 91久久精品日日躁夜夜躁欧美| 蜜臀久久99精品久久久久久9| 中文字幕日韩一区| 日韩欧美色综合网站| 色域天天综合网| 国产一区二区福利视频| 婷婷久久综合九色综合绿巨人 | 精品人伦一区二区色婷婷| 91免费在线看| 国产一本一道久久香蕉| 亚洲va欧美va天堂v国产综合| 中文欧美字幕免费| 日韩精品专区在线影院重磅| 色综合激情久久| 国产成人在线网站| 奇米888四色在线精品| 一区二区三区四区蜜桃| 中文字幕一区在线| 久久综合九色欧美综合狠狠| 欧美一区二区三区播放老司机| 色视频成人在线观看免| 高清日韩电视剧大全免费| 日韩精品成人一区二区三区| 亚洲一区二区三区四区不卡| 国产精品国产自产拍高清av| 久久精品亚洲麻豆av一区二区| 91精品国产综合久久蜜臀| 一本色道综合亚洲| 色诱视频网站一区| 色综合网站在线| 97精品国产露脸对白| 国产精品18久久久| 国产精品12区| 国产成人夜色高潮福利影视| 免费日韩伦理电影| 美脚の诱脚舐め脚责91 | 欧美国产综合色视频| 久久久久久影视| 欧美r级在线观看| 精品福利一二区| 久久久精品国产99久久精品芒果 | 一区二区三区在线影院| 亚洲精品美国一| 亚洲午夜久久久久久久久电影院 | 久久久高清一区二区三区| 欧美大肚乱孕交hd孕妇| 日韩欧美色综合网站| 久久先锋资源网| 亚洲国产精品av| 亚洲欧美日韩久久| 亚洲午夜视频在线| 日本欧美一区二区| 激情欧美一区二区三区在线观看| 国产电影精品久久禁18| 成人福利视频网站| 欧美亚洲动漫精品| 欧美一区二区三区视频在线| 精品sm在线观看| 国产精品电影一区二区| 亚洲成人午夜影院| 黄一区二区三区| 99久久国产免费看| 69成人精品免费视频| 国产亚洲制服色| 亚洲精品自拍动漫在线| 日本欧美韩国一区三区| 国产盗摄一区二区三区| 91国内精品野花午夜精品| 欧美一区二区久久| 中文字幕日韩欧美一区二区三区| 亚洲第一电影网| 顶级嫩模精品视频在线看| 欧美日韩一区视频| 国产午夜一区二区三区| 亚洲综合久久久久| 国产精品一线二线三线| 91精品福利视频| 久久久精品免费网站| 亚洲国产精品天堂| 国产99精品在线观看| 日韩一区二区电影| 亚洲精品免费在线| 国产乱子轮精品视频| 欧美男生操女生| 亚洲欧美另类在线| 国产ts人妖一区二区| 欧美不卡视频一区|