又黄又www的网站_青青草.com_在线亚洲美日韩_九九九国产视频_√天堂8资源中文在线_一区二区三区免费网站_久久久久国产一区二区三区_人妻激情偷乱视频一区二区三区_一本到在线视频

C語言:rsa算法原理

發布時間:2011-08-29 共3頁

  C. 大數的運算

  1. 大數的運算原理

  RSA算法依賴于大數的運算,目前主流RSA算法都建立在512位到1024位的大數運算之上,所以我們首先需要掌握大數(比如1024位)的運算原理。

  大多數的編譯器只能支持到32位(或64位)的整數運算,即我們在運算中所使用的整數必須小于等于32位,即0xFFFFFFFF,這遠遠達不到RSA的需要,于是需要專門建立大數運算庫,來解決這一問題。

  最簡單的辦法是將大數當作字符串進行處理,也就是將大數用10進制字符數組進行表示,然后模擬人們手工進行“豎式計算”的過程編寫其加減乘除函數。但是這樣做效率很低。當然其優點是算法符合人們的日常習慣,易于理解。

  另一種思路是將大數當作一個二進制流進行處理,使用各種移位和邏輯操作來進行加減乘除運算,但是這樣做代碼設計非常復雜,可讀性很低,難以理解也難以調試。

  這里我們采用了一種介于兩者之間的思路:將大數看作一個N進制數組,對于目前的32位系統而言,N可以取2的32次方,即 0x100000000,假如將一個1024位的大數轉化成0x10000000進制,它就變成了32位,而每一位的取值范圍是0- 0xFFFFFFFF。我們正好可以用一個無符號長整數來表示這一數值。所以1024位的大數就是一個有32個元素的unsigned long數組。而且0x100000000進制的數組排列與2進制流對于計算機來說,實際上是一回事,但是我們完全可以針對unsigned long數組進行“豎式計算”,而循環規模被降低到了32次之內,并且算法很容易理解。

  但考慮到乘法和除法,都要進行擴展才能進行快速的計算(如果把除法變減法而不擴展,速度將慢的無法忍受)。所以我們將N取2的16次方的,即 0xFFFF。每一位用unsigned short來表示,當進行乘除運算時,將short擴展成long,這是編譯器所支持的,所以運算起

  9) 大數的蒙氏算法。它是已知大數A、B和C,求X=A^B MOD C的值。要對指數進行逐漸降階,直到變成2次方,也就是轉換成乘法和取余運算。降階的方法和算法的具體過程,請參考相關書籍和源代碼。

  10) 大數的最大公約數。求兩個大數的最大公約數,用輾轉相除法。

  RSA算法的實現

  A. 生成密鑰函數

  gChar gGenerateKey(gBigInt *n,gBigInt *e,gBigInt *d);

  功能:該函數實現了產生密鑰的功能。先產生兩個隨機的大素數p和q,然后計算n=p×q,隨機產生(或固定)一個大數e,計算d,使得ed≡1 MOD (p-1)(q-1)。

  參數:

  n:兩個大數的乘積,和e或d聯合構成加密密鑰或解密密鑰。

  e:一個大數,作為加密密鑰。

  d:一個和e互異的大數,作為解密密鑰。

  返回值:1-成功,0-失敗。

  B. 數據加密函數

  char gEncRSA(unsigned char* indata, unsigned long inlen, gBigInt* e, gBigInt* n,\

  unsigned char *outdata, unsigned long* outlen, int flg);

  功能:把待加密的明文數據indata,用加密密鑰e和n進行分段加密。

  加密后的數據放到提前開辟好的內存outdata中,其長度outlen不得小于((inlen+k-12)/(k-11))*k,這里k為n的位數。

  參數:

  indata:指向明文數據的指針。

  Inlen:傳入數據的長度,即明文數據的長度。

  e和n:兩個大數,作為加密密鑰。

  Outdata:存放加密后密文數據的指針。

  Outlen:傳入outdata的長度,傳出數據的長度,即密文數據的長度。

  Flg:公鑰加密或私鑰加密的標志,g_PUBLIC-公鑰,g_PRIVATE-私鑰。

  返回值:1-成功,0-失敗。

  C. 數據解密函數

  char gDecRSA(unsigned char* indata, unsigned long inlen, gBigInt* d, gBigInt* n,\

  unsigned char *outdata, unsigned long* outlen, int flg);

  功能:把待解密的密文數據indata,用解密密鑰e和n進行分段解密。

  解密后的數據放到提前開辟好的內存outdata中,其長度outlen不得小于(inlen)*k/(k-11),

  這里k為n的位數。

  參數:

  indata:指向密文數據的指針。

  Inlen:傳入數據的長度,即密文數據的長度。

  d和n:兩個大數,作為加密密鑰。

  Outdata:存放解密后明文數據的指針。

  Outlen:傳入outdata的長度,傳出數據的長度,即明文數據的長度。

  Flg:公鑰加密或私鑰加密的標志,g_PUBLIC-公鑰,g_PRIVATE-私鑰。

  返回值:1-成功,0-失敗。

  D. 用小素數檢測

百分百考試網 考試寶典

