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

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

?? r_encode.c

?? 一個測試DES加密算法和測試程序
?? C
字號:
/* R_ENCODE.C - RFC 1113 encoding and decoding routines
 */

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

#include "global.h"
#include "rsaref.h"

/* RFC 1113 encoding:

   Value Encoding  Value Encoding  Value Encoding  Value Encoding
       0 A            17 R            34 i            51 z
       1 B            18 S            35 j            52 0
       2 C            19 T            36 k            53 1
       3 D            20 U            37 l            54 2
       4 E            21 V            38 m            55 3
       5 F            22 W            39 n            56 4
       6 G            23 X            40 o            57 5
       7 H            24 Y            41 p            58 6
       8 I            25 Z            42 q            59 7
       9 J            26 a            43 r            60 8
      10 K            27 b            44 s            61 9
      11 L            28 c            45 t            62 +
      12 M            29 d            46 u            63 /
      13 N            30 e            47 v
      14 O            31 f            48 w         (pad) =
      15 P            32 g            49 x
      16 Q            33 h            50 y
*/
#define ENCODING(i) \
  (unsigned char)(((i) < 26) ? ((i) + 0x41) : \
                  (((i) < 52) ? ((i) - 26 + 0x61) : \
                   (((i) < 62) ? ((i) - 52 + 0x30) : \
                    (((i) == 62) ? 0x2b : 0x2f))))
#define ENCODING_PAD 0x3d

#define IS_ENCODING(c) \
  ((((c) >= 0x41) && ((c) <= 0x5a)) || \
   (((c) >= 0x61) && ((c) <= 0x7a)) || \
   (((c) >= 0x30) && ((c) <= 0x39)) || \
   ((c) == 0x2b) || \
   ((c) == 0x2f))

/* assumes IS_ENCODING (c) == 1 */
#define DECODING(c) \
  (((c) == 0x2b) ? 62 : \
   (((c) == 0x2f) ? 63 : \
    (((c) <= 0x39) ? ((c) - 0x30 + 52) : \
     (((c) <= 0x5a) ? ((c) - 0x41) : ((c) - 0x61 + 26)))))
      
static void EncodeQuantum PROTO_LIST ((unsigned char [4], unsigned char [3]));
static int DecodeQuantum PROTO_LIST ((unsigned char [3], unsigned char [4]));
static void EncodeLastQuantum
  PROTO_LIST ((unsigned char [4], unsigned char *, unsigned int));
static int DecodeLastQuantum
  PROTO_LIST ((unsigned char *, unsigned int *, unsigned char [4]));

/* This always returns 0.  It is an int function for future compatibility.
 */
int R_EncodePEMBlock (encodedBlock, encodedBlockLen, block, blockLen)
unsigned char *encodedBlock;                               /* encoded block */
unsigned int *encodedBlockLen;                   /* length of encoded block */
unsigned char *block;                                              /* block */
unsigned int blockLen;                                   /* length of block */
{
  unsigned int i, lastLen;
  
  if (blockLen < 1) {
    *encodedBlockLen = 0;
    return (0);
  }
  
  for (i = 0; i < (blockLen-1)/3; i++)
    EncodeQuantum (&encodedBlock[4*i], &block[3*i]);
  
  lastLen = blockLen - 3*i;
  EncodeLastQuantum (&encodedBlock[4*i], &block[3*i], lastLen);
  *encodedBlockLen = 4*i + 4;

  return (0);
}
                    
int R_DecodePEMBlock (block, blockLen, encodedBlock, encodedBlockLen)
unsigned char *block;                                              /* block */
unsigned int *blockLen;                                  /* length of block */
unsigned char *encodedBlock;                               /* encoded block */
unsigned int encodedBlockLen;                    /* length of encoded block */
{
  int status;
  unsigned int i, lastLen;

  if (encodedBlockLen % 4)
    return (RE_ENCODING);
  
  if (encodedBlockLen < 1) {
    *blockLen = 0;
    return (0);
  }
  
  for (i = 0; i < (encodedBlockLen-1)/4; i++)
    if (status = DecodeQuantum (&block[3*i], &encodedBlock[4*i]))
      return (status);
    
  if (status = DecodeLastQuantum (&block[3*i], &lastLen, &encodedBlock[4*i]))
    return (status);

  *blockLen = 3*i + lastLen;
  return (0);
}

