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

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

?? rsakgimpl.c

?? IBE是一種非對稱密碼技術
?? C
?? 第 1 頁 / 共 2 頁
字號:

    /* Store the generated values in the buffers in the rsaGenCtx.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      prime1, &sign, rsaGenCtx->prime1.data, rsaGenCtx->prime1.len,
      &(rsaGenCtx->prime1.len));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      prime2, &sign, rsaGenCtx->prime2.data, rsaGenCtx->prime2.len,
      &(rsaGenCtx->prime2.len));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      expo1, &sign, rsaGenCtx->expo1.data, rsaGenCtx->expo1.len,
      &(rsaGenCtx->expo1.len));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      expo2, &sign, rsaGenCtx->expo2.data, rsaGenCtx->expo2.len,
      &(rsaGenCtx->expo2.len));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      coeff, &sign, rsaGenCtx->coeff.data, rsaGenCtx->coeff.len,
      &(rsaGenCtx->coeff.len));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      modulus, &sign, rsaGenCtx->modulus.data, rsaGenCtx->modulus.len,
      &(rsaGenCtx->modulus.len));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      priExpo, &sign, rsaGenCtx->priExpo.data, rsaGenCtx->priExpo.len,
      &(rsaGenCtx->priExpo.len));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = SetRSAPubKeyObject (libCtx, rsaGenCtx, pubKey);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = SetRSAPriKeyObject (libCtx, rsaGenCtx, priKey);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltTestRsaKeyPair (
      libCtx, surrCtx, rsaGenCtx->usageFlag, pubKey, priKey, randomToUse);

    /* If we're building this for the FIPS shared library, we want to set
     * the FIPS error.
     */
#if VOLT_BUILD == VOLT_BUILD_FIPS_SHARED
    if (status == VT_ERROR_UNMATCHED_KEY_PAIR)
    {
      VoltSetFipsError (VT_ERROR_FIPS_RSA_PAIR_GEN);
      status = VT_ERROR_FIPS_RSA_PAIR_GEN;
    }
#endif  /* VOLT_BUILD == VOLT_BUILD_FIPS_SHARED */
    if (status != 0)
      break;

    VOLT_CALL_SURRENDER (surrCtx, VT_SURRENDER_FNCT_RSA_KEY_GEN, 0, 0)

  } while (0);

  mpCtx->DestroyMpInt (&coeff);
  mpCtx->DestroyMpInt (&expo1);
  mpCtx->DestroyMpInt (&expo2);
  mpCtx->DestroyMpInt (&lambda);
  mpCtx->DestroyMpInt (&modulus);
  mpCtx->DestroyMpInt (&priExpo);
  mpCtx->DestroyMpInt (&pubExpo);
  mpCtx->DestroyMpInt (&prime1);
  mpCtx->DestroyMpInt (&prime2);

  VOLT_LOG_ERROR_INFO_COMPARE (
    status, 0, priKey, status, 0, errorType,
    (char *)0, "RSAGenerateKeyPair", fnctLine, (char *)0)

  return (status);
}

static int SetRSAPubKeyObject (
   VoltLibCtx *libCtx,
   VoltRsaKeyGenCtx *rsaGenCtx,
   VtKeyObject pubKey
   )
{
  int status;
  VtRSAPubKeyInfo keyInfo;
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  VOLT_SET_FNCT_LINE (fnctLine)
  keyInfo.modulus = rsaGenCtx->modulus;
  keyInfo.pubExpo = rsaGenCtx->pubExpo;
  if (rsaGenCtx->usageFlag == VT_RSA_KEY_USAGE_SIGN_VERIFY)
    status = VtSetKeyParam (
      pubKey, VtKeyParamRSAPublicVerify, (Pointer)&keyInfo);
  else
    status = VtSetKeyParam (
      pubKey, VtKeyParamRSAPublicEncrypt, (Pointer)&keyInfo);

  VOLT_LOG_ERROR_INFO_COMPARE (
    status, libCtx, 0, status, 0, 0,
    (char *)0, "SetRSAPubKeyObject", fnctLine, (char *)0)

  return (status);
}

