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

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

?? md5.cpp

?? 配套《網絡通信編程實用案例精選》源代碼。
?? CPP
字號:
/* 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 "stdafx.h"
#include "glob-md5.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 (UINT4 state[4], unsigned char block[64]);
static void Encode (unsigned char *output, UINT4 *input, unsigned int len);
static void Decode (UINT4 *output, unsigned char *input, unsigned int len);
static void MD5_memcpy (POINTER output, POINTER input, unsigned int len);
static void MD5_memset (POINTER output, int value, unsigned int len);

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 (MD5_CTX *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 (MD5_CTX *context, unsigned char *input, unsigned int inputLen)
{
  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 (unsigned char digest[16], MD5_CTX *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 (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 (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 (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 (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 (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一区二区三区免费野_久草精品视频
欧美美女直播网站| 亚洲人精品午夜| 日本一区二区成人| 国产91对白在线观看九色| 99这里都是精品| 欧美大片日本大片免费观看| 亚洲男人的天堂在线观看| 蜜臀av一区二区| 91久久精品一区二区| 中文字幕va一区二区三区| 久久精品国产色蜜蜜麻豆| 欧美另类高清zo欧美| 亚洲乱码日产精品bd| 国产v综合v亚洲欧| 久久亚洲免费视频| 免费在线观看一区| 91精品国产综合久久久蜜臀粉嫩| 中文字幕色av一区二区三区| 狠狠狠色丁香婷婷综合激情 | 爽好多水快深点欧美视频| 成人综合在线网站| 久久一日本道色综合| 免费人成网站在线观看欧美高清| 在线观看视频一区| 一区二区三区在线观看国产| 99视频超级精品| 国产精品欧美极品| 成人黄色电影在线| 国产精品免费观看视频| av在线不卡观看免费观看| 国产精品私人影院| zzijzzij亚洲日本少妇熟睡| 亚洲精品在线电影| 国产乱码精品一品二品| 久久免费美女视频| 成人av影院在线| 国产精品卡一卡二| 色婷婷久久久综合中文字幕| 最新日韩av在线| 色就色 综合激情| 亚洲成人综合网站| 日韩女优电影在线观看| 国产一区不卡在线| 成人免费在线视频观看| 欧美在线一二三四区| 亚洲一区二区五区| 制服丝袜在线91| 精品一区二区三区av| 久久精品亚洲乱码伦伦中文 | 国产人成亚洲第一网站在线播放| 丰满亚洲少妇av| 亚洲精品国产精品乱码不99| 欧美性淫爽ww久久久久无| 亚洲h动漫在线| 精品久久人人做人人爰| 成人高清在线视频| 亚洲国产日韩一级| 2021中文字幕一区亚洲| 99热精品一区二区| 五月天婷婷综合| 国产午夜一区二区三区| 日本福利一区二区| 麻豆久久一区二区| 国产精品夫妻自拍| 制服丝袜亚洲网站| www.欧美亚洲| 日本成人中文字幕在线视频| 国产免费久久精品| 欧美精品在线观看播放| 国产精品乡下勾搭老头1| 一区二区三区四区亚洲| 精品人在线二区三区| 一本久久a久久精品亚洲| 日韩av在线发布| 18成人在线观看| 精品久久人人做人人爱| 欧美午夜寂寞影院| 国产91精品免费| 欧美aaaaa成人免费观看视频| 国产精品成人午夜| 2022国产精品视频| 91精品国产一区二区| 91麻豆精品秘密| 国产酒店精品激情| 秋霞电影网一区二区| 亚洲色图欧洲色图婷婷| 久久久久久97三级| 欧美一区二区精品在线| 色老头久久综合| 成人小视频免费观看| 六月丁香婷婷久久| 午夜欧美大尺度福利影院在线看| 国产免费成人在线视频| 精品国产1区二区| 91精品久久久久久久久99蜜臂| 91久久香蕉国产日韩欧美9色| 丁香婷婷综合五月| 国产久卡久卡久卡久卡视频精品| 美女国产一区二区三区| 亚洲成av人片一区二区梦乃| 亚洲激情欧美激情| 亚洲免费大片在线观看| 国产精品国产三级国产aⅴ无密码| 久久一区二区三区四区| 精品999在线播放| 欧美一卡在线观看| 欧美一级免费大片| 欧美va亚洲va在线观看蝴蝶网| 91精品国产一区二区人妖| 欧美日韩不卡一区| 欧美四级电影网| 欧美人狂配大交3d怪物一区| 欧美日韩亚洲综合一区二区三区| 日本韩国精品一区二区在线观看| 91免费国产视频网站| 91一区二区在线| 91成人免费在线视频| 91成人免费在线| 欧美片在线播放| 777午夜精品视频在线播放| 91麻豆精品国产91久久久久| 欧美丰满少妇xxxxx高潮对白| 欧美三级电影在线看| 欧美一区二区三区爱爱| 久久一区二区视频| 国产精品福利一区| 亚洲高清免费观看高清完整版在线观看| 有码一区二区三区| 午夜精品久久久| 精品一区二区免费看| 丁香亚洲综合激情啪啪综合| 91啪在线观看| 欧美日韩国产色站一区二区三区| 91精品国产综合久久久久| 精品久久久久久久一区二区蜜臀| 久久噜噜亚洲综合| 中文字幕日韩一区| 日韩电影免费在线| 国产一区二区三区日韩 | 国产精品福利影院| 一区二区在线免费| 日本不卡中文字幕| 成人短视频下载| 欧美四级电影网| 久久精品视频在线免费观看| 亚洲视频一区二区在线观看| 午夜影院久久久| 国产黄色91视频| 欧美日韩精品一区视频| 国产无遮挡一区二区三区毛片日本| 17c精品麻豆一区二区免费| 性做久久久久久免费观看| 国产精品一级黄| 在线观看一区二区视频| 欧美精品一区二区在线观看| 亚洲精品国产一区二区三区四区在线| 蜜桃精品视频在线| 91蜜桃在线免费视频| 精品国产sm最大网站| 亚洲国产成人tv| 国产一区二区免费视频| 欧美三级在线播放| 国产精品毛片a∨一区二区三区| 日韩影院在线观看| 91视频在线观看| 26uuu欧美| 亚洲成在线观看| 91免费在线播放| 国产嫩草影院久久久久| 开心九九激情九九欧美日韩精美视频电影| 不卡在线视频中文字幕| 精品国产一区a| 亚洲bt欧美bt精品777| 99re成人在线| 国产欧美精品一区二区色综合朱莉 | 成人免费三级在线| 精品国产不卡一区二区三区| 午夜在线成人av| 日本高清免费不卡视频| 中文字幕日本不卡| 国产不卡高清在线观看视频| 日韩一区二区免费视频| 亚洲午夜电影在线| 色婷婷国产精品综合在线观看| 国产日韩精品久久久| 精品一区二区精品| 26uuu精品一区二区在线观看| 日本不卡一二三区黄网| 777a∨成人精品桃花网| 亚洲午夜一二三区视频| 色天使色偷偷av一区二区| 亚洲欧美怡红院| 99久久久国产精品| 中文字幕日韩精品一区 | 欧美精品自拍偷拍| 亚洲国产另类精品专区| 在线视频一区二区三区| 亚洲精品免费视频| 色94色欧美sute亚洲线路一久| 亚洲色图在线看|