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

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

?? qqcrypt.cpp

?? 一個QQ-TEA加密解密算法的應用程序, 可以直接對數據進行加密和解密, 對于分析QQ登錄協議很有幫助
?? CPP
字號:
// QQCrypt.cpp: implementation of the CQQCrypt class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "QQEncrypt.h"
#include "QQCrypt.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CQQCrypt::CQQCrypt()
{
	Out = NULL;
	Crypt = 0;
	preCrypt = 0;
	Pos = 0;
	padding = 0;
	Header = FALSE; 
	memset(Plain, 0, 8);
	memset(prePlain, 0, 8);
	memset(Key, 0, 16);
	srand(::GetTickCount());
}

CQQCrypt::~CQQCrypt()
{
	if (Out) delete[] Out;
}

void CQQCrypt::CopyArray(BYTE arr[], int arr_len, int arr_index, DWORD input)
{
	if(arr_index +4 > arr_len) {
                // 不能執行
		return;
	} 
	arr[arr_index+3]=(BYTE)((input & 0xff000000) >> 24);
    arr[arr_index+2]=(BYTE)((input & 0x00ff0000) >> 16);
    arr[arr_index+1]=(BYTE)((input & 0x0000ff00) >> 8);
    arr[arr_index]=(BYTE)(input & 0x000000ff); 

    arr[arr_index] &= 0xff;
    arr[arr_index+1] &= 0xff;
    arr[arr_index+2] &= 0xff;
    arr[arr_index+3] &= 0xff;
}

DWORD CQQCrypt::CopyArray(DWORD Out, BYTE arr[], int arr_len, int arr_index)
{
	if(arr_index+4 > arr_len) {
		return Out;
                //不能執行
	} 

    DWORD x1 = arr[arr_index+3] << 24;
    DWORD x2 = arr[arr_index+2] << 16;
    DWORD x3 = arr[arr_index+1] << 8;
    DWORD x4 = arr[arr_index]; 

    DWORD o = x1 | x2 | x3 | x4;
    o &= 0xffffffff;

	return o;
}

DWORD CQQCrypt::getUnsignedInt(BYTE arrayIn[], int offset, int len)
{
	DWORD ret = 0;
    int end = 0;
    if (len > 8)
        end = offset + 8;
    else
        end = offset + len;
    for (int i = offset; i < end; i++) {
        ret <<= 8;
        ret |= arrayIn[i] & 0xff;
    }

    return (ret & 0xffffffff) | (ret >> 32);
}

DWORD CQQCrypt::Rand()
{
	int rd = rand();

	return rd + rd % 1024;
 
}

