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

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

?? md5c.c

?? MD算法的源代碼
?? C
字號:
/* MD5C.C - RSA Data Security, Inc., MD5 message-digest algorithm
 */

/* Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All
rights reserved.

License to copy and use this software is granted provided that it
is identified as the "RSA Data Security, Inc. MD5 Message-Digest
Algorithm" in all material mentioning or referencing this software
or this function.

License is also granted to make and use derivative works provided
that such works are identified as "derived from the RSA Data
Security, Inc. MD5 Message-Digest Algorithm" in all material
mentioning or referencing the derived work.

RSA Data Security, Inc. makes no representations concerning either
the merchantability of this software or the suitability of this
software for any particular purpose. It is provided "as is"
without express or implied warranty of any kind.

These notices must be retained in any copies of any part of this
documentation and/or software.
 */

#include "global.h"
#include "md5.h"

/* Constants for MD5Transform routine.
 */


#define S11 7
#define S12 12
#define S13 17
#define S14 22
#define S21 5
#define S22 9
#define S23 14
#define S24 20
#define S31 4
#define S32 11
#define S33 16
#define S34 23
#define S41 6
#define S42 10
#define S43 15
#define S44 21

static void MD5Transform PROTO_LIST ((UINT4 [4], unsigned char [64]));
static void Encode PROTO_LIST
  ((unsigned char *, UINT4 *, unsigned int));
static void Decode PROTO_LIST
  ((UINT4 *, unsigned char *, unsigned int));
static void MD5_memcpy PROTO_LIST ((POINTER, POINTER, unsigned int));
static void MD5_memset PROTO_LIST ((POINTER, int, unsigned int));

static unsigned char PADDING[64] = {
  0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
};

/* F, G, H and I are basic MD5 functions.
 */
#define F(x, y, z) (((x) & (y)) | ((~x) & (z)))
#define G(x, y, z) (((x) & (z)) | ((y) & (~z)))
#define H(x, y, z) ((x) ^ (y) ^ (z))
#define I(x, y, z) ((y) ^ ((x) | (~z)))

/* ROTATE_LEFT rotates x left n bits.
 */
#define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n))))

/* FF, GG, HH, and II transformations for rounds 1, 2, 3, and 4.
Rotation is separate from addition to prevent recomputation.
 */
#define FF(a, b, c, d, x, s, ac) { \
 (a) += F ((b), (c), (d)) + (x) + (UINT4)(ac); \
 (a) = ROTATE_LEFT ((a), (s)); \
 (a) += (b); \
  }
#define GG(a, b, c, d, x, s, ac) { \
 (a) += G ((b), (c), (d)) + (x) + (UINT4)(ac); \
 (a) = ROTATE_LEFT ((a), (s)); \
 (a) += (b); \
  }
#define HH(a, b, c, d, x, s, ac) { \
 (a) += H ((b), (c), (d)) + (x) + (UINT4)(ac); \
 (a) = ROTATE_LEFT ((a), (s)); \
 (a) += (b); \
  }
#define II(a, b, c, d, x, s, ac) { \
 (a) += I ((b), (c), (d)) + (x) + (UINT4)(ac); \
 (a) = ROTATE_LEFT ((a), (s)); \
 (a) += (b); \
  }

/* MD5 initialization. Begins an MD5 operation, writing a new context.
 */
void MD5Init (context)
MD5_CTX *context;                                        /* context */
{
  context->count[0] = context->count[1] = 0;
  /* Load magic initialization constants.
*/
  context->state[0] = 0x67452301;
  context->state[1] = 0xefcdab89;
  context->state[2] = 0x98badcfe;
  context->state[3] = 0x10325476;
}

/* MD5 block update operation. Continues an MD5 message-digest
  operation, processing another message block, and updating the
  context.
 */
