青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

網絡軟件開發

網絡軟件開發,vc ++ 、linux 、asp、sql server 2000 android、iOS

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  5 隨筆 :: 1 文章 :: 45 評論 :: 0 Trackbacks

.h文件

/******************************************************************************
 *  Copyright (C) 2000 by Robert Hubley.                                      *
 *  All rights reserved.                                                      *
 *                                                                            *
 *  This software is provided ``AS IS'' and any express or implied            *
 *  warranties, including, but not limited to, the implied warranties of      *
 *  merchantability and fitness for a particular purpose, are disclaimed.     *
 *  In no event shall the authors be liable for any direct, indirect,         *
 *  incidental, special, exemplary, or consequential damages (including, but  *
 *  not limited to, procurement of substitute goods or services; loss of use, *
 *  data, or profits; or business interruption) however caused and on any     *
 *  theory of liability, whether in contract, strict liability, or tort       *
 *  (including negligence or otherwise) arising in any way out of the use of  *
 *  this software, even if advised of the possibility of such damage.         *
 *                                                                            *
 ******************************************************************************

 MD5.H - header file for MD5C.C
 
   Port to Win32 DLL by Robert Hubley 1/5/2000

   Original Copyright:

  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.
*/
/******************************************************************************
 *  Copyright (C) 2000 by Robert Hubley.                                      *
 *  All rights reserved.                                                      *
 *                                                                            *
 *  This software is provided ``AS IS'' and any express or implied            *
 *  warranties, including, but not limited to, the implied warranties of      *
 *  merchantability and fitness for a particular purpose, are disclaimed.     *
 *  In no event shall the authors be liable for any direct, indirect,         *
 *  incidental, special, exemplary, or consequential damages (including, but  *
 *  not limited to, procurement of substitute goods or services; loss of use, *
 *  data, or profits; or business interruption) however caused and on any     *
 *  theory of liability, whether in contract, strict liability, or tort       *
 *  (including negligence or otherwise) arising in any way out of the use of  *
 *  this software, even if advised of the possibility of such damage.         *
 *                                                                            *
 ******************************************************************************
*/

/******************************************************************************
 *   2002-4-18 Modified by Liguangyi.               *
 *   struct MD5_CTX ==> class MD5_CTX.                  *
 *   Take off the Globals Functions                                           *
 ******************************************************************************
*/

#ifndef _LGY_MD5_H
#define _LGY_MD5_H

/* MD5 Class. */
class MD5_CTX {
public:
 MD5_CTX();
 virtual ~MD5_CTX();
 void MD5Update ( unsigned char *input, unsigned int inputLen);
 void MD5Final (unsigned char digest[16]);

private:
 unsigned long int state[4];     /* state (ABCD) */
 unsigned long int count[2];     /* number of bits, modulo 2^64 (lsb first) */
 unsigned char buffer[64];       /* input buffer */
 unsigned char PADDING[64];  /* What? */

private:
 void MD5Init ();
 void MD5Transform (unsigned long int state[4], unsigned char block[64]);
 void MD5_memcpy (unsigned char* output, unsigned char* input,unsigned int len);
 void Encode (unsigned char *output, unsigned long int *input,unsigned int len);
 void Decode (unsigned long int *output, unsigned char *input, unsigned int len);
 void MD5_memset (unsigned char* output,int value,unsigned int len);
};

#endif

 

 

 

.cpp文件


