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

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

?? r_keygen.c

?? 一個測試DES加密算法和測試程序
?? C
字號:
/* R_KEYGEN.C - key-pair generation for RSAREF
 */

/* Copyright (C) RSA Laboratories, a division of RSA Data Security,
     Inc., created 1991. All rights reserved.
 */

#include "global.h"
#include "rsaref.h"
#include "r_random.h"
#include "nn.h"
#include "prime.h"

static int RSAFilter PROTO_LIST
  ((NN_DIGIT *, unsigned int, NN_DIGIT *, unsigned int));
static int RelativelyPrime PROTO_LIST
  ((NN_DIGIT *, unsigned int, NN_DIGIT *, unsigned int));

/* Generates an RSA key pair with a given length and public exponent.
 */
int R_GeneratePEMKeys (publicKey, privateKey, protoKey, randomStruct)
R_RSA_PUBLIC_KEY *publicKey;                          /* new RSA public key */
R_RSA_PRIVATE_KEY *privateKey;                       /* new RSA private key */
R_RSA_PROTO_KEY *protoKey;                             /* RSA prototype key */
R_RANDOM_STRUCT *randomStruct;                          /* random structure */
{
  NN_DIGIT d[MAX_NN_DIGITS], dP[MAX_NN_DIGITS], dQ[MAX_NN_DIGITS],
    e[MAX_NN_DIGITS], n[MAX_NN_DIGITS], p[MAX_NN_DIGITS], phiN[MAX_NN_DIGITS],
    pMinus1[MAX_NN_DIGITS], q[MAX_NN_DIGITS], qInv[MAX_NN_DIGITS],
    qMinus1[MAX_NN_DIGITS], t[MAX_NN_DIGITS], u[MAX_NN_DIGITS],
    v[MAX_NN_DIGITS];
  int status;
  unsigned int nDigits, pBits, pDigits, qBits;
  
  if ((protoKey->bits < MIN_RSA_MODULUS_BITS) || 
      (protoKey->bits > MAX_RSA_MODULUS_BITS))
    return (RE_MODULUS_LEN);
  nDigits = (protoKey->bits + NN_DIGIT_BITS - 1) / NN_DIGIT_BITS;
  pDigits = (nDigits + 1) / 2;
  pBits = (protoKey->bits + 1) / 2;
  qBits = protoKey->bits - pBits;

  /* NOTE: for 65537, this assumes NN_DIGIT is at least 17 bits. */
  NN_ASSIGN_DIGIT
    (e, protoKey->useFermat4 ? (NN_DIGIT)65537 : (NN_DIGIT)3, nDigits);

  /* Generate prime p between 3*2^(pBits-2) and 2^pBits-1, searching
       in steps of 2, until one satisfies gcd (p-1, e) = 1.
   */
  NN_Assign2Exp (t, pBits-1, pDigits);
  NN_Assign2Exp (u, pBits-2, pDigits);
  NN_Add (t, t, u, pDigits);
  NN_ASSIGN_DIGIT (v, 1, pDigits);
  NN_Sub (v, t, v, pDigits);
  NN_Add (u, u, v, pDigits);
  NN_ASSIGN_DIGIT (v, 2, pDigits);
  do {
    if (status = GeneratePrime (p, t, u, v, pDigits, randomStruct))
      return (status);
  }
  while (! RSAFilter (p, pDigits, e, 1));
  
  /* Generate prime q between 3*2^(qBits-2) and 2^qBits-1, searching
       in steps of 2, until one satisfies gcd (q-1, e) = 1.
   */
  NN_Assign2Exp (t, qBits-1, pDigits);
  NN_Assign2Exp (u, qBits-2, pDigits);
  NN_Add (t, t, u, pDigits);
  NN_ASSIGN_DIGIT (v, 1, pDigits);
  NN_Sub (v, t, v, pDigits);
  NN_Add (u, u, v, pDigits);
  NN_ASSIGN_DIGIT (v, 2, pDigits);
  do {
    if (status = GeneratePrime (q, t, u, v, pDigits, randomStruct))
      return (status);
  }
  while (! RSAFilter (q, pDigits, e, 1));
  
  /* Sort so that p > q. (p = q case is extremely unlikely.)
   */
  if (NN_Cmp (p, q, pDigits) < 0) {
    NN_Assign (t, p, pDigits);
    NN_Assign (p, q, pDigits);
    NN_Assign (q, t, pDigits);
  }

  /* Compute n = pq, qInv = q^{-1} mod p, d = e^{-1} mod (p-1)(q-1),
     dP = d mod p-1, dQ = d mod q-1.
   */
  NN_Mult (n, p, q, pDigits);
  NN_ModInv (qInv, q, p, pDigits);
  
  NN_ASSIGN_DIGIT (t, 1, pDigits);
  NN_Sub (pMinus1, p, t, pDigits);
  NN_Sub (qMinus1, q, t, pDigits);
  NN_Mult (phiN, pMinus1, qMinus1, pDigits);

  NN_ModInv (d, e, phiN, nDigits);
  NN_Mod (dP, d, nDigits, pMinus1, pDigits);
  NN_Mod (dQ, d, nDigits, qMinus1, pDigits);
  
  publicKey->bits = privateKey->bits = protoKey->bits;
  NN_Encode (publicKey->modulus, MAX_RSA_MODULUS_LEN, n, nDigits);
  NN_Encode (publicKey->exponent, MAX_RSA_MODULUS_LEN, e, 1);
  R_memcpy 
    ((POINTER)privateKey->modulus, (POINTER)publicKey->modulus,
     MAX_RSA_MODULUS_LEN);
  R_memcpy
    ((POINTER)privateKey->publicExponent, (POINTER)publicKey->exponent,
     MAX_RSA_MODULUS_LEN);
  NN_Encode (privateKey->exponent, MAX_RSA_MODULUS_LEN, d, nDigits);
  NN_Encode (privateKey->prime[0], MAX_RSA_PRIME_LEN, p, pDigits);
  NN_Encode (privateKey->prime[1], MAX_RSA_PRIME_LEN, q, pDigits);
  NN_Encode (privateKey->primeExponent[0], MAX_RSA_PRIME_LEN, dP, pDigits);
  NN_Encode (privateKey->primeExponent[1], MAX_RSA_PRIME_LEN, dQ, pDigits);
  NN_Encode (privateKey->coefficient, MAX_RSA_PRIME_LEN, qInv, pDigits);
   
  /* Zeroize sensitive information.
   */
  R_memset ((POINTER)d, 0, sizeof (d));
  R_memset ((POINTER)dP, 0, sizeof (dP));
  R_memset ((POINTER)dQ, 0, sizeof (dQ));
  R_memset ((POINTER)p, 0, sizeof (p));
  R_memset ((POINTER)phiN, 0, sizeof (phiN));
  R_memset ((POINTER)pMinus1, 0, sizeof (pMinus1));
  R_memset ((POINTER)q, 0, sizeof (q));
  R_memset ((POINTER)qInv, 0, sizeof (qInv));
  R_memset ((POINTER)qMinus1, 0, sizeof (qMinus1));
  R_memset ((POINTER)t, 0, sizeof (t));
  
  return (0);
}