void CQQCrypt::Decipher(BYTE arrayIn[], int in_len, BYTE arrayKey[], int key_len, DWORD offset, BYTE arrayOut[])
{
     DWORD sum,delta;
        //Y=z=a=b=c=d=0;
    BYTE tmpArray[24];
    if(in_len < 8) {
        // Error:return
        return;
    }
    if(in_len < 16) {
        // Error:return
        return;
    }
    sum = 0xE3779B90; 
    sum = sum & 0xFFFFFFFF; 
    delta = 0x9E3779B9; 
    delta = delta & 0xFFFFFFFF; 
    /**//*tmpArray[3] = arrayIn[offset]; 
    tmpArray[2] = arrayIn[offset + 1]; 
    tmpArray[1] = arrayIn[offset + 2]; 
    tmpArray[0] = arrayIn[offset + 3]; 
    tmpArray[7] = arrayIn[offset + 4]; 
    tmpArray[6] = arrayIn[offset + 5]; 
    tmpArray[5] = arrayIn[offset + 6]; 
    tmpArray[4] = arrayIn[offset + 7]; 
    tmpArray[11] = arrayKey[0]; 
    tmpArray[10] = arrayKey[1]; 
    tmpArray[9] = arrayKey[2]; 
    tmpArray[8] = arrayKey[3]; 
    tmpArray[15] = arrayKey[4]; 
    tmpArray[14] = arrayKey[5]; 
    tmpArray[13] = arrayKey[6]; 
    tmpArray[12] = arrayKey[7]; 
    tmpArray[19] = arrayKey[8]; 
    tmpArray[18] = arrayKey[9]; 
    tmpArray[17] = arrayKey[10]; 
    tmpArray[16] = arrayKey[11]; 
    tmpArray[23] = arrayKey[12]; 
    tmpArray[22] = arrayKey[13]; 
    tmpArray[21] = arrayKey[14]; 
    tmpArray[20] = arrayKey[15]; 
    Y=CopyArray(Y,tmpArray,0);    
    z=CopyArray(z,tmpArray,4);
    a=CopyArray(a,tmpArray,8);
    b=CopyArray(b,tmpArray,12);
    c=CopyArray(c,tmpArray,16);
    d=CopyArray(d,tmpArray,20);*/
    DWORD Y = getUnsignedInt(arrayIn, (int)offset, 4);
    DWORD z = getUnsignedInt(arrayIn, (int)offset + 4, 4);
    DWORD a = getUnsignedInt(arrayKey, 0, 4);
    DWORD b = getUnsignedInt(arrayKey, 4, 4);
    DWORD c = getUnsignedInt(arrayKey, 8, 4);
    DWORD d = getUnsignedInt(arrayKey, 12, 4);
    for(int i=1;i<=16;i++) {
        z -= ((Y<<4)+c) ^ (Y+sum) ^ ((Y>>5)+d);
        z &= 0xFFFFFFFF;
        Y -= ((z<<4)+a) ^ (z+sum) ^ ((z>>5)+b);
        Y &= 0xFFFFFFFF;
        sum -= delta;
        sum &= 0xFFFFFFFF; 
    } 

    CopyArray(tmpArray,24,0,Y);
    CopyArray(tmpArray,24,4,z);
    arrayOut[0] = tmpArray[3]; 
    arrayOut[1] = tmpArray[2]; 
    arrayOut[2] = tmpArray[1]; 
    arrayOut[3] = tmpArray[0]; 
    arrayOut[4] = tmpArray[7]; 
    arrayOut[5] = tmpArray[6]; 
    arrayOut[6] = tmpArray[5]; 
    arrayOut[7] = tmpArray[4]; 
}

void CQQCrypt::Decipher(BYTE arrayIn[], int in_len, BYTE arrayKey[], int key_len, BYTE arrayOut[])
{
	Decipher(arrayIn, in_len, arrayKey, key_len, 0, arrayOut);
}

void CQQCrypt::Encipher(BYTE arrayIn[], int in_len, BYTE arrayKey[], int key_len, DWORD offset, BYTE arrayOut[])
{
    BYTE tmpArray[24];
    //DWORD Y,z,a,b,c,d;
    //Y=z=a=b=c=d=0;
    DWORD sum,delta;
    if(in_len < 8) {
        // Error:
        return;
    }
    if(key_len < 16) {
        // Error:
        return;
    }
    sum = 0;
    delta = 0x9E3779B9;
    delta &= 0xFFFFFFFF; 

    /**//*tmpArray[3] = arrayIn[offset]; 
    tmpArray[2] = arrayIn[offset + 1]; 
    tmpArray[1] = arrayIn[offset + 2]; 
    tmpArray[0] = arrayIn[offset + 3]; 
    tmpArray[7] = arrayIn[offset + 4]; 
    tmpArray[6] = arrayIn[offset + 5]; 
    tmpArray[5] = arrayIn[offset + 6]; 
    tmpArray[4] = arrayIn[offset + 7]; 
    tmpArray[11] = arrayKey[0]; 
    tmpArray[10] = arrayKey[1]; 
    tmpArray[9] = arrayKey[2]; 
    tmpArray[8] = arrayKey[3]; 
    tmpArray[15] = arrayKey[4]; 
    tmpArray[14] = arrayKey[5]; 
    tmpArray[13] = arrayKey[6]; 
    tmpArray[12] = arrayKey[7]; 
    tmpArray[19] = arrayKey[8];
    tmpArray[18] = arrayKey[9]; 
    tmpArray[17] = arrayKey[10]; 
    tmpArray[16] = arrayKey[11]; 
    tmpArray[23] = arrayKey[12]; 
    tmpArray[22] = arrayKey[13]; 
    tmpArray[21] = arrayKey[14]; 
    tmpArray[20] = arrayKey[15]; 

    Y=CopyArray(Y,tmpArray,0);
    z=CopyArray(z,tmpArray,4);
    a=CopyArray(a,tmpArray,8);
    b=CopyArray(b,tmpArray,12);
    c=CopyArray(c,tmpArray,16);
    d=CopyArray(d,tmpArray,20);*/ 

    DWORD Y = getUnsignedInt(arrayIn, (int)offset, 4);
    DWORD z = getUnsignedInt(arrayIn, (int)offset + 4, 4);
    DWORD a = getUnsignedInt(arrayKey, 0, 4);
    DWORD b = getUnsignedInt(arrayKey, 4, 4);
    DWORD c = getUnsignedInt(arrayKey, 8, 4);
    DWORD d = getUnsignedInt(arrayKey, 12, 4); 

    for(int i=1;i<=16;i++) {
        sum += delta;
        sum &= 0xFFFFFFFF;
        Y += ((z<<4)+a) ^ (z+sum) ^ ((z>>5)+b);
        Y &= 0xFFFFFFFF;
        z += ((Y<<4)+c) ^ (Y+sum) ^ ((Y>>5)+d);
        z &= 0xFFFFFFFF;
    } 

    CopyArray(tmpArray, 24, 0,Y);
    CopyArray(tmpArray, 24, 4,z); 

    arrayOut[0] = tmpArray[3]; 
    arrayOut[1] = tmpArray[2]; 
    arrayOut[2] = tmpArray[1];
    arrayOut[3] = tmpArray[0]; 
    arrayOut[4] = tmpArray[7]; 
    arrayOut[5] = tmpArray[6]; 
    arrayOut[6] = tmpArray[5]; 
    arrayOut[7] = tmpArray[4]; 

}