/******************************************************************************
*  Copyright (C) 2000 by Robert Hubley.                                      *
*  All rights reserved.                                                      *
*                                                                            *
*  This software is provided ``AS IS'' and any express or implied            *
*  warranties, including, but not limited to, the implied warranties of      *
*  merchantability and fitness for a particular purpose, are disclaimed.     *
*  In no event shall the authors be liable for any direct, indirect,         *
*  incidental, special, exemplary, or consequential damages (including, but  *
*  not limited to, procurement of substitute goods or services; loss of use, *
*  data, or profits; or business interruption) however caused and on any     *
*  theory of liability, whether in contract, strict liability, or tort       *
*  (including negligence or otherwise) arising in any way out of the use of  *
*  this software, even if advised of the possibility of such damage.         *
*                                                                            *
******************************************************************************

 MD5C.C - RSA Data Security, Inc., MD5 message-digest algorithm

 Port to Win32 DLL by Robert Hubley 1/5/2000

 Original Copyright:

 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 "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

/* 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) + (unsigned long int)(ac); \
 (a) = ROTATE_LEFT ((a), (s)); \
 (a) += (b); \
 }
#define GG(a, b, c, d, x, s, ac) { \
 (a) += G ((b), (c), (d)) + (x) + (unsigned long int)(ac); \
 (a) = ROTATE_LEFT ((a), (s)); \
 (a) += (b); \
 }
#define HH(a, b, c, d, x, s, ac) { \
 (a) += H ((b), (c), (d)) + (x) + (unsigned long int)(ac); \
 (a) = ROTATE_LEFT ((a), (s)); \
 (a) += (b); \
 }
#define II(a, b, c, d, x, s, ac) { \
 (a) += I ((b), (c), (d)) + (x) + (unsigned long int)(ac); \
 (a) = ROTATE_LEFT ((a), (s)); \
 (a) += (b); \
 }


/* MD5 initialization. Begins an MD5 operation, writing a new context.
*/

MD5_CTX::MD5_CTX()
{
 MD5Init ();
}

MD5_CTX::~MD5_CTX()
{
}

void MD5_CTX::MD5Init ()
{
 this->count[0] = this->count[1] = 0;
 /* Load magic initialization constants.*/
 this->state[0] = 0x67452301;
 this->state[1] = 0xefcdab89;
 this->state[2] = 0x98badcfe;
 this->state[3] = 0x10325476;
 /* Add by Liguangyi */
 MD5_memset(PADDING, 0, sizeof(PADDING));
 *PADDING=0x80;
 //PADDING = {
 // 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 };
}

/* MD5 block update operation. Continues an MD5 message-digest
operation, processing another message block, and updating the
context.
*/
void MD5_CTX::MD5Update (unsigned char *input,unsigned int inputLen)
{
 unsigned int i, index, partLen;
 
 /* Compute number of bytes mod 64 */
 index = (unsigned int)((this->count[0] >> 3) & 0x3F);
 
 /* Update number of bits */
 if ((this->count[0] += ((unsigned long int)inputLen << 3))
  < ((unsigned long int)inputLen << 3))
  this->count[1]++;
 this->count[1] += ((unsigned long int)inputLen >> 29);
 
 partLen = 64 - index;
 
 /* Transform as many times as possible.
 */
 if (inputLen >= partLen) {
  MD5_memcpy((unsigned char*)&this->buffer[index],
   (unsigned char*)input, partLen);
  MD5Transform (this->state, this->buffer);
  
  for (i = partLen; i + 63 < inputLen; i += 64)
   MD5Transform (this->state, &input[i]);
  
  index = 0;
 }
 else
  i = 0;
 
 /* Buffer remaining input */
 MD5_memcpy ((unsigned char*)&this->buffer[index], (unsigned char*)&input[i], inputLen-i);
}

/* MD5 finalization. Ends an MD5 message-digest operation, writing the
the message digest and zeroizing the context.
*/
void MD5_CTX::MD5Final (unsigned char digest[16])
{
 unsigned char bits[8];
 unsigned int index, padLen;
 
 /* Save number of bits */
 Encode (bits, this->count, 8);
 
 /* Pad out to 56 mod 64.
 */
 index = (unsigned int)((this->count[0] >> 3) & 0x3f);
 padLen = (index < 56) ? (56 - index) : (120 - index);
 MD5Update ( PADDING, padLen);
 
 /* Append length (before padding) */
 MD5Update (bits, 8);
 /* Store state in digest */
 Encode (digest, this->state, 16);
 
 /* Zeroize sensitive information.
 */
 MD5_memset ((unsigned char*)this, 0, sizeof (*this));
 this->MD5Init();
}

/* MD5 basic transformation. Transforms state based on block.
*/
void MD5_CTX::MD5Transform (unsigned long int state[4], unsigned char block[64])
{
 unsigned long int 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 ((unsigned char*)x, 0, sizeof (x));
}