void MD5Update (context, input, inputLen)
MD5_CTX *context;                                        /* context */
unsigned char *input;                                /* input block */
unsigned int inputLen;                     /* length of input block */
{
  unsigned int i, index, partLen;

  /* Compute number of bytes mod 64 */
  index = (unsigned int)((context->count[0] >> 3) & 0x3F);

  /* Update number of bits */
  if ((context->count[0] += ((UINT4)inputLen << 3))
   < ((UINT4)inputLen << 3))
 context->count[1]++;
  context->count[1] += ((UINT4)inputLen >> 29);

  partLen = 64 - index;

  /* Transform as many times as possible.
*/
  if (inputLen >= partLen) {
 MD5_memcpy
   ((POINTER)&context->buffer[index], (POINTER)input, partLen);
 MD5Transform (context->state, context->buffer);

 for (i = partLen; i + 63 < inputLen; i += 64)
   MD5Transform (context->state, &input[i]);

 index = 0;
  }
  else
 i = 0;

  /* Buffer remaining input */
  MD5_memcpy
 ((POINTER)&context->buffer[index], (POINTER)&input[i],
  inputLen-i);
}

/* MD5 finalization. Ends an MD5 message-digest operation, writing the
  the message digest and zeroizing the context.
 */
void MD5Final (digest, context)
unsigned char digest[16];                         /* message digest */
MD5_CTX *context;                                       /* context */
{
  unsigned char bits[8];
  unsigned int index, padLen;

  /* Save number of bits */
  Encode (bits, context->count, 8);

  /* Pad out to 56 mod 64.
*/
  index = (unsigned int)((context->count[0] >> 3) & 0x3f);
  padLen = (index < 56) ? (56 - index) : (120 - index);
  MD5Update (context, PADDING, padLen);

  /* Append length (before padding) */
  MD5Update (context, bits, 8);

  /* Store state in digest */
  Encode (digest, context->state, 16);

  /* Zeroize sensitive information.
*/
  MD5_memset ((POINTER)context, 0, sizeof (*context));
}

/* MD5 basic transformation. Transforms state based on block.
 */