void CQQCrypt::Encipher(BYTE arrayIn[], int in_len, BYTE arrayKey[], int key_len, BYTE arrayOut[])
{
	Encipher(arrayIn, in_len, arrayKey, key_len, 0, arrayOut);
}

void CQQCrypt::Encrypt8Bytes()
{
	BYTE Crypted[8];
    for(Pos=0; Pos<=7; Pos++) {
        if(Header == TRUE){
            Plain[Pos] = (BYTE)(Plain[Pos] ^ prePlain[Pos]);
        } else {
            Plain[Pos] = (BYTE)(Plain[Pos] ^ Out[preCrypt + Pos]);
        }
    }
    Encipher(Plain, 8, Key, 8, Crypted);
    
    for(int i=0; i<=7; i++) {
        Out[Crypt + i] = (BYTE)Crypted[i];
    }
    
    for(Pos=0;Pos<=7;Pos++) {
        Out[Crypt + Pos] = (BYTE)(Out[Crypt + Pos] ^ prePlain[Pos]);
    }            
    //Plain.CopyTo(prePlain,0);
	memcpy(prePlain, Plain, 8);
    preCrypt = Crypt;
    Crypt = Crypt + 8;
    Pos = 0;
    Header = FALSE;
}

BOOL CQQCrypt::Decrypt8Bytes(BYTE arrayIn[], int in_len, DWORD offset)
{
       //DWORD lngTemp;
	   for(Pos=0; Pos<=7; Pos++) {
		   if(contextStart + Pos > in_len -1) {
				return TRUE;
			}
			prePlain[Pos] = (byte)(prePlain[Pos] ^ arrayIn[offset+Crypt+Pos]);
		}
	   try {
		   Decipher(prePlain, 8, Key, 8, prePlain);
			//prePlain = Decipher(prePlain, Key);
		}
	   catch (...) {
			return FALSE;
		}
		//lngTemp = prePlain.Length - 1;
		contextStart += 8;
		Crypt+=8;
		Pos = 0;

		return TRUE;
}

BOOL CQQCrypt::Decrypt8Bytes(BYTE arrayIn[], int in_len)
{
	return Decrypt8Bytes(arrayIn, in_len, 0);
}