/* Encodes input (unsigned long int) into output (unsigned char). Assumes len is
a multiple of 4.
*/
void MD5_CTX::Encode (unsigned char *output, unsigned long int *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 (unsigned long int). Assumes len is
a multiple of 4.
*/
void MD5_CTX::Decode (unsigned long int *output, unsigned char *input, unsigned int len)
{
 unsigned int i, j;
 
 for (i = 0, j = 0; j < len; i++, j += 4)
  output[i] = ((unsigned long int)input[j]) | (((unsigned long int)input[j+1]) << 8) |
  (((unsigned long int)input[j+2]) << 16) | (((unsigned long int)input[j+3]) << 24);
}

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

void MD5_CTX::MD5_memcpy (unsigned char* output, unsigned char* 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.
*/
void MD5_CTX::MD5_memset (unsigned char* output,int value,unsigned int len)
{
 unsigned int i;
 
 for (i = 0; i < len; i++)
  ((char *)output)[i] = (char)value;
}
//-------------------------------------------------------------------------
用法
    //TODO: Add your source code here
    MD5_CTX *before_password;
    before_password = new MD5_CTX();
    char *temp,final_string[16];
    temp = password.c_str();
    before_password->MD5Update(temp,password.Length());
    before_password->MD5Final(final_string);
    return BCD_to_AnsiString(final_string,16);   //將MD5加密的驗證碼用16進制顯示

posted on 2008-05-03 17:26 信任 閱讀(496) 評論(0)  編輯 收藏 引用
敏捷軟件、敏捷企業管理系統 青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
      <noscript id="pjuwb"></noscript>
            <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
              <dd id="pjuwb"></dd>
              <abbr id="pjuwb"></abbr>
              久久久亚洲国产美女国产盗摄| 亚洲看片免费| 久久久久久9| 午夜精品一区二区三区在线视| 国产精品久久久久久久一区探花| 午夜精品久久久久久久99热浪潮| 亚洲一区二区在线看| 国产欧美一区二区精品忘忧草| 欧美专区一区二区三区| 久久久精品日韩| 亚洲免费电影在线观看| 亚洲一区二区三区免费视频| 国产日韩亚洲欧美精品| 欧美国产日本| 欧美日韩视频在线观看一区二区三区| 亚洲一区国产| 久久久精品网| 宅男噜噜噜66一区二区| 欧美亚洲自偷自偷| 日韩午夜在线电影| 亚洲欧洲99久久| 亚洲精品国产欧美| 亚洲欧美日韩在线播放| 亚洲高清视频在线观看| 制服丝袜激情欧洲亚洲| 国内精品一区二区| aa亚洲婷婷| 亚洲电影成人| 亚洲性色视频| 亚洲看片一区| 久久久国产一区二区| 亚洲夜晚福利在线观看| 老司机午夜免费精品视频| 亚洲女性裸体视频| 欧美成人免费网| 久久精品日韩| 国产精品久久久久毛片大屁完整版 | 欧美日韩大陆在线| 久久先锋影音| 国产精品无码专区在线观看| 亚洲欧洲一级| 韩国精品在线观看| 亚洲综合精品自拍| 在线视频你懂得一区| 久久午夜影视| 久久久久久久一区| 国产精品成人免费| 亚洲精品一区二区三区蜜桃久| 黄色国产精品| 欧美在线观看视频| 欧美一区二区三区久久精品茉莉花 | 日韩写真视频在线观看| 亚洲激情另类| 开元免费观看欧美电视剧网站| 欧美在线免费观看视频| 欧美性猛交xxxx乱大交退制版| 亚洲激情国产精品| 亚洲精品黄网在线观看| 免费成人高清| 欧美激情91| 亚洲国产精品久久久久婷婷老年 | 亚洲综合日韩| 亚洲欧美资源在线| 国产精品啊v在线| 一本色道久久| 亚洲一级一区| 国产精品久99| 亚洲曰本av电影| 亚洲欧洲av一区二区三区久久| 欧美性淫爽ww久久久久无| av不卡在线看| 欧美一区成人| 国产有码一区二区| 久久综合给合久久狠狠色| 美女国产一区| 亚洲国产精品va| 欧美精品福利| 亚洲香蕉在线观看| 久久精品国产99国产精品澳门| 国产视频一区在线观看一区免费 | 91久久精品一区| 一区二区国产日产| 国产精品推荐精品| 久久久噜噜噜久久狠狠50岁| 亚洲大片免费看| 亚洲在线一区| 国产亚洲一区二区精品| 麻豆91精品| 正在播放亚洲| 麻豆亚洲精品| 亚洲色诱最新| 狠狠色综合网站久久久久久久| 美国成人直播| 亚洲午夜视频| 欧美国产先锋| 亚洲综合国产| 亚洲国产精品久久久久秋霞不卡| 欧美日韩一级大片网址| 欧美亚洲一区二区三区| 亚洲国产精品传媒在线观看| 亚洲综合999| 亚洲黑丝在线| 国产精品一区一区三区| 蜜臀va亚洲va欧美va天堂| 一区二区三区.www| 欧美xx69| 久久成人国产精品| 一本久久综合| 在线精品观看| 国产目拍亚洲精品99久久精品| 老色批av在线精品| 欧美一级精品大片| 日韩亚洲欧美一区二区三区| 老司机精品福利视频| 亚洲女女做受ⅹxx高潮| 99re亚洲国产精品| 一区二区三区在线免费视频| 欧美四级在线观看| 欧美激情精品久久久六区热门 | 亚洲伦理网站| 伊人久久婷婷色综合98网| 国产精品久久久久久模特| 欧美成人69av| 久久久久久久久久码影片| 亚洲午夜av| 亚洲视频综合| 99精品欧美| 亚洲精品视频在线| 亚洲国产美女| 亚洲福利久久| 欧美激情aaaa| 欧美v国产在线一区二区三区| 久久激情综合网| 欧美一区中文字幕| 午夜精彩视频在线观看不卡 | 国内精品久久久久久久影视麻豆| 欧美日韩一区在线观看| 欧美精品一区二区三区在线播放 | 日韩写真在线| 一本大道久久a久久综合婷婷| 亚洲日本aⅴ片在线观看香蕉| 欧美顶级少妇做爰| 欧美福利一区二区三区| 欧美韩日一区| 亚洲国产激情| 亚洲精品美女免费| 亚洲精品欧美精品| 亚洲精品女人| 亚洲国产精品久久久久久女王| 免费观看亚洲视频大全| 老司机午夜免费精品视频| 久久偷窥视频| 亚洲国产精品成人综合| 亚洲免费观看高清完整版在线观看| 亚洲欧洲三级| 亚洲香蕉在线观看| 欧美一区二区免费视频| 久久久久国产精品一区| 麻豆精品传媒视频| 欧美黄色免费网站| 欧美三级日韩三级国产三级| 国产精品大片免费观看| 国产精品一页| 亚洲第一精品福利| 一本色道久久综合狠狠躁篇怎么玩 | 欧美日韩成人一区| 欧美日韩中文字幕| 国产日韩欧美在线播放不卡| 一区二区在线观看视频| 亚洲精品激情| 欧美一区三区三区高中清蜜桃| 久久看片网站| 最新国产成人在线观看| 亚洲网址在线| 久久婷婷亚洲| 国产精品久久久久久久久久免费看| 国产在线观看精品一区二区三区| 亚洲国产日韩欧美一区二区三区| 日韩一级片网址| 久久精品视频网| 亚洲人成啪啪网站| 欧美一区永久视频免费观看| 欧美14一18处毛片| 国产精品一二三四区| 亚洲人成在线免费观看| 欧美一区二区三区在线播放| 亚洲电影免费在线观看| 亚洲欧美在线看| 欧美激情一区二区三区高清视频 | 麻豆精品传媒视频| 国产精品私房写真福利视频| 亚洲精品乱码久久久久久黑人 | 亚洲精品日产精品乱码不卡| 欧美在线视频一区| 欧美香蕉大胸在线视频观看| 在线观看av不卡| 久久成人免费视频| 一区二区三区国产精华| 麻豆精品一区二区av白丝在线| 国产欧美一区二区精品婷婷|