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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? md5.cpp

?? VC++網(wǎng)絡(luò)通信編程實(shí)例案例精選》源代碼 第三部分
?? CPP
字號(hào):
/* 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;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久国产精品麻豆ai换脸 | 成人黄色av网站在线| 亚洲欧洲精品成人久久奇米网| 欧美艳星brazzers| 国产成人精品影视| 首页国产欧美久久| 亚洲天堂成人网| 国产日韩亚洲欧美综合| 91精品国产麻豆国产自产在线 | 国产午夜亚洲精品理论片色戒| 欧美日韩一区不卡| 99精品视频在线观看| 美女精品自拍一二三四| 亚洲美女屁股眼交| 中文av一区特黄| www国产精品av| 欧美日韩aaaaaa| 色婷婷久久久久swag精品| 国产成人精品午夜视频免费| 麻豆成人av在线| 亚洲gay无套男同| 一区二区在线观看视频 | 国产精品久久久99| 久久免费午夜影院| 日韩欧美在线网站| 5858s免费视频成人| 欧美亚洲精品一区| 欧美中文字幕亚洲一区二区va在线 | 久久综合久久鬼色| 欧美一级二级三级乱码| 欧美年轻男男videosbes| 欧洲av在线精品| 色美美综合视频| 91污片在线观看| 91原创在线视频| 91一区在线观看| 91毛片在线观看| 色狠狠av一区二区三区| 99riav久久精品riav| 成人免费黄色大片| av网站免费线看精品| av不卡一区二区三区| k8久久久一区二区三区| 99久久久免费精品国产一区二区 | 91视频在线看| 91免费在线看| 欧美视频一区二区| 91精品国产乱| 精品国产91洋老外米糕| 久久久蜜臀国产一区二区| 久久精品无码一区二区三区| 日本一二三不卡| 成人欧美一区二区三区视频网页| 亚洲日本欧美天堂| 亚洲福利国产精品| 捆绑紧缚一区二区三区视频 | 欧美少妇一区二区| 欧美精品一二三| 精品奇米国产一区二区三区| 久久久777精品电影网影网| 国产亚洲欧洲997久久综合| 中文字幕不卡在线播放| 亚洲精品高清在线| 免播放器亚洲一区| 福利一区福利二区| 91极品美女在线| 日韩欧美一级片| 中文字幕欧美一| 偷偷要91色婷婷| 国产真实精品久久二三区| 成人国产精品免费观看视频| 91久久一区二区| 欧美大胆一级视频| 国产精品卡一卡二| 视频一区免费在线观看| 国产乱码精品一区二区三区av| 91丨九色丨尤物| 精品久久99ma| 亚洲精品免费在线| 激情丁香综合五月| 色婷婷av久久久久久久| 日韩欧美国产三级| 亚洲精品写真福利| 国产一区二区精品久久| 99久久精品国产观看| 4438x亚洲最大成人网| 国产欧美1区2区3区| 亚洲超碰97人人做人人爱| 国产精品自在在线| 欧美日韩一级黄| 国产精品美女久久久久高潮| 秋霞电影网一区二区| 99精品欧美一区二区蜜桃免费| 91精品国产高清一区二区三区| 欧美国产欧美综合| 久久黄色级2电影| 色激情天天射综合网| 国产欧美日韩综合精品一区二区| 亚洲国产欧美在线| 9色porny自拍视频一区二区| 日韩欧美国产麻豆| 午夜久久电影网| 一本在线高清不卡dvd| 久久这里都是精品| 日韩精品免费视频人成| 色综合久久综合中文综合网| 国产日韩精品一区二区浪潮av| 亚洲国产成人91porn| 不卡的电影网站| 国产亚洲成aⅴ人片在线观看| 日产欧产美韩系列久久99| 色欲综合视频天天天| 国产精品视频一区二区三区不卡| 免费日本视频一区| 欧美日韩在线一区二区| 亚洲欧美日韩电影| caoporn国产一区二区| 久久亚洲精品国产精品紫薇| 日本美女视频一区二区| 欧美日韩国产一级| 一区二区理论电影在线观看| 99久久99久久免费精品蜜臀| 国产婷婷精品av在线| 国产一区二区中文字幕| 日韩精品在线看片z| 日韩精品电影一区亚洲| 欧美精品视频www在线观看| 一区二区三区免费| 色天天综合色天天久久| 亚洲三级在线免费观看| 99视频一区二区| 国产精品高潮呻吟| 盗摄精品av一区二区三区| 久久久综合精品| 成人精品视频网站| 国产精品色呦呦| 99久久国产免费看| 亚洲精品成人悠悠色影视| 91福利精品视频| 午夜激情一区二区| 欧美一二三四区在线| 蜜桃视频第一区免费观看| 日韩欧美国产不卡| 久久99九九99精品| 精品国产乱码久久久久久图片| 精品一区二区三区免费毛片爱| 2021中文字幕一区亚洲| 国产精品系列在线观看| 中文字幕高清不卡| 99视频在线观看一区三区| 一二三四社区欧美黄| 91精品黄色片免费大全| 免费成人在线播放| 国产色产综合色产在线视频| 成人av电影在线播放| 亚洲午夜在线视频| 制服丝袜av成人在线看| 国产专区综合网| 中文字幕精品—区二区四季| 色婷婷久久一区二区三区麻豆| 日韩电影一区二区三区四区| 精品国产一区二区三区不卡 | 99久久婷婷国产| 午夜一区二区三区视频| 日韩免费一区二区三区在线播放| 国产精品中文字幕一区二区三区| 国产精品久久久久久久久久免费看 | 国产综合久久久久久鬼色| 国产精品午夜电影| 在线观看av一区二区| 久久精品噜噜噜成人88aⅴ| 国产免费成人在线视频| 在线一区二区视频| 久久国产精品99精品国产| 国产精品欧美久久久久无广告 | 亚洲一区二区欧美日韩| 日韩久久久久久| 91欧美一区二区| 美脚の诱脚舐め脚责91| 国产精品久久久久aaaa| 91精品国产色综合久久不卡电影| 国产成人a级片| 亚洲国产视频网站| 国产日产欧产精品推荐色| 欧美在线你懂的| 国产激情一区二区三区四区| 亚洲国产裸拍裸体视频在线观看乱了 | 精品无人码麻豆乱码1区2区| 中文字幕日本乱码精品影院| 日韩写真欧美这视频| 91亚洲精品久久久蜜桃网站| 免费在线成人网| 亚洲精品国产高清久久伦理二区| 久久先锋影音av| 欧美二区三区的天堂| 不卡在线视频中文字幕| 久久精品999| 亚洲一区在线观看视频| 中文字幕一区在线观看| 精品乱人伦小说|