立即免費試用
久久综合色综合88| 久久久成人免费视频| 色悠悠久久综合| 色婷婷成人网| 波多野结衣在线电影| 国产成人+综合亚洲+天堂| 香蕉成人影院| 日韩一级片免费视频| 夜间精品视频| 久久久久亚洲av成人毛片韩| 精品国产电影一区二区| 色视频在线观看在线播放| 日韩欧美亚洲国产一区| 男人午夜天堂| 久久性爱视频网站| 亚洲一区二区三区免费视频| 3d动漫成人在线| 五月天亚洲综合| 日韩中出av| 日韩黄色片视频| 一区二区免费看| a免费在线观看| 亚洲裸色大胆大尺寸艺术写真| a级在线观看视频| 亚洲综合在线第一页| 四虎影音在线| 日韩三级电影| 国产精品91xxx| 全免费a级毛片| 精品人在线二区三区| 最新av电影| 国产私拍一区| 欧美色另类天堂2015| 91久久精品无嫩草影院 | 亚洲天堂成人在线观看| 久久久久中文字幕亚洲精品| 91麻豆精品国产91久久久久久久久| 久草资源在线观看| 无码人妻aⅴ一区二区三区69岛| 国产精品99在线观看| 污污视频在线免费看| 最近中文字幕一区二区| 欧美成人久久久| gogogogo高清视频在线| 久久午夜鲁丝片午夜精品| 成人h猎奇视频网站| 天堂蜜桃91精品| 91大神福利视频| 欧美一级欧美一级在线播放| 欧美电影网站| 国产成人无码精品久久久久| 国产精品久久久久久久久久三级 | 91av视频免费观看| 久久久影视精品| 国产一区二区高清在线| 久操视频免费看| 欧美中文在线字幕| 波多野洁衣一区| 男同在线观看| 亚洲五码在线观看视频| 老牛嫩草一区二区三区日本| 高清免费观看在线| 亚洲精品自拍网| 91精品国产综合久久精品性色 | 久久精品99久久无色码中文字幕| 中文字幕在线看精品乱码| 亚洲巨乳在线观看| 综合136福利视频在线| 黄网站免费久久| 色视频www在线播放国产人成| 91aaa精品| 色偷偷9999www| 九九精品久久| 黄色污污网站在线观看| 国产成年人在线观看| 在线中文字幕一区二区| 精品国产美女| 91美女视频在线| 亚洲国产成人不卡| 亚洲精品五月天| 国产成人1区| 桃花网日韩影视在线观看视频| 69av视频在线| 日韩欧美理论片| 免费日韩电影在线观看| 精品香蕉一区二区三区| 久久激情电影| 国内a∨免费播放| 国产精品少妇在线视频| 日韩一区二区三区国产| 风流少妇一区二区| 成人做爰免费视频免费看| 97精品人妻一区二区三区| 亚洲一线二线三线久久久| 国产图片一区| 2019一级黄色毛片免费看网| 亚洲久草视频| 中国一级特黄毛片| 中文字幕一区二区三区在线乱码| 日韩精品影音先锋| 日韩精品一级中文字幕精品视频免费观看 | 999精品在线视频| 男女激情无遮挡| 日本精品一区二区三区在线播放视频| 亚洲精品日韩专区silk| 牲欧美videos精品| 亚洲а∨精品天堂在线| 一区二区视频免费看| 久久综合狠狠综合久久综青草| 欧美久久久久久久久中文字幕| 秋霞国产午夜精品免费视频| 在线看片黄色| 国产又粗又猛又爽又黄的视频四季 | 欧美电影h版| 欧美黄色免费视频| 波多野结衣黄色| 天天爱天天做天天操| 亚洲最新在线观看| 久久精品最新免费国产成人| 国产精品久久久久久久久久久久冷| 国产日产精品一区| 欧美天堂一区| 精品女同一区二区| 轻轻草成人在线| 日韩精品2区| 成人精品亚洲| 亚洲高清毛片| 综合一区在线| 国产一区二区福利| 国产一区免费电影| 亚洲免费网站| 亚洲毛片免费看| av资源在线观看免费高清| 最近中文字幕在线视频| 日本中文字幕高清| 精品一区二区三区视频日产| 亚洲理论在线a中文字幕| 国产精品午夜电影| 久久久综合视频| 久久免费大视频| 成人性爱视频在线观看| 国产刺激高潮av| 人人妻人人澡人人爽| 一区二区三区视频在线播放| 日韩在线视频一区| 亚洲国产欧美在线| 99精品国产91久久久久久 | 水莓100在线视频| 免费黄网大全| 在线免费一区二区| 国产成人小视频在线观看| 久久久久久久久久久97| 国产超碰精品| 精品国产百合女同互慰| 日韩福利在线视频| 麻豆精品蜜桃| 亚洲精品720p| 麻豆成人在线视频| 久草视频国产| 日韩福利视频导航| 都市激情久久久久久久久久久| 男女啪啪无遮挡| 夜夜精品视频| 亚洲一区二区三区xxx视频| 四虎久久影院| 久久成人精品无人区| 国产在线一区二区三区欧美| 国产精品欧美韩国日本久久| 国产最新精品免费| 日本一区二区三区www| 福利视频1000| 久久久蜜桃精品| 激情五月开心婷婷| 精品成人一区二区三区免费视频| 亚洲一区二区三区在线看| 自拍一级黄色片| 中国色在线日|韩| 亚洲毛片在线免费观看| 在线精品免费视| 亚洲一级淫片| 国产乱码一区| 成人免费观看在线网址| 国产精品久久久久7777按摩| 国产日韩在线一区二区三区| 精品无线一线二线三线| 国产99一区视频免费| 日本大片免费看| 成人性爱视频在线观看| 欧美精品xxxxbbbb| 玖玖爱免费视频| re久久精品视频| 成人淫片在线看| 激情小说图片视频| 亚洲视频香蕉人妖| 精品熟女一区二区三区| 精品九九久久| 久久露脸国产精品| 久草国产视频| 欧美激情一区三区| 亚洲av成人片色在线观看高潮|