int CQQCrypt::QQ_Encrypt(BYTE arrayIn[], int in_len, BYTE arrayKey[], int key_len, DWORD offset, BYTE *&ArrayOut)
{
        
		DWORD l;

		ArrayOut = 0;
        Pos = 1;
        padding = 0;
        Crypt = preCrypt = 0;
        //arrayKey.CopyTo(Key,0);    // Key Must Be 16 Length!
		memcpy(Key, arrayKey, key_len);
        Header = TRUE;
        Pos = 2;
        //計算頭部填充字節數
        Pos = (in_len+10) % 8;
        if(Pos != 0)
            Pos = 8-Pos;
        //輸出長度
		if (Out) delete[] Out;
		int out_len = in_len + Pos + 10;
        Out = new BYTE[out_len];
        //把POS存到PLAIN的第一個字節
        //0xf8后面3位是空的,正好給Pos
        Plain[0] = (BYTE)((Rand() & 0xf8) | Pos);
        //用隨機數填充1到Pos的內容
        for(int i=1;i<=Pos;i++) {
            Plain[i] = (BYTE)(Rand() & 0xff);
        }
        Pos++;
        padding = 1; 

        //繼續填充兩個字節隨機數,滿8字節就加密
        while(padding < 3) {
            if( Pos < 8) {
                Plain[Pos] = (BYTE)(Rand() & 0xff);
                padding++;
                Pos++;
            }
            else if(Pos == 8) {
                Encrypt8Bytes();
            }
        } 

        int I = (int)offset;
        l = 0;
        //明文內容,滿8字節加密到讀完
        l = in_len;
        while ( l > 0) {
            if(Pos<8) {
                Plain[Pos] = arrayIn[I];
                I++;
                Pos++;
                l--;
            } else if(Pos == 8) {
                Encrypt8Bytes();
            }
        } 

        //末尾填充0,保證是8的倍數
        padding = 1;
        while(padding < 9) {
            if(Pos<8) {
                Plain[Pos] = 0;
                Pos++;
                padding++;
            } else if(Pos == 8) {
                Encrypt8Bytes();
            }
        } 
		ArrayOut = Out;

        return out_len;
}

int CQQCrypt::QQ_Encrypt(BYTE arrayIn[], int in_len, BYTE arrayKey[], int key_len, BYTE *&ArrayOut)
{
	return QQ_Encrypt(arrayIn, in_len, arrayKey, key_len, 0, ArrayOut);
}

int CQQCrypt::QQ_Decrypt(BYTE arrayIn[], int in_len, BYTE arrayKey[], int key_len, DWORD offset, BYTE *&ArrayOut)
{
   //檢查是否是8的倍數至少16字節
	CString str;
	
	ArrayOut = 0;
    if(in_len < 16 || (in_len % 8 != 0)) {
        //Return What?
        return 0;
    }
    if(key_len != 16) {
        //Return What?
        return 0;
    }
	
    BYTE *m;
    DWORD I,Count;
	int m_len = offset+8;
    m= new BYTE[m_len];
	memcpy(Key, arrayKey, key_len);
    //arrayKey.CopyTo(Key,0);
    Crypt = preCrypt = 0;
    //計算消息頭部,明文開始的偏移,解密第一字節和7相與得到
    //prePlain = this.Decipher(arrayIn,arrayKey,offset);
	Decipher(arrayIn, in_len, arrayKey, key_len, offset, prePlain);
    Pos = prePlain[0] & 7;
    //計算明文長度
    Count = in_len - Pos - 10;
    if(Count <= 0) {
        //Return What?
        return 0;
    }
	if (Out) delete[] Out;
	int out_len = Count;
    Out = new BYTE[out_len];
    preCrypt = 0;
    Crypt = 8;
    contextStart = 8;
    Pos++;
    padding = 1;
    //跳過頭部
    while(padding < 3) {
        if(Pos<8) {
            Pos++;
            padding++;
        }
        else if(Pos==8) {
            for(int i=0;i<m_len;i++)
                m[i]=arrayIn[i];
            //if(this.Decrypt8Bytes(arrayIn,offset) == false)
			if(Decrypt8Bytes(arrayIn, in_len, offset) == FALSE) {
                //Return What?
                return 0;
            }
        }
    } 

    //解密明文
    I=0;
    while(Count != 0) {
        if(Pos<8) {
            Out[I] = (BYTE)(m[offset+preCrypt+Pos] ^ prePlain[Pos]);
            I++;
            Count--;
            Pos++;
        }
        else if(Pos == 8) {
            m = arrayIn;
            preCrypt = Crypt - 8;
            //if(this.Decrypt8Bytes(arrayIn,offset) == false)
			if(Decrypt8Bytes(arrayIn, in_len, offset) == FALSE) {
                //Return What?
                return 0;
            }
        }
    } 
    //最后的解密部分,檢查尾部是不是0
    for(padding=1; padding<=7; padding++) {
        if(Pos<8) {
            if( (m[offset+preCrypt+Pos] ^ prePlain[Pos]) != 0 ) {
                //Return What?
				//這里解不出
                return 0;
            }
            Pos++;
        }
        else if(Pos == 8) {
            for(int i=0;i<m_len;i++)
                m[i] = arrayIn[i];
            preCrypt = Crypt;
            //if(this.Decrypt8Bytes(arrayIn,offset) == false)
			if(Decrypt8Bytes(arrayIn, in_len, offset) == FALSE) {
                //Return What?
                return 0;
            }
        }
    }
	ArrayOut = Out;

    return out_len;
}