static int SetRSAPriKeyObject (
   VoltLibCtx *libCtx,
   VoltRsaKeyGenCtx *rsaGenCtx,
   VtKeyObject priKey
   )
{
  int status;
  VtRSAPriKeyInfo keyInfo;
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  VOLT_SET_FNCT_LINE (fnctLine)
  keyInfo.modulus = rsaGenCtx->modulus;
  keyInfo.pubExpo = rsaGenCtx->pubExpo;
  keyInfo.priExpo = rsaGenCtx->priExpo;
  keyInfo.prime1 = rsaGenCtx->prime1;
  keyInfo.prime2 = rsaGenCtx->prime2;
  keyInfo.exponent1 = rsaGenCtx->expo1;
  keyInfo.exponent2 = rsaGenCtx->expo2;
  keyInfo.coefficient = rsaGenCtx->coeff;
  if (rsaGenCtx->usageFlag == VT_RSA_KEY_USAGE_SIGN_VERIFY)
    status = VtSetKeyParam (
      priKey, VtKeyParamRSAPrivateSign, (Pointer)&keyInfo);
  else
    status = VtSetKeyParam (
      priKey, VtKeyParamRSAPrivateDecrypt, (Pointer)&keyInfo);

  VOLT_LOG_ERROR_INFO_COMPARE (
    status, libCtx, 0, status, 0, 0,
    (char *)0, "SetRSAPriKeyObject", fnctLine, (char *)0)

  return (status);
}

