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

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

?? leapmd4.c

?? 可以用作很多客戶端的XSUPPLICANT的源代碼。比如用在802.1x或者無線AP上
?? C
字號:
/* Copyright (C) 1990-2, RSA Data Security, Inc. All rights reserved.   License to copy and use this software is granted provided that it   is identified as the "RSA Data Security, Inc. MD4 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. MD4 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 "leapmd4.h"/* Constants for MD4Transform routine. */#define S11 3#define S12 7#define S13 11#define S14 19#define S21 3#define S22 5#define S23 9#define S24 13#define S31 3#define S32 9#define S33 11#define S34 15static void MD4Transform 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 MD4_memcpy PROTO_LIST ((POINTER, POINTER, unsigned int));static void MD4_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 and H are basic MD4 functions. */#define F(x, y, z) (((x) & (y)) | ((~x) & (z)))#define G(x, y, z) (((x) & (y)) | ((x) & (z)) | ((y) & (z)))#define H(x, y, z) ((x) ^ (y) ^ (z))/* ROTATE_LEFT rotates x left n bits. */#define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n))))/* FF, GG and HH are transformations for rounds 1, 2 and 3 *//* Rotation is separate from addition to prevent recomputation */#define FF(a, b, c, d, x, s) { \    (a) += F ((b), (c), (d)) + (x); \    (a) = ROTATE_LEFT ((a), (s)); \  }#define GG(a, b, c, d, x, s) { \    (a) += G ((b), (c), (d)) + (x) + (UINT4)0x5a827999; \    (a) = ROTATE_LEFT ((a), (s)); \  }#define HH(a, b, c, d, x, s) { \    (a) += H ((b), (c), (d)) + (x) + (UINT4)0x6ed9eba1; \    (a) = ROTATE_LEFT ((a), (s)); \  }void md4_calc(output, input, inlen)unsigned char *output;unsigned char *input;                                /* input block */unsigned int inlen;                     /* length of input block */{	MD4_CTX_	context;	MD4Init(&context);	MD4Update(&context, input, inlen);	MD4Final(output, &context);}/* MD4 initialization. Begins an MD4 operation, writing a new context. */void MD4Init (context)MD4_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;}/* MD4 block update operation. Continues an MD4 message-digest     operation, processing another message block, and updating the     context. */void MD4Update (context, input, inputLen)MD4_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) {    MD4_memcpy      ((POINTER)&context->buffer[index], (POINTER)input, partLen);    MD4Transform (context->state, context->buffer);    for (i = partLen; i + 63 < inputLen; i += 64)      MD4Transform (context->state, &input[i]);    index = 0;  }  else    i = 0;  /* Buffer remaining input */  MD4_memcpy    ((POINTER)&context->buffer[index], (POINTER)&input[i],     inputLen-i);}/* MD4 finalization. Ends an MD4 message-digest operation, writing the     the message digest and zeroizing the context. */void MD4Final (digest, context)unsigned char digest[16];                         /* message digest */MD4_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);  MD4Update (context, PADDING, padLen);  /* Append length (before padding) */  MD4Update (context, bits, 8);  /* Store state in digest */  Encode (digest, context->state, 16);  /* Zeroize sensitive information.   */  MD4_memset ((POINTER)context, 0, sizeof (*context));}/* MD4 basic transformation. Transforms state based on block. */static void MD4Transform (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); /* 1 */  FF (d, a, b, c, x[ 1], S12); /* 2 */  FF (c, d, a, b, x[ 2], S13); /* 3 */  FF (b, c, d, a, x[ 3], S14); /* 4 */  FF (a, b, c, d, x[ 4], S11); /* 5 */  FF (d, a, b, c, x[ 5], S12); /* 6 */  FF (c, d, a, b, x[ 6], S13); /* 7 */  FF (b, c, d, a, x[ 7], S14); /* 8 */  FF (a, b, c, d, x[ 8], S11); /* 9 */  FF (d, a, b, c, x[ 9], S12); /* 10 */  FF (c, d, a, b, x[10], S13); /* 11 */  FF (b, c, d, a, x[11], S14); /* 12 */  FF (a, b, c, d, x[12], S11); /* 13 */  FF (d, a, b, c, x[13], S12); /* 14 */  FF (c, d, a, b, x[14], S13); /* 15 */  FF (b, c, d, a, x[15], S14); /* 16 */  /* Round 2 */  GG (a, b, c, d, x[ 0], S21); /* 17 */  GG (d, a, b, c, x[ 4], S22); /* 18 */  GG (c, d, a, b, x[ 8], S23); /* 19 */  GG (b, c, d, a, x[12], S24); /* 20 */  GG (a, b, c, d, x[ 1], S21); /* 21 */  GG (d, a, b, c, x[ 5], S22); /* 22 */  GG (c, d, a, b, x[ 9], S23); /* 23 */  GG (b, c, d, a, x[13], S24); /* 24 */  GG (a, b, c, d, x[ 2], S21); /* 25 */  GG (d, a, b, c, x[ 6], S22); /* 26 */  GG (c, d, a, b, x[10], S23); /* 27 */  GG (b, c, d, a, x[14], S24); /* 28 */  GG (a, b, c, d, x[ 3], S21); /* 29 */  GG (d, a, b, c, x[ 7], S22); /* 30 */  GG (c, d, a, b, x[11], S23); /* 31 */  GG (b, c, d, a, x[15], S24); /* 32 */  /* Round 3 */  HH (a, b, c, d, x[ 0], S31); /* 33 */  HH (d, a, b, c, x[ 8], S32); /* 34 */  HH (c, d, a, b, x[ 4], S33); /* 35 */  HH (b, c, d, a, x[12], S34); /* 36 */  HH (a, b, c, d, x[ 2], S31); /* 37 */  HH (d, a, b, c, x[10], S32); /* 38 */  HH (c, d, a, b, x[ 6], S33); /* 39 */  HH (b, c, d, a, x[14], S34); /* 40 */  HH (a, b, c, d, x[ 1], S31); /* 41 */  HH (d, a, b, c, x[ 9], S32); /* 42 */  HH (c, d, a, b, x[ 5], S33); /* 43 */  HH (b, c, d, a, x[13], S34); /* 44 */  HH (a, b, c, d, x[ 3], S31); /* 45 */  HH (d, a, b, c, x[11], S32); /* 46 */  HH (c, d, a, b, x[ 7], S33); /* 47 */  HH (b, c, d, a, x[15], S34); /* 48 */  state[0] += a;  state[1] += b;  state[2] += c;  state[3] += d;  /* Zeroize sensitive information.   */  MD4_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 MD4_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 MD4_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一区二区三区免费野_久草精品视频
欧美日精品一区视频| 国产精品家庭影院| 国产精品电影一区二区| 一区二区三区中文字幕电影| 奇米四色…亚洲| 一本久久a久久免费精品不卡| 日韩一级免费观看| 亚洲欧美另类小说视频| 精东粉嫩av免费一区二区三区| 欧日韩精品视频| 国产精品福利影院| 久久99蜜桃精品| 欧美色图天堂网| 中文字幕一区二区三区四区不卡| 精品影院一区二区久久久| 欧美色男人天堂| 亚洲三级在线免费观看| 粉嫩aⅴ一区二区三区四区五区| 欧美一区二区三级| 亚洲国产综合色| 色综合中文字幕国产 | 午夜亚洲国产au精品一区二区| 国产不卡高清在线观看视频| 日韩美女视频一区二区在线观看| 亚洲v中文字幕| 欧美性视频一区二区三区| 亚洲欧美视频一区| www.亚洲人| 国产精品麻豆一区二区| 成人听书哪个软件好| 久久毛片高清国产| 国产乱子伦视频一区二区三区| 精品国产一区二区三区忘忧草| 男男视频亚洲欧美| 91精品国产欧美一区二区18| 日本伊人精品一区二区三区观看方式| 欧美色老头old∨ideo| 性感美女久久精品| 欧美片网站yy| 琪琪一区二区三区| 337p粉嫩大胆色噜噜噜噜亚洲| 久久av老司机精品网站导航| 久久亚洲一区二区三区明星换脸| 韩国v欧美v日本v亚洲v| 日本一区二区三区高清不卡 | 精品国产乱码久久久久久影片| 美女在线一区二区| 欧美精品一区二区精品网| 国产精品一区免费在线观看| 国产欧美精品区一区二区三区 | 免费成人深夜小野草| 欧美一二三四在线| 国产一区二区主播在线| 国产精品欧美综合在线| 色综合咪咪久久| 亚洲综合999| 日韩一区二区三区电影在线观看| 激情另类小说区图片区视频区| 久久久777精品电影网影网| 国产成人免费在线观看不卡| 亚洲人成精品久久久久久| 欧美精品乱码久久久久久| 激情六月婷婷久久| 亚洲人成7777| 日韩精品中文字幕在线一区| 国产高清在线精品| 伊人色综合久久天天人手人婷| 538prom精品视频线放| 国产成人午夜99999| 一区二区在线观看不卡| 日韩欧美亚洲另类制服综合在线| 国产成人在线观看免费网站| 亚洲综合一二区| 久久久综合视频| 欧美这里有精品| 国产原创一区二区| 亚洲精品乱码久久久久久久久 | 国产在线不卡一区| 亚洲女性喷水在线观看一区| 日韩精品在线看片z| 91原创在线视频| 久99久精品视频免费观看| 亚洲色图制服诱惑| 欧美成va人片在线观看| 日本韩国欧美在线| 大美女一区二区三区| 污片在线观看一区二区| 中文字幕一区二区三区四区| 精品久久久久一区二区国产| 欧美性感一类影片在线播放| 国产一区二区三区久久久| 午夜精品在线看| 亚洲欧洲中文日韩久久av乱码| 久久亚洲精品小早川怜子| 欧美日韩精品电影| 91黄色免费版| 99久久精品一区二区| 国产精品99久| 国产综合久久久久久久久久久久| 日韩制服丝袜av| 一区二区不卡在线播放| 亚洲欧美在线高清| 中文字幕亚洲成人| 欧美国产一区二区| 久久精品日产第一区二区三区高清版| 日韩三级中文字幕| 欧美一级黄色片| 91精品国产一区二区三区| 在线观看欧美精品| 在线观看免费视频综合| 色先锋资源久久综合| 99久久国产免费看| www.欧美色图| 99久久精品免费精品国产| 成人av电影免费观看| 成人国产一区二区三区精品| 国产成人自拍网| 成人一二三区视频| 成人avav影音| 91麻豆产精品久久久久久| 不卡一区二区三区四区| 99精品欧美一区二区蜜桃免费 | 欧美理论电影在线| 欧美日韩精品高清| 91精品国产91综合久久蜜臀| 69久久夜色精品国产69蝌蚪网| 777午夜精品视频在线播放| 制服丝袜在线91| 日韩久久久精品| 国产日本欧洲亚洲| 综合久久综合久久| 亚洲一区二区欧美| 日韩中文字幕91| 国产一区二区精品久久| av中文字幕不卡| 欧美性一级生活| 精品久久久久香蕉网| 中文字幕av免费专区久久| 一区二区三区在线观看动漫| 亚洲成人综合网站| 精品一区二区三区久久| 国产乱子伦视频一区二区三区| 99精品视频一区| 欧美精品 国产精品| 久久综合久久综合九色| 中文字幕在线不卡一区| 日韩—二三区免费观看av| 国产精品综合久久| 色哟哟一区二区三区| 欧美一级高清片| 国产精品久久久久天堂| 丝袜美腿亚洲色图| 国产一区二区三区在线观看精品 | 亚洲色图制服诱惑| 日本中文在线一区| 波多野结衣亚洲| 欧美一级在线视频| 国产精品久久久久永久免费观看 | 亚洲一区在线观看网站| 九九**精品视频免费播放| 91亚洲精品一区二区乱码| 欧美一区二区三区系列电影| 亚洲欧洲性图库| 久久福利资源站| 欧美视频一区二区三区| 久久你懂得1024| 日韩成人一级大片| av在线这里只有精品| 精品国产乱码久久久久久浪潮 | 国产精品网站导航| 日韩黄色小视频| 欧洲精品中文字幕| 欧美国产精品劲爆| 九色|91porny| 欧美一区二区三区视频在线| 亚洲欧美国产77777| 国产精品亚洲专一区二区三区| 欧美日本在线观看| 亚洲欧美日韩一区二区 | 久久精品国产99国产| 在线观看区一区二| 亚洲欧美韩国综合色| 大陆成人av片| 国产欧美日本一区视频| 麻豆成人久久精品二区三区红| 欧美日韩在线三级| 一区二区欧美视频| 91久久精品一区二区三区| 中文欧美字幕免费| 国产电影精品久久禁18| 久久综合九色综合97婷婷| 蜜臀av性久久久久蜜臀av麻豆| 欧美日韩大陆一区二区| 亚洲不卡一区二区三区| 欧美日韩在线播放三区四区| 亚洲与欧洲av电影| 欧美性猛交xxxx黑人交| 亚洲尤物在线视频观看| 欧美日韩高清影院| 日韩电影在线观看电影|