static void MD5Transform (state, block)
UINT4 state[4];
unsigned char block[64];
{
  UINT4 a = state[0], b = state[1], c = state[2], d = state[3], x[16];

  Decode (x, block, 64);

  /* Round 1 */
  FF (a, b, c, d, x[ 0], S11, 0xd76aa478); /* 1 */
  FF (d, a, b, c, x[ 1], S12, 0xe8c7b756); /* 2 */
  FF (c, d, a, b, x[ 2], S13, 0x242070db); /* 3 */
  FF (b, c, d, a, x[ 3], S14, 0xc1bdceee); /* 4 */
  FF (a, b, c, d, x[ 4], S11, 0xf57c0faf); /* 5 */
  FF (d, a, b, c, x[ 5], S12, 0x4787c62a); /* 6 */
  FF (c, d, a, b, x[ 6], S13, 0xa8304613); /* 7 */
  FF (b, c, d, a, x[ 7], S14, 0xfd469501); /* 8 */
  FF (a, b, c, d, x[ 8], S11, 0x698098d8); /* 9 */
  FF (d, a, b, c, x[ 9], S12, 0x8b44f7af); /* 10 */
  FF (c, d, a, b, x[10], S13, 0xffff5bb1); /* 11 */
  FF (b, c, d, a, x[11], S14, 0x895cd7be); /* 12 */
  FF (a, b, c, d, x[12], S11, 0x6b901122); /* 13 */
  FF (d, a, b, c, x[13], S12, 0xfd987193); /* 14 */
  FF (c, d, a, b, x[14], S13, 0xa679438e); /* 15 */
  FF (b, c, d, a, x[15], S14, 0x49b40821); /* 16 */

 /* Round 2 */
  GG (a, b, c, d, x[ 1], S21, 0xf61e2562); /* 17 */
  GG (d, a, b, c, x[ 6], S22, 0xc040b340); /* 18 */
  GG (c, d, a, b, x[11], S23, 0x265e5a51); /* 19 */
  GG (b, c, d, a, x[ 0], S24, 0xe9b6c7aa); /* 20 */
  GG (a, b, c, d, x[ 5], S21, 0xd62f105d); /* 21 */
  GG (d, a, b, c, x[10], S22,  0x2441453); /* 22 */
  GG (c, d, a, b, x[15], S23, 0xd8a1e681); /* 23 */
  GG (b, c, d, a, x[ 4], S24, 0xe7d3fbc8); /* 24 */
  GG (a, b, c, d, x[ 9], S21, 0x21e1cde6); /* 25 */
  GG (d, a, b, c, x[14], S22, 0xc33707d6); /* 26 */
  GG (c, d, a, b, x[ 3], S23, 0xf4d50d87); /* 27 */
  GG (b, c, d, a, x[ 8], S24, 0x455a14ed); /* 28 */
  GG (a, b, c, d, x[13], S21, 0xa9e3e905); /* 29 */
  GG (d, a, b, c, x[ 2], S22, 0xfcefa3f8); /* 30 */
  GG (c, d, a, b, x[ 7], S23, 0x676f02d9); /* 31 */
  GG (b, c, d, a, x[12], S24, 0x8d2a4c8a); /* 32 */

  /* Round 3 */
  HH (a, b, c, d, x[ 5], S31, 0xfffa3942); /* 33 */
  HH (d, a, b, c, x[ 8], S32, 0x8771f681); /* 34 */
  HH (c, d, a, b, x[11], S33, 0x6d9d6122); /* 35 */
  HH (b, c, d, a, x[14], S34, 0xfde5380c); /* 36 */
  HH (a, b, c, d, x[ 1], S31, 0xa4beea44); /* 37 */
  HH (d, a, b, c, x[ 4], S32, 0x4bdecfa9); /* 38 */
  HH (c, d, a, b, x[ 7], S33, 0xf6bb4b60); /* 39 */
  HH (b, c, d, a, x[10], S34, 0xbebfbc70); /* 40 */
  HH (a, b, c, d, x[13], S31, 0x289b7ec6); /* 41 */
  HH (d, a, b, c, x[ 0], S32, 0xeaa127fa); /* 42 */
  HH (c, d, a, b, x[ 3], S33, 0xd4ef3085); /* 43 */
  HH (b, c, d, a, x[ 6], S34,  0x4881d05); /* 44 */
  HH (a, b, c, d, x[ 9], S31, 0xd9d4d039); /* 45 */
  HH (d, a, b, c, x[12], S32, 0xe6db99e5); /* 46 */
  HH (c, d, a, b, x[15], S33, 0x1fa27cf8); /* 47 */
  HH (b, c, d, a, x[ 2], S34, 0xc4ac5665); /* 48 */

  /* Round 4 */
  II (a, b, c, d, x[ 0], S41, 0xf4292244); /* 49 */
  II (d, a, b, c, x[ 7], S42, 0x432aff97); /* 50 */
  II (c, d, a, b, x[14], S43, 0xab9423a7); /* 51 */
  II (b, c, d, a, x[ 5], S44, 0xfc93a039); /* 52 */
  II (a, b, c, d, x[12], S41, 0x655b59c3); /* 53 */
  II (d, a, b, c, x[ 3], S42, 0x8f0ccc92); /* 54 */
  II (c, d, a, b, x[10], S43, 0xffeff47d); /* 55 */
  II (b, c, d, a, x[ 1], S44, 0x85845dd1); /* 56 */
  II (a, b, c, d, x[ 8], S41, 0x6fa87e4f); /* 57 */
  II (d, a, b, c, x[15], S42, 0xfe2ce6e0); /* 58 */
  II (c, d, a, b, x[ 6], S43, 0xa3014314); /* 59 */
  II (b, c, d, a, x[13], S44, 0x4e0811a1); /* 60 */
  II (a, b, c, d, x[ 4], S41, 0xf7537e82); /* 61 */
  II (d, a, b, c, x[11], S42, 0xbd3af235); /* 62 */
  II (c, d, a, b, x[ 2], S43, 0x2ad7d2bb); /* 63 */
  II (b, c, d, a, x[ 9], S44, 0xeb86d391); /* 64 */

  state[0] += a;
  state[1] += b;
  state[2] += c;
  state[3] += d;

  /* Zeroize sensitive information.
   */
  MD5_memset ((POINTER)x, 0, sizeof (x));
}

/* Encodes input (UINT4) into output (unsigned char). Assumes len is
  a multiple of 4.
 */