int VoltTestRsaKeyPair (
   VoltLibCtx *libCtx,
   VoltSurrenderCtx *surrCtx,
   unsigned int usageFlag,
   VtKeyObject pubKey,
   VtKeyObject priKey,
   VtRandomObject random
   )
{
  int status;
  unsigned int modLen, offsetE, offsetD;
  unsigned int encryptedDataLen, decryptedDataLen, verifyResult;
  unsigned char *buffer = (unsigned char *)0;
  VtAlgorithmObject algObj = (VtAlgorithmObject)0;
  VtRSAPubKeyInfo *pubKeyInfo;
  VtRSAInfo rsaInfo;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* How big is the modulus? We'll need input of that length and two
     * output buffers that size.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    if (usageFlag == VT_RSA_KEY_USAGE_SIGN_VERIFY)
    {
      status = VtGetKeyParam (
        pubKey, VtKeyParamRSAPublicVerify, (Pointer *)&pubKeyInfo);
    }
    else
    {
      status = VtGetKeyParam (
        pubKey, VtKeyParamRSAPublicEncrypt, (Pointer *)&pubKeyInfo);
    }
    if (status != 0)
      break;

    modLen = pubKeyInfo->modulus.len;

    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_MEMORY;
    buffer = (unsigned char *)Z2Malloc (
      (2 * modLen) + 20, VOLT_MEMORY_SENSITIVE);
    if (buffer == (unsigned char *)0)
      break;

    offsetE = 20;
    offsetD = 20 + modLen;

    /* Generate "random" data to encrypt or sign.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VtGenerateRandomBytes (random, buffer, 20);
    if (status != 0)
      break;

    if (usageFlag == VT_RSA_KEY_USAGE_ENCRYPT_DECRYPT)
    {
      /* Encrypt that data using the pubKey.
       */
      rsaInfo.padding = VtPaddingPkcs1Type2;
      rsaInfo.paddingInfo = (Pointer)0;
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtCreateAlgorithmObject (
        (VtLibCtx)libCtx, VtAlgorithmImplRSAEncrypt, (Pointer)&rsaInfo,
        &algObj);
      if (status != 0)
        break;

      /* Set the encryption object with the surrender ctx.
       */
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltSetObjectSurrenderCtx ((VoltObject *)algObj, surrCtx);
      if (status != 0)
        break;

      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtEncryptInit (algObj, pubKey);
      if (status != 0)
        break;

      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtEncryptFinal (
        algObj, random, buffer, 20,
        buffer + offsetE, modLen, &encryptedDataLen);
      if (status != 0)
        break;

      /* Now decrypt the data.
       */
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtDecryptInit (algObj, priKey);
      if (status != 0)
        break;

      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtDecryptFinal (
        algObj, (VtRandomObject)0, buffer + offsetE, encryptedDataLen,
        buffer + offsetD, modLen, &decryptedDataLen);
      if (status != 0)
        break;

      /* If the length and data are the same, the keys are partners.
       */
      VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VT_ERROR_UNMATCHED_KEY_PAIR;
      if (decryptedDataLen != 20)
        break;

      VOLT_SET_FNCT_LINE (fnctLine)
      if (Z2Memcmp (buffer, buffer + offsetD, decryptedDataLen) != 0)
        break;
    }
    else
    {
      /* Sign using the private key.
       */
      rsaInfo.padding = VtPaddingPkcs1Type1;
      rsaInfo.paddingInfo = (Pointer)0;
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtCreateAlgorithmObject (
        (VtLibCtx)libCtx, VtAlgorithmImplRSASignVerify, (Pointer)&rsaInfo,
        &algObj);
      if (status != 0)
        break;

      /* Set the encryption object with the surrender ctx.
       */
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltSetObjectSurrenderCtx ((VoltObject *)algObj, surrCtx);
      if (status != 0)
        break;

      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtSign (
        algObj, priKey, random, VT_DIGEST_ALG_SHA1,
        buffer, 20, buffer + offsetE, modLen, &encryptedDataLen);
      if (status != 0)
        break;

      /* Try to verify
       */
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtVerifySignature (
        algObj, pubKey, random, VT_DIGEST_ALG_SHA1,
        buffer, 20, buffer + offsetE, encryptedDataLen, &verifyResult);
      if (status != 0)
        break;

      /* If the signature verifies, the keys are partners, if not, return
       * an error.
       */
      VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VT_ERROR_UNMATCHED_KEY_PAIR;
      if (verifyResult == 0)
        break;
    }

    status = 0;

  } while (0);

  if (buffer != (unsigned char *)0)
    Z2Free (buffer);

  VtDestroyAlgorithmObject (&algObj);

  VOLT_LOG_ERROR_INFO_COMPARE (
    status, libCtx, 0, status, 0, errorType,
    (char *)0, "VoltTestRsaKeyPair", fnctLine, (char *)0)

  return (status);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产suv精品一区二区883| 最新成人av在线| 日本特黄久久久高潮| 欧美日韩国产高清一区二区| 午夜国产精品影院在线观看| 3d动漫精品啪啪| 国产一区亚洲一区| 国产精品女同一区二区三区| 91色九色蝌蚪| 青椒成人免费视频| 久久综合五月天婷婷伊人| 成人午夜电影小说| 玉足女爽爽91| 日韩欧美国产电影| 成人av在线影院| 一区二区国产视频| 日韩久久精品一区| 懂色av中文一区二区三区| 成人欧美一区二区三区在线播放| 色综合久久99| 日本成人在线电影网| 久久久亚洲欧洲日产国码αv| 91在线国产福利| 婷婷综合在线观看| 久久精品日韩一区二区三区| 91网站最新地址| 奇米影视在线99精品| 国产精品家庭影院| 制服丝袜亚洲播放| 91性感美女视频| 久久国产免费看| 亚洲精品视频在线观看免费| 26uuu国产日韩综合| 色哟哟在线观看一区二区三区| 美女脱光内衣内裤视频久久影院| 中文字幕亚洲在| 日韩欧美激情在线| 91国偷自产一区二区三区观看 | 视频精品一区二区| 久久久99免费| 欧美日韩国产在线观看| 粗大黑人巨茎大战欧美成人| 亚洲国产成人av| 国产精品欧美综合在线| 欧美不卡视频一区| 欧美人成免费网站| 色综合久久99| 成人污污视频在线观看| 久久99久久久久| 午夜激情一区二区| 亚洲精品欧美在线| 中文字幕在线观看不卡| 亚洲精品一线二线三线| 91.com在线观看| 日本电影欧美片| 91在线国产观看| 成人免费高清视频| 国产精品一区二区在线观看网站| 亚洲成av人片一区二区梦乃| 国产精品成人免费在线| 久久亚区不卡日本| 日韩精品中午字幕| 日韩午夜小视频| 欧美日韩日日骚| 欧美性videosxxxxx| 91原创在线视频| 9人人澡人人爽人人精品| 国产成人精品免费网站| 狠狠色综合播放一区二区| 日韩国产欧美在线视频| 亚洲最新视频在线观看| 亚洲乱码精品一二三四区日韩在线 | 欧美日韩成人综合天天影院| 日本精品免费观看高清观看| 91丨九色porny丨蝌蚪| 99久久久精品免费观看国产蜜| 成人免费福利片| 成人国产精品免费| www.在线成人| 91色九色蝌蚪| 欧美日韩一级二级三级| 538prom精品视频线放| 欧美一区在线视频| 欧美大片国产精品| 久久亚区不卡日本| 中文字幕不卡三区| 国产精品国产三级国产三级人妇| 成人免费小视频| 一区2区3区在线看| 偷拍一区二区三区| 久久精品国产网站| 国产成人免费视| 一本在线高清不卡dvd| 欧美午夜在线一二页| 777a∨成人精品桃花网| 久久综合久久鬼色| 国产精品美女久久久久久2018 | 欧美日韩在线三级| 日韩精品中文字幕一区二区三区| 精品国产91乱码一区二区三区| 欧美xxxxx裸体时装秀| 久久久久久久综合| 国产精品传媒入口麻豆| 一区二区三区蜜桃网| 偷拍一区二区三区| 国产成人在线色| 在线免费观看日本欧美| 欧美日韩一级二级三级| 2023国产精华国产精品| 欧美极品少妇xxxxⅹ高跟鞋| 一区二区三区在线观看国产 | 免费在线观看一区二区三区| 日韩国产精品久久久| 一区二区三区四区中文字幕| 香港成人在线视频| 亚洲精品免费在线观看| 亚洲va在线va天堂| 国产资源精品在线观看| 国产成人精品影视| 欧美自拍偷拍一区| 欧美大肚乱孕交hd孕妇| 国产精品色眯眯| 五月婷婷综合激情| www.亚洲国产| 欧美日韩日日摸| 欧美国产1区2区| 亚洲精品视频一区| 精品一区二区国语对白| 在线观看免费亚洲| 精品久久一二三区| 午夜欧美视频在线观看| 国产成人h网站| 欧美巨大另类极品videosbest | 日韩电影免费在线观看网站| 久久国产精品无码网站| 欧美中文字幕一区| 国产视频一区在线播放| 亚洲国产综合色| av动漫一区二区| 欧美一区二区视频在线观看| 亚洲视频 欧洲视频| 久久精品国产亚洲5555| 欧美日韩一区精品| 中文在线一区二区 | 久久综合久久综合久久综合| 一区二区在线观看视频 | 久久九九影视网| 亚洲综合色区另类av| 国产乱人伦精品一区二区在线观看| 在线欧美日韩精品| 国产欧美一区二区精品性色| 日韩高清在线观看| 日本电影亚洲天堂一区| 1000部国产精品成人观看| 精品一区二区影视| 精品国产免费人成在线观看| 亚洲午夜久久久久久久久电影网 | 日韩在线一区二区三区| 欧美在线999| 国产精品高清亚洲| 成人av资源下载| 亚洲精品一区二区精华| 久久精品国内一区二区三区| 欧美一区二区三区白人| 亚洲午夜久久久| 成人久久18免费网站麻豆| 欧美无乱码久久久免费午夜一区 | 亚洲精品一区在线观看| 毛片av一区二区三区| 日韩欧美色电影| 日本不卡一区二区| 日韩欧美国产一区二区在线播放| 亚洲va国产va欧美va观看| 在线不卡免费欧美| 香蕉乱码成人久久天堂爱免费| 欧美区视频在线观看| 亚洲激情第一区| 欧美日韩精品一区二区三区| 视频在线观看国产精品| 欧美丰满少妇xxxxx高潮对白| 三级影片在线观看欧美日韩一区二区 | 色婷婷精品久久二区二区蜜臂av| 一区二区三区在线播放| 在线免费视频一区二区| 亚洲国产成人av| 欧美精品乱人伦久久久久久| 男女性色大片免费观看一区二区| 制服丝袜日韩国产| 国产一区不卡在线| 久久久久久久久久美女| 国产原创一区二区三区| 国产精品色一区二区三区| 91在线观看高清| 日本成人在线一区| 日韩精品中文字幕在线一区| 视频在线观看91| 欧美久久久久免费| 国内外精品视频| 欧美日本一区二区| 国产综合久久久久久久久久久久|