int CQQCrypt::QQ_Decrypt(BYTE arrayIn[], int in_len, BYTE arrayKey[], int key_len, BYTE *&ArrayOut)
{
	return QQ_Decrypt(arrayIn, in_len, arrayKey, key_len, 0, ArrayOut);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
肉丝袜脚交视频一区二区| 国产精品中文字幕欧美| 久久国产精品免费| 97久久超碰国产精品| 日韩午夜激情免费电影| 中文字幕在线免费不卡| 久久国产尿小便嘘嘘| 色一情一伦一子一伦一区| 久久久久久99久久久精品网站| 亚洲最新在线观看| 成人免费看黄yyy456| 欧美精品一区二区精品网| 亚洲高清视频在线| 色综合色综合色综合| 国产清纯白嫩初高生在线观看91 | 日本一区二区在线不卡| 天天综合色天天| 色偷偷久久一区二区三区| 久久精品亚洲麻豆av一区二区| 日韩精品乱码免费| 欧美天堂一区二区三区| 亚洲三级在线免费观看| 大白屁股一区二区视频| 久久久www成人免费毛片麻豆| 日本va欧美va欧美va精品| 欧美午夜免费电影| 一区二区视频在线| 99国产欧美另类久久久精品| 欧美国产精品一区二区三区| 国产成人av电影在线观看| 精品日产卡一卡二卡麻豆| 美女免费视频一区| 欧美一二区视频| 久久国内精品视频| 精品福利二区三区| 国产一区 二区| 久久精品亚洲乱码伦伦中文 | 国产成人免费在线观看不卡| 久久先锋资源网| 狠狠色狠狠色综合系列| 精品久久一区二区| 国产精品一区二区男女羞羞无遮挡 | 成人高清视频免费观看| 18欧美乱大交hd1984| 色哟哟一区二区| 亚洲国产一区二区视频| 91麻豆精品国产91久久久久久久久| 日韩成人伦理电影在线观看| 精品日韩一区二区三区| 国产成人超碰人人澡人人澡| 国产精品久久久久久户外露出 | 91美女精品福利| 亚洲自拍欧美精品| 6080国产精品一区二区| 国内精品嫩模私拍在线| 国产精品国产精品国产专区不片 | 国产成人在线免费观看| 国产精品国产自产拍高清av| 91成人在线免费观看| 婷婷久久综合九色综合绿巨人| 欧美一区二区三区在线观看 | 成人午夜激情影院| 国产精品天干天干在线综合| 欧美亚洲国产怡红院影院| 青娱乐精品在线视频| 欧美国产成人精品| 欧美性欧美巨大黑白大战| 奇米四色…亚洲| 国产精品美女视频| 欧美精品色一区二区三区| 国产成人免费av在线| 日韩理论片网站| 日韩免费一区二区三区在线播放| 成人免费视频视频在线观看免费| 亚洲激情在线激情| 精品国产一区二区三区忘忧草| av中文字幕不卡| 麻豆传媒一区二区三区| 亚洲人吸女人奶水| 久久夜色精品国产噜噜av| 色香蕉成人二区免费| 国产精品一区不卡| 性欧美疯狂xxxxbbbb| 国产精品美女视频| 欧美xxx久久| 欧美日韩一区二区三区免费看| 国产成人av福利| 日本不卡免费在线视频| 亚洲精品日日夜夜| 国产欧美日韩三区| 日韩精品最新网址| 欧美日韩美女一区二区| 99热精品国产| 国产精品18久久久久久久久| 奇米精品一区二区三区在线观看一| 一色桃子久久精品亚洲| 久久久www成人免费无遮挡大片| 777午夜精品免费视频| 色999日韩国产欧美一区二区| 粉嫩一区二区三区性色av| 另类专区欧美蜜桃臀第一页| 亚洲国产wwwccc36天堂| 亚洲摸摸操操av| 中文字幕av不卡| 国产色产综合产在线视频| 欧美va日韩va| 日韩三级免费观看| 欧美一区二区三区在线看| 欧美性生活大片视频| 91国偷自产一区二区三区观看| 成人av影视在线观看| 国产成人精品免费在线| 国产裸体歌舞团一区二区| 精品一区二区在线观看| 毛片一区二区三区| 男女男精品网站| 日韩福利视频网| 日韩av一级片| 青草av.久久免费一区| 亚洲一区二区三区精品在线| 亚洲一本大道在线| 欧美二区三区的天堂| 日韩中文字幕av电影| 一区二区三区在线观看欧美| 亚洲精品国产第一综合99久久| 中文字幕欧美三区| 国产精品久久三区| 自拍偷拍欧美精品| 一区二区三区电影在线播| 一区二区在线免费观看| 亚洲香蕉伊在人在线观| 午夜不卡av免费| 美腿丝袜亚洲一区| 精品一区二区国语对白| 国产91精品一区二区麻豆亚洲| 国产成人综合在线观看| zzijzzij亚洲日本少妇熟睡| 色婷婷久久久综合中文字幕| 欧美日韩日日骚| 日韩精品一区二区三区中文不卡| 日韩免费视频一区二区| 日本一区二区电影| 一级做a爱片久久| 欧美bbbbb| 成人免费va视频| 欧美视频一二三区| 日韩一区二区影院| 欧美激情综合五月色丁香| 中文字幕在线视频一区| 亚洲mv在线观看| 国产精品白丝jk白祙喷水网站| 国产suv一区二区三区88区| 色婷婷激情综合| 日韩精品一区二区三区在线播放| 欧美韩日一区二区三区| 一区二区三区日韩欧美精品 | 久久老女人爱爱| 综合分类小说区另类春色亚洲小说欧美| 亚洲综合色视频| 国产精一品亚洲二区在线视频| www.欧美色图| 日韩一区二区影院| 最新成人av在线| 久久99精品久久只有精品| 99国产精品视频免费观看| 日韩视频一区二区三区在线播放| 中文字幕乱码一区二区免费| 日日欢夜夜爽一区| 9久草视频在线视频精品| 日韩一区二区精品在线观看| 亚洲欧美电影院| 丁香婷婷综合网| 欧美一级理论性理论a| 亚洲猫色日本管| 国产一区二区三区精品视频| 欧美性大战xxxxx久久久| 国产免费观看久久| 激情成人综合网| 欧美体内she精视频| 国产精品三级av| 国产永久精品大片wwwapp| 555夜色666亚洲国产免| 亚洲欧美国产77777| 成人深夜福利app| 日韩网站在线看片你懂的| 亚洲国产婷婷综合在线精品| av成人免费在线| 国产精品美女久久久久aⅴ国产馆| 久久精品国产久精国产爱| 欧美精品色一区二区三区| 亚洲自拍都市欧美小说| 99视频国产精品| 国产精品乱码久久久久久| 欧美精品v日韩精品v韩国精品v| 午夜精品在线视频一区| 日韩精品一区国产麻豆| 亚洲国产婷婷综合在线精品| 欧洲一区二区三区在线| 一区二区三区蜜桃网| 97se亚洲国产综合在线|