/* Returns nonzero iff GCD (a-1, b) = 1.

   Lengths: a[aDigits], b[bDigits].
   Assumes aDigits < MAX_NN_DIGITS, bDigits < MAX_NN_DIGITS.
 */
static int RSAFilter (a, aDigits, b, bDigits)
NN_DIGIT *a, *b;
unsigned int aDigits, bDigits;
{
  int status;
  NN_DIGIT aMinus1[MAX_NN_DIGITS], t[MAX_NN_DIGITS];
  
  NN_ASSIGN_DIGIT (t, 1, aDigits);
  NN_Sub (aMinus1, a, t, aDigits);
  
  status = RelativelyPrime (aMinus1, aDigits, b, bDigits);

  /* Zeroize sensitive information.
   */
  R_memset ((POINTER)aMinus1, 0, sizeof (aMinus1));
  
  return (status);
}

/* Returns nonzero iff a and b are relatively prime.

   Lengths: a[aDigits], b[bDigits].
   Assumes aDigits >= bDigits, aDigits < MAX_NN_DIGITS.
 */
static int RelativelyPrime (a, aDigits, b, bDigits)
NN_DIGIT *a, *b;
unsigned int aDigits, bDigits;
{
  int status;
  NN_DIGIT t[MAX_NN_DIGITS], u[MAX_NN_DIGITS];
  
  NN_AssignZero (t, aDigits);
  NN_Assign (t, b, bDigits);
  NN_Gcd (t, a, t, aDigits);
  NN_ASSIGN_DIGIT (u, 1, aDigits);

  status = NN_EQUAL (t, u, aDigits);
  
  /* Zeroize sensitive information.
   */
  R_memset ((POINTER)t, 0, sizeof (t));
  
  return (status);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品免费日韩av| 欧美四级电影在线观看| 91在线精品一区二区三区| 久久99国产精品免费网站| 狠狠色丁香久久婷婷综合_中 | 亚洲成va人在线观看| 美女一区二区久久| 国产精品性做久久久久久| 99re热这里只有精品视频| 欧美日韩日日骚| 久久综合网色—综合色88| 国产精品久久久久久久久久久免费看| 日本一区二区三区国色天香| 亚洲男女毛片无遮挡| 精品亚洲免费视频| 欧美日韩三级在线| 欧美高清一级片在线观看| 人妖欧美一区二区| 欧洲另类一二三四区| 国产精品乱码人人做人人爱| 日韩电影免费在线看| 色八戒一区二区三区| 精品成人私密视频| 视频一区欧美精品| 色综合久久六月婷婷中文字幕| 精品精品国产高清一毛片一天堂| 亚洲精品视频自拍| 色久综合一二码| 尤物视频一区二区| 91久久一区二区| 亚洲素人一区二区| 91精彩视频在线| 日本网站在线观看一区二区三区 | 欧美一区二区国产| 丝袜美腿亚洲色图| 这里只有精品视频在线观看| 亚洲午夜精品17c| 欧美一级黄色大片| 日韩在线a电影| 久久综合久久久久88| 精品一区免费av| 国产精品午夜电影| 91麻豆文化传媒在线观看| 久久久午夜精品理论片中文字幕| 久久99久久99精品免视看婷婷| 久久久久久久久久久久电影 | 美女一区二区久久| 一级日本不卡的影视| 欧美日韩一级黄| 国产精品77777| 日韩精品亚洲专区| 日本一区二区电影| 欧美一区二区福利视频| 一本大道综合伊人精品热热 | 欧美一区二区三区在线| 国产成人免费在线| 婷婷成人激情在线网| 欧美韩国日本不卡| 日韩限制级电影在线观看| 色偷偷久久一区二区三区| 热久久一区二区| 亚洲国产日韩精品| 国产精品剧情在线亚洲| 精品1区2区在线观看| 91精品国产欧美一区二区成人| 成人av免费在线| 东方欧美亚洲色图在线| 人人精品人人爱| www.av精品| 成人免费视频播放| 懂色av一区二区在线播放| 高清国产午夜精品久久久久久| 老司机精品视频线观看86| 免费xxxx性欧美18vr| 久久成人综合网| 国产精品中文字幕欧美| 国产成人亚洲综合a∨婷婷| 国产精品一二一区| 91麻豆成人久久精品二区三区| 色天使色偷偷av一区二区| 欧美三级视频在线播放| 欧美一级一区二区| 久久看人人爽人人| 亚洲精品写真福利| 激情都市一区二区| 在线观看一区二区精品视频| 91精品国产aⅴ一区二区| 国产精品拍天天在线| 亚洲国产精品嫩草影院| 99re8在线精品视频免费播放| 欧美精品自拍偷拍动漫精品| 国产亚洲欧美一级| 日本午夜精品视频在线观看 | 色婷婷av一区二区| 久久综合久久久久88| 亚洲第一激情av| 色女孩综合影院| 中文字幕精品综合| 久热成人在线视频| 欧美色国产精品| 亚洲免费高清视频在线| eeuss影院一区二区三区| 欧美一区二区三区四区视频| 亚洲欧美日韩在线| 国产精品一区在线| 日韩女优毛片在线| 国产综合色产在线精品| 久久蜜桃香蕉精品一区二区三区| 日日欢夜夜爽一区| 日韩欧美国产系列| 毛片一区二区三区| 久久久久久久一区| 99久久久无码国产精品| 欧美久久久久久久久中文字幕| 视频在线观看国产精品| 日韩欧美一二三四区| 国产福利精品一区二区| 国产精品久久久久久亚洲毛片 | aaa亚洲精品| 一区二区三区高清在线| 欧美精品久久久久久久多人混战| 蜜桃一区二区三区四区| 中文字幕一区二| 欧美一区二区三区在线观看| av高清不卡在线| 经典三级视频一区| 亚洲国产精品一区二区www在线| 日韩精品一区二区在线| 91福利视频网站| 懂色中文一区二区在线播放| 天堂影院一区二区| 一区二区三区在线高清| 久久精品人人做人人综合| 欧美三级日本三级少妇99| 99国产麻豆精品| 成人在线综合网| 从欧美一区二区三区| 久久99热狠狠色一区二区| 日韩vs国产vs欧美| 亚洲国产精品久久人人爱蜜臀| 成人欧美一区二区三区白人| 亚洲国产精品黑人久久久| 久久精品欧美一区二区三区不卡 | 欧美日韩亚洲另类| 日本高清不卡一区| 日本韩国精品一区二区在线观看| www.在线成人| 在线视频欧美区| 91久久精品日日躁夜夜躁欧美| 99国产精品国产精品久久| 97精品久久久久中文字幕| 91视频一区二区三区| 在线观看亚洲精品| 欧美性猛片aaaaaaa做受| 欧美在线制服丝袜| 欧美一区二区视频在线观看 | 老司机精品视频一区二区三区| 国产一区在线视频| 99国产精品久久久久久久久久久| 色先锋久久av资源部| 欧美mv日韩mv国产网站| 亚洲日本丝袜连裤袜办公室| 五月天视频一区| 成人黄色一级视频| 日韩欧美一区二区视频| 亚洲视频电影在线| 国产中文字幕精品| 欧美三级日本三级少妇99| 中文字幕av不卡| 奇米精品一区二区三区在线观看一| 国产精品小仙女| 欧美大尺度电影在线| 一二三区精品福利视频| 成人激情开心网| 国产精品国产三级国产有无不卡| 日韩黄色一级片| 欧美一区二区三区四区在线观看| 最新成人av在线| 一道本成人在线| 一区二区三区国产精品| 91黄色免费网站| 一区二区三区毛片| 欧美午夜一区二区三区免费大片| 亚洲黄色尤物视频| 色中色一区二区| 丝瓜av网站精品一区二区 | 麻豆专区一区二区三区四区五区| 在线观看免费成人| 午夜欧美一区二区三区在线播放| 欧洲在线/亚洲| 五月婷婷色综合| 精品乱码亚洲一区二区不卡| 国产呦精品一区二区三区网站| 久久综合精品国产一区二区三区| 粗大黑人巨茎大战欧美成人| 亚洲免费观看高清完整版在线观看熊| 色综合天天综合| 午夜一区二区三区在线观看| 日韩精品一区二区三区中文精品| 国产成人精品一区二区三区四区 |