static void EncodeQuantum (encodedQuantum, quantum)
unsigned char encodedQuantum[4];
unsigned char quantum[3];
{
  UINT4 temp;
  unsigned int a, b, c, d;
  
  temp = ((UINT4)quantum[0]) << 16;
  temp |= ((UINT4)quantum[1]) << 8;
  temp |= (UINT4)quantum[2];
  
  a = (unsigned int)((temp >> 18) & 0x3f);
  b = (unsigned int)((temp >> 12) & 0x3f);
  c = (unsigned int)((temp >> 6) & 0x3f);
  d = (unsigned int)(temp & 0x3f);

  encodedQuantum[0] = ENCODING (a);
  encodedQuantum[1] = ENCODING (b);
  encodedQuantum[2] = ENCODING (c);
  encodedQuantum[3] = ENCODING (d);

  /* Zeroize potentially sensitive information.
   */
  temp = 0;
  a = b = c = d = 0;
}

static int DecodeQuantum (quantum, encodedQuantum)
unsigned char quantum[3];
unsigned char encodedQuantum[4];
{
  UINT4 temp;
  unsigned int a, b, c, d;
  
  if (! IS_ENCODING (encodedQuantum[0]) ||
      ! IS_ENCODING (encodedQuantum[1]) ||
      ! IS_ENCODING (encodedQuantum[2]) ||
      ! IS_ENCODING (encodedQuantum[3]))
    return (RE_ENCODING);
  
  a = DECODING (encodedQuantum[0]);
  b = DECODING (encodedQuantum[1]);
  c = DECODING (encodedQuantum[2]);
  d = DECODING (encodedQuantum[3]);
  
  temp = ((UINT4)a) << 18;
  temp |= ((UINT4)b) << 12;
  temp |= ((UINT4)c) << 6;
  temp |= (UINT4)d;

  quantum[0] = (unsigned char)(temp >> 16);
  quantum[1] = (unsigned char)(temp >> 8);
  quantum[2] = (unsigned char)temp;
  
  /* Zeroize potentially sensitive information.
   */
  temp = 0;
  a = b = c = d = 0;

  return (0);
}

static void EncodeLastQuantum (encodedQuantum, quantum, quantumLen)
unsigned char encodedQuantum[4];
unsigned char *quantum;
unsigned int quantumLen;                                       /* 1, 2 or 3 */
{
  UINT4 temp;
  unsigned int a, b, c, d;

  temp = ((UINT4)quantum[0]) << 16;
  if (quantumLen >= 2)
    temp |= ((UINT4)quantum[1]) << 8;
  if (quantumLen == 3)
    temp |= ((UINT4)quantum[2]);
  
  a = (unsigned int)((temp >> 18) & 0x3f);
  b = (unsigned int)((temp >> 12) & 0x3f);
  if (quantumLen >= 2)
    c = (unsigned int)((temp >> 6) & 0x3f);
  if (quantumLen == 3)
    d = (unsigned int)(temp & 0x3f);

  encodedQuantum[0] = ENCODING (a);
  encodedQuantum[1] = ENCODING (b);
  if (quantumLen >= 2)
    encodedQuantum[2] = ENCODING (c);
  else
    encodedQuantum[2] = ENCODING_PAD;
  if (quantumLen == 3)
    encodedQuantum[3] = ENCODING (d);
  else
    encodedQuantum[3] = ENCODING_PAD;

  /* Zeroize potentially sensitive information.
   */
  temp = 0;
  a = b = c = d = 0;
}