static void Encode (output, input, len)
unsigned char *output;
UINT4 *input;
unsigned int len;
{
  unsigned int i, j;

  for (i = 0, j = 0; j < len; i++, j += 4) {
 output[j] = (unsigned char)(input[i] & 0xff);
 output[j+1] = (unsigned char)((input[i] >> 8) & 0xff);
 output[j+2] = (unsigned char)((input[i] >> 16) & 0xff);
 output[j+3] = (unsigned char)((input[i] >> 24) & 0xff);
  }
}

/* Decodes input (unsigned char) into output (UINT4). Assumes len is
  a multiple of 4.
 */
static void Decode (output, input, len)
UINT4 *output;
unsigned char *input;
unsigned int len;
{
  unsigned int i, j;

  for (i = 0, j = 0; j < len; i++, j += 4)
 output[i] = ((UINT4)input[j]) | (((UINT4)input[j+1]) << 8) |
   (((UINT4)input[j+2]) << 16) | (((UINT4)input[j+3]) << 24);
}

/* Note: Replace "for loop" with standard memcpy if possible.
 */

static void MD5_memcpy (output, input, len)
POINTER output;
POINTER input;
unsigned int len;
{
  unsigned int i;

  for (i = 0; i < len; i++)
    output[i] = input[i];
}

/* Note: Replace "for loop" with standard memset if possible.
 */