static int DecodeLastQuantum (quantum, quantumLen, encodedQuantum)
unsigned char *quantum;
unsigned int *quantumLen;                                      /* 1, 2 or 3 */
unsigned char encodedQuantum[4];
{
  UINT4 temp;
  unsigned int a, b, c, d;
  
  if (! IS_ENCODING (encodedQuantum[0]) ||
      ! IS_ENCODING (encodedQuantum[1]) ||
      (! IS_ENCODING (encodedQuantum[2]) &&
       (encodedQuantum[2] != ENCODING_PAD)) ||
      (! IS_ENCODING (encodedQuantum[3]) &&
       (encodedQuantum[3] != ENCODING_PAD)))
    return (RE_ENCODING);
        
  if (encodedQuantum[2] == ENCODING_PAD)
    *quantumLen = 1;
  else if (encodedQuantum[3] == ENCODING_PAD)
    *quantumLen = 2;
  else
    *quantumLen = 3;
  
  a = DECODING (encodedQuantum[0]);
  b = DECODING (encodedQuantum[1]);
  if (*quantumLen >= 2)
    c = DECODING (encodedQuantum[2]);
  if (*quantumLen == 3)
    d = DECODING (encodedQuantum[3]);
  
  temp = ((UINT4)a) << 18;
  temp |= ((UINT4)b) << 12;
  if (*quantumLen >= 2)
    temp |= ((UINT4)c) << 6;
  if (*quantumLen == 3)
    temp |= ((UINT4)d);

  quantum[0] = (unsigned char)(temp >> 16);
  if (*quantumLen >= 2)
    quantum[1] = (unsigned char)(temp >> 8);
  if (*quantumLen == 3)
    quantum[2] = (unsigned char)temp;
  
  /* Zeroize potentially sensitive information.
   */
  temp = 0;
  a = b = c = d = 0;
  
  return (0);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久精品国产麻豆演员表| 粉嫩aⅴ一区二区三区四区 | 99精品国产99久久久久久白柏| 久久久一区二区| 国产一区二区三区美女| 久久久久久久久岛国免费| 国产尤物一区二区在线| 亚洲国产精品国自产拍av| 岛国一区二区在线观看| 1区2区3区精品视频| 色天天综合久久久久综合片| 一区二区三区资源| 欧美人妇做爰xxxⅹ性高电影 | 日本强好片久久久久久aaa| 777久久久精品| 蜜臀av性久久久久蜜臀av麻豆| 欧美变态口味重另类| 国产乱理伦片在线观看夜一区| 欧美国产综合色视频| 91免费看`日韩一区二区| 亚洲电影在线播放| 26uuu欧美日本| 99精品视频在线播放观看| 亚洲成av人片一区二区三区 | 国产亚洲欧洲997久久综合| 成人精品小蝌蚪| 亚洲国产毛片aaaaa无费看| 日韩欧美一区二区在线视频| 国产一区二区三区四区五区入口 | 国产精品伊人色| 亚洲欧洲色图综合| 日韩欧美中文字幕一区| 97se亚洲国产综合自在线观| 制服丝袜亚洲色图| 奇米在线7777在线精品| 国产精品国产三级国产aⅴ原创| 在线免费不卡电影| 国产在线精品一区在线观看麻豆| 亚洲日本丝袜连裤袜办公室| 精品国产亚洲在线| 色婷婷亚洲综合| 美女被吸乳得到大胸91| 亚洲美女屁股眼交3| 2020国产成人综合网| 在线观看国产精品网站| 国产成人免费在线观看不卡| 视频一区视频二区中文| 国产精品入口麻豆九色| 日韩一区二区高清| 在线视频你懂得一区| 国产suv精品一区二区883| 亚洲风情在线资源站| 中文字幕亚洲电影| 久久久久国产免费免费| 91精品福利在线一区二区三区| 成人午夜看片网址| 国产在线一区观看| 日本亚洲欧美天堂免费| 亚洲一区二区视频在线观看| 国产精品美女久久久久高潮| 精品国产1区2区3区| 欧美精品丝袜中出| 欧美在线制服丝袜| 91蝌蚪porny| 99re在线视频这里只有精品| 国产不卡一区视频| 国产一区 二区| 久久精品99久久久| 毛片av一区二区| 日日嗨av一区二区三区四区| 一区二区三区高清| 亚洲男人天堂av| 亚洲欧美偷拍三级| 最新欧美精品一区二区三区| 国产精品毛片a∨一区二区三区| 久久久不卡影院| 久久综合色婷婷| 欧美成人女星排行榜| 91精品国产91综合久久蜜臀| 3d动漫精品啪啪1区2区免费| 欧美日本高清视频在线观看| 欧美三级午夜理伦三级中视频| 在线观看av一区二区| 欧美色成人综合| 欧美亚洲一区三区| 经典三级一区二区| 国产又黄又大久久| 粉嫩欧美一区二区三区高清影视| 国产二区国产一区在线观看| 国产91综合网| av网站一区二区三区| 日本高清视频一区二区| 一本色道久久综合亚洲aⅴ蜜桃| 色婷婷综合五月| 在线看国产日韩| 欧美性生活一区| 欧美福利一区二区| 日韩免费观看2025年上映的电影| 日韩欧美色综合网站| 久久久久久久久久久99999| 中文字幕在线一区二区三区| 依依成人综合视频| 天天综合色天天| 精品一区精品二区高清| 成人午夜电影小说| 欧美优质美女网站| 日韩女优电影在线观看| 国产欧美日韩综合精品一区二区| 亚洲人成网站色在线观看| 亚洲成人av一区二区| 极品美女销魂一区二区三区| 成人国产精品免费观看动漫| 91国模大尺度私拍在线视频| 欧美一区二区人人喊爽| 国产欧美一区二区精品忘忧草| 亚洲欧美激情在线| 捆绑紧缚一区二区三区视频| 成人一区二区视频| 欧美日韩综合在线| 久久精品人人做人人综合 | 午夜精品久久久久久久久| 国产一区二区在线免费观看| 色综合天天综合网天天狠天天| 91.com在线观看| 国产精品久线观看视频| 亚洲成人你懂的| 国产成人免费网站| 欧美日韩在线一区二区| 久久精品亚洲一区二区三区浴池| 亚洲国产视频a| 国产99精品在线观看| 91精品国产91久久久久久一区二区| 国产精品不卡一区| 奇米综合一区二区三区精品视频| gogo大胆日本视频一区| 欧美xxxx老人做受| 亚洲午夜国产一区99re久久| 成人美女视频在线看| 精品美女一区二区| 欧美一区二区三区婷婷月色| 日韩理论电影院| 激情综合亚洲精品| 欧美一区二区三区小说| 亚洲一区中文在线| 粉嫩一区二区三区性色av| 欧美电视剧免费全集观看| 亚洲一区日韩精品中文字幕| 国产91丝袜在线播放0| 日韩欧美的一区二区| 一区二区视频免费在线观看| 国产麻豆精品95视频| 欧美一级日韩一级| 亚洲电影一区二区| 91色|porny| 日韩高清在线观看| 亚洲麻豆国产自偷在线| 欧美va在线播放| 在线观看亚洲一区| 精品久久久久一区二区国产| 久久精品人人爽人人爽| 日本欧美一区二区| 欧美日韩精品欧美日韩精品| 亚洲欧美国产77777| zzijzzij亚洲日本少妇熟睡| 久久午夜色播影院免费高清| 免费成人性网站| 6080国产精品一区二区| 亚洲二区在线观看| 欧美日韩激情一区二区三区| 一区二区在线看| 日本韩国一区二区三区视频| 亚洲视频免费在线| 色播五月激情综合网| 一区二区在线看| 欧美三级日韩在线| 亚洲一区二区三区四区在线 | 亚洲国产视频一区二区| 欧美色视频在线| 日日摸夜夜添夜夜添亚洲女人| 欧美日韩亚洲综合在线| 性久久久久久久久| 欧美日韩二区三区| 丝袜国产日韩另类美女| 欧美一区二区美女| 国内精品国产三级国产a久久| xfplay精品久久| 丁香婷婷深情五月亚洲| 自拍偷拍欧美精品| 欧美色视频一区| 久久精品理论片| 国产欧美精品国产国产专区| 99re6这里只有精品视频在线观看| 亚洲精品视频在线看| 欧美日韩国产高清一区二区| 免费三级欧美电影| 久久综合999| 色香蕉成人二区免费| 亚洲h在线观看| 精品久久久久久久久久久久包黑料| 国产福利一区二区三区视频在线|