static void MD5_memset (output, value, len)
POINTER output;
int value;
unsigned int len;
{
  unsigned int i;

  for (i = 0; i < len; i++)
 ((char *)output)[i] = (char)value;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费三区一区二区| 欧美日韩在线播放一区| 色欧美片视频在线观看在线视频| 欧美在线视频全部完| 日韩视频一区在线观看| 亚洲日本乱码在线观看| 久久se精品一区二区| 91视视频在线直接观看在线看网页在线看| 欧美日韩一区二区在线视频| 国产欧美一区二区精品仙草咪| 亚洲成人激情综合网| 国产成人免费xxxxxxxx| 日韩一级片在线观看| 亚洲一级二级在线| 95精品视频在线| 久久综合久久鬼色中文字| 首页亚洲欧美制服丝腿| 在线亚洲免费视频| 国产精品免费久久久久| 国产麻豆精品视频| 欧美成人aa大片| 日韩中文字幕av电影| 欧美日韩中文字幕一区二区| 一区二区三区中文字幕在线观看| 国产98色在线|日韩| 久久久精品欧美丰满| 九九视频精品免费| 精品免费视频一区二区| 日本不卡一二三| 欧美一区二区三级| 蜜桃av噜噜一区| 日韩精品一区二区三区蜜臀| 天天色天天操综合| 在线综合+亚洲+欧美中文字幕| 亚洲成人免费电影| 制服丝袜日韩国产| 日韩成人午夜电影| 欧美xxxx在线观看| 国产一区日韩二区欧美三区| 欧美精品一区二区久久婷婷| 国产一区二区精品久久| 国产视频911| 99在线精品一区二区三区| 综合久久久久久| 欧美亚洲日本国产| 亚洲成人免费在线| 精品福利av导航| 盗摄精品av一区二区三区| 国产精品成人一区二区三区夜夜夜| 夫妻av一区二区| 亚洲精品v日韩精品| 欧美三级欧美一级| 久久99精品久久久久久久久久久久| 精品日韩欧美一区二区| 成人午夜在线播放| 一区二区三区在线免费观看| 欧美午夜一区二区三区| 蜜桃久久精品一区二区| 中文欧美字幕免费| 欧美在线免费观看亚洲| 久久99在线观看| 国产精品三级久久久久三级| 色噜噜狠狠色综合中国| 日本系列欧美系列| 国产区在线观看成人精品| 91视频.com| 久久爱www久久做| 国产精品久久三| 欧美性猛交xxxx黑人交| 精品一区二区三区视频| 综合亚洲深深色噜噜狠狠网站| 在线播放91灌醉迷j高跟美女| 美日韩一区二区| 亚洲天堂精品在线观看| 日韩天堂在线观看| 日本韩国一区二区三区| 韩国欧美国产1区| 亚洲精品亚洲人成人网| 精品美女一区二区| 在线视频观看一区| 国产麻豆精品久久一二三| 无吗不卡中文字幕| 国产精品国产自产拍高清av王其| 在线观看91精品国产麻豆| 成a人片国产精品| 久久精品国产精品亚洲红杏| 一卡二卡三卡日韩欧美| 国产精品色噜噜| 精品国产乱码久久久久久久久| 在线观看www91| 成人国产精品免费观看视频| 久久99精品国产麻豆婷婷| 亚洲一二三区在线观看| 中文字幕中文字幕中文字幕亚洲无线| 制服.丝袜.亚洲.另类.中文| 91高清视频在线| 99精品在线免费| 狠狠色丁香九九婷婷综合五月| 性久久久久久久久| 最新国产精品久久精品| 日本一区二区三级电影在线观看| 欧美久久久久久蜜桃| 91极品视觉盛宴| 91香蕉视频黄| 成人av电影在线网| 不卡一区二区三区四区| 99re热视频这里只精品| 国产伦精品一区二区三区免费| 日韩精品资源二区在线| 欧美日韩免费一区二区三区| 97精品视频在线观看自产线路二| 国产成人av自拍| 国产91综合一区在线观看| 精品一区二区三区av| 看电视剧不卡顿的网站| 毛片av一区二区| 激情五月激情综合网| 久久超级碰视频| 国产伦精品一区二区三区视频青涩 | 欧美激情一区二区三区| 日韩欧美成人一区二区| 欧美一级黄色片| 日韩一区二区免费在线电影 | 视频一区在线视频| 午夜精品久久久久久久久久久| 夜色激情一区二区| 亚洲一区二区三区四区的| 亚洲国产视频一区二区| 三级欧美韩日大片在线看| 日韩高清一级片| 激情五月播播久久久精品| 国产激情精品久久久第一区二区 | 亚洲国产另类精品专区| 亚洲国产精品一区二区久久恐怖片 | 最新日韩av在线| 亚洲第四色夜色| 蜜桃av一区二区三区电影| 国产一区二区三区高清播放| 成人小视频免费观看| 欧美又粗又大又爽| 欧美精品高清视频| 欧美videofree性高清杂交| 久久综合久久综合久久| 亚洲欧洲另类国产综合| 亚洲综合在线观看视频| 美腿丝袜一区二区三区| 成人精品亚洲人成在线| 欧美色窝79yyyycom| 日韩一区和二区| 国产精品久久福利| 亚洲va欧美va国产va天堂影院| 麻豆成人综合网| jlzzjlzz亚洲日本少妇| 欧美日韩成人综合在线一区二区| 日韩精品中午字幕| 成人免费的视频| 成人性生交大合| 激情偷乱视频一区二区三区| 极品少妇一区二区| 成年人午夜久久久| 日韩视频免费观看高清完整版在线观看 | 亚洲电影一级片| 国产一区999| 欧美日本一区二区在线观看| 国产日韩欧美激情| 日韩精品国产欧美| 99久久综合国产精品| 日韩一级精品视频在线观看| 国产精品午夜在线观看| 成人午夜激情片| 久久亚洲欧美国产精品乐播| 日韩精品一区二区三区老鸭窝 | 国产一区91精品张津瑜| 色94色欧美sute亚洲线路二| 欧美一区二区啪啪| 亚洲精品日韩一| 成人一区二区三区视频| 欧美一区二区福利在线| 亚洲麻豆国产自偷在线| 国产成人精品综合在线观看| 欧美精品免费视频| 亚洲精品视频观看| 成人综合婷婷国产精品久久蜜臀| 日韩一区二区三区免费看| 夜夜爽夜夜爽精品视频| 成年人网站91| 国产精品三级久久久久三级| 国产一区三区三区| www精品美女久久久tv| 日本aⅴ精品一区二区三区| 欧美探花视频资源| 一区二区三区在线观看欧美| www.色综合.com| 中文在线免费一区三区高中清不卡| 久久er精品视频| 日韩精品中午字幕| 精品无人区卡一卡二卡三乱码免费卡| 精品婷婷伊人一区三区三| 亚洲欧美日韩一区| 色噜噜偷拍精品综合在线|