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

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

?? 數字簽名dlg.cpp

?? 本程序實現DSA數字簽名 是學習和研究密碼學的良好資源 歡迎下載
?? CPP
字號:
// 數字簽名Dlg.cpp : implementation file
//

#include "stdafx.h"
#include "數字簽名.h"
#include "數字簽名Dlg.h"
#include "BigInt.h"
#include "MD5.h"
#include "SHA1.h"

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

CBigInt sha(CBigInt y);
CBigInt pow2( const int x, int y);
CBigInt makerandnumber( unsigned int len);
CBigInt pow3(CBigInt x, CBigInt y, CBigInt m);

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	virtual void OnOK();
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// DMyDlg dialog

DMyDlg::DMyDlg(CWnd* pParent /*=NULL*/)
	: CDialog(DMyDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(DMyDlg)
	m_P = _T("");
	m_Q = _T("");
	m_G = _T("");		//mpdified in 2007.6.10
	m_Y = _T("");
	m_S = _T("");
	m_V = _T("");
	m_Len = 0;
	m_OUT = _T("");
	m_IN = _T("");
	ready = 0;
	m_file = _T("");
	m_string = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void DMyDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(DMyDlg)
	DDX_Text(pDX, IDC_P, m_P);
	DDX_Text(pDX, IDC_Q, m_Q);
	DDX_Text(pDX, IDC_G, m_G);		// mpdified in 2007.6.10
	DDX_Text(pDX, IDC_Y, m_Y);
	DDX_Text(pDX, IDC_S, m_S);
	DDX_Text(pDX, IDC_V, m_V);
	DDX_CBIndex(pDX, IDC_COMBO, m_Len);
	DDX_Text(pDX, IDC_OUTPUT, m_OUT);
	DDX_Text(pDX, IDC_INPUT, m_IN);
	DDX_Text(pDX, IDC_EDITFILE, m_file);
	DDX_Text(pDX, IDC_STRING, m_string);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(DMyDlg, CDialog)
	//{{AFX_MSG_MAP(DMyDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON_GET, OnButtonGet)
	ON_BN_CLICKED(IDC_ENCRYPT, OnEncrypt)
	ON_BN_CLICKED(IDC_DECRYPT, OnDecrypt)
	ON_BN_CLICKED(IDC_Btnfile, OnBtnfile)
	ON_EN_CHANGE(IDC_EDITFILE, OnChangeEditfile)
	ON_EN_CHANGE(IDC_STRING, OnChangeString)
	ON_BN_CLICKED(IDC_SHA1_RADIO, OnSha1Radio)
	ON_BN_CLICKED(IDC_MD5_RADIO, OnMd5Radio)
	ON_CBN_EDITCHANGE(IDC_COMBO, OnEditchangeCombo)
	ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// DMyDlg message handlers

BOOL DMyDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here

	CheckRadioButton(IDC_MD5_RADIO,IDC_SHA1_RADIO,IDC_MD5_RADIO);
	UpdateData(FALSE);

	return TRUE;  // return TRUE  unless you set the focus to a control
}

void DMyDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void DMyDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR DMyDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void DMyDlg::OnButtonGet() 
{
	// TODO: Add your control notification handler code here
	ready=1;
	UpdateData(TRUE);
    CTime t0=CTime::GetCurrentTime();
/*
	int len=8;  //int len=2; modified in 2007 6. 9
	for(int i=0;i<m_Len;i++){len*=2;}
	P.Mov(0);
	Q.Mov(0);
	N.Mov(0);
	E.Mov(0);
	P.GetPrime(len);
	Q.GetPrime(len);
	N.Mov(P.Mul(Q));
	N.Put(m_P);
	P.m_ulValue[0]--;
	Q.m_ulValue[0]--;
	P.Mov(P.Mul(Q));
	D.Mov(0x10001);		//mpdified in 2007.6.10
//	m_D="10001";		//mpdified in 2007.6.10
	E.Mov(D.Euc(P));
	E.Put(m_Q);
    CTime t1=CTime::GetCurrentTime();
    CTimeSpan t=t1-t0;
	m_OUT.Format("%d",t.GetTotalSeconds());
	m_OUT+=" 秒";
	Q.m_ulValue[0]=0;
*/
	CBigInt r,s,u,v[4],w,p,q,t; //,H,G,X,Y;
	int n=3,b=31,L=512,g=160,T=1;
	t.Mov(pow2(2,g));
	while (T)
	{
		s.Mov(makerandnumber(g));
//			r.Mov(s);
//			r.Mov(r.Add(1));
//			r.Mov(r.Mod(t));
//			u.Mov(sha(s));
		q.Mov(sha(s));
		q.m_ulValue[0]=q.m_ulValue[0]|0x1;
		q.m_ulValue[4]=q.m_ulValue[4]|0x80000000; 
		while (q.Rab()==0)  
			q.Mov(q.Add(2));
		int C=0,N=2;
		for (int k=0;k<4;k++)
		{
			v[k].Mov(s);
			v[k].Mov(v[k].Add(N+k));
			v[k].Mov(v[k].Mod(t));
			v[k].Mov(sha(v[k]));
		}
		w.Mov(0);
		r.Mov(1);
		for ( k=0;k<3;k++)
		{
			v[k].Mov(v[k].Mul(r));
			w.Mov(w.Add(v[k]));
			r.Mov(r.Mul(t));
		}
		s.Mov(pow2(2,b));
		v[k].Mov(v[k].Mod(s));
		v[k].Mov(v[k].Mul(r));
		w.Mov(w.Add(v[k]));
		r.Mov(w);
		r.Mov(r.Add(1));
		w.Mov(w.Mod(q));
		r.Mov(r.Sub(w));
		p.Mov(r);
		while (p.Rab()==0) 
		{
			C=C+1;
			N=N+n+1;
			if (C==4096) break;
			p.Mov(p.Add(q));
			p.Mov(p.Add(q));
		}
		if (C<4096)	break;
	}
	P.Mov(p);
	Q.Mov(q);
	H.Mov(makerandnumber(g));
	X.Mov(makerandnumber(g));
	X.Mov(X.Mod(Q));
	t.Mov(P.Sub(1));
	t.Mov(t.Div(Q));
	G.Mov(H.RsaTrans(t, Q));
	Y.Mov(G.RsaTrans(X, P));
	P.Put(m_P);
	Q.Put(m_Q);
	G.Put(m_G);
	Y.Put(m_Y);
//	m_D="10001";
    CTime t1=CTime::GetCurrentTime();
    CTimeSpan t2=t1-t0;
	m_OUT.Format("%d",t2.GetTotalSeconds());
	m_OUT+=" 秒";
	UpdateData(FALSE);
}

void DMyDlg::OnEncrypt() 
{
	// TODO: Add your control notification handler code here
	CBigInt g,t;
	if(ready==0)
	{
		m_OUT=_T("請先輸入或生成N、D、E");
        UpdateData(FALSE);
		return;
	}
	UpdateData(TRUE);
    if(m_IN.GetLength()>256)
	{
		m_OUT=_T("N不得大于256位");
		UpdateData(FALSE);
		return;
	}
	K.Mov(makerandnumber(160));
	R.Mov(G.RsaTrans(K,P));
	R.Mov(R.Mod(Q));
	S.Mov(K.Euc(Q));
	g.Get(m_IN);
	t.Mov(X.Mul(R));
	t.Mov(t.Mod(Q));
	t.Mov(t.Add(g));
	S.Mov(S.Mul(t));
	S.Mov(S.Mod(Q));
	R.Put(m_OUT);
	S.Put(m_S);
/*	for(int i=0;i<m_IN.GetLength();i++)
	{
		if((m_IN[i]<'0')||
		   ((m_IN[i]>'9')&&(m_IN[i]<'A'))||
		   ((m_IN[i]>'F')&&(m_IN[i]<'a'))||
		   (m_IN[i]>'f'))
		{
			m_OUT=_T("待加密數據必須為0-9或A-F或a-f組成的整數");
			UpdateData(FALSE);
			return;
		}
	}*/
//	P.Get(m_IN);
//	if(P.Cmp(N)>=0)
//	{
//		m_OUT=_T("待加密數據必須小于N");
//        UpdateData(FALSE);
//		return;
//	}
//	Q.Mov(P.RsaTrans(E,N));
//	Q.Put(m_OUT);
	UpdateData(FALSE);
}

void DMyDlg::OnDecrypt() 
{
	CBigInt W,U1,U2,t;
	// TODO: Add your control notification handler code here
	if((ready==0)||(Q.m_ulValue[0]==0))
	{
		m_OUT=_T("請先進行數字簽名");
        UpdateData(FALSE);
		return;
	}
	W.Mov(S.Euc(Q));
	U1.Get(m_IN);
	U1.Mov(U1.Mul(W));
	U1.Mov(U1.Mod(Q));
	U2.Mov(R.Mul(W));
	U2.Mov(U2.Mod(Q));
	V.Mov(G.RsaTrans(U1,P));
	V.Mov(V.Mod(P));
	t.Mov(Y.RsaTrans(U2,P));
	t.Mov(t.Mod(P));
	V.Mov(V.Mul(t));
	V.Mov(V.Mod(P));
	V.Mov(V.Mod(Q));
	if (V.Cmp(R)==0) V.Put(m_V);
	R.Put(m_V);


//	Q.Get(m_OUT);
//	P.Mov(Q.RsaTrans(D,N));
//	P.Put(m_OUT);
	UpdateData(FALSE);
}

void DMyDlg::OnBtnfile() 
{
	// TODO: Add your control notification handler code here
	CFileDialog m_FileOpen(TRUE); 
//設置打開窗體的標題 
	m_FileOpen.m_ofn.lpstrTitle = _T("打開文件"); 
	m_FileOpen.m_ofn.lpstrFilter = _T("文件 (*.*)\0*.*\0\0"); 
//點擊瀏覽按鈕 
	if(IDOK == m_FileOpen.DoModal()) 
	{ 
	   //獲取打開的文件路徑 
	   CString m_FileName = m_FileOpen.GetPathName(); 
	   CEdit* pEdit = (CEdit*)(GetDlgItem(IDC_EDITFILE)); 
	   //將選擇的文件路徑名顯示到IDC_EDITFILE表識的EDIT中 
	   pEdit->SetWindowText(m_FileName); 
	} 
}

void byte2strhash(unsigned char *hash,int hashlen,unsigned char *out)
{
int i,x,y;

	for (i = 0;i < hashlen; i++)
	{
	y = hash[i] >> 4;			

	y += 0x30;
	if (y > 0x39) y+= 0x07;

	x = hash[i] & 0x0F;			
	
	x += 0x30;
	if (x > 0x39) x+= 0x07;

	out[i << 1] = y;			
	out[(i << 1)+1] = x;		
	}

	out[hashlen << 1] = 0x00;

}

void DMyDlg::OnChangeEditfile() 
{
	// TODO: If this is a RICHEDIT control, the control will not
	// send this notification unless you override the CDialog::OnInitDialog()
	// function and call CRichEditCtrl().SetEventMask()
	// with the ENM_CHANGE flag ORed into the mask.
	
	// TODO: Add your control notification handler code here
	UpdateData(TRUE);   
    CString open=m_file;   
    MD5_CTX	md5_ctx;
    SHA1_CTX sha1_ctx;

	int hashradio;
 
	hashradio=GetCheckedRadioButton(IDC_MD5_RADIO,IDC_SHA1_RADIO);
	if(hashradio==IDC_MD5_RADIO)         //MD5
	{   
		int i;
		unsigned char digest[16],output[16];
		FILE* file;
        unsigned char buffer[16384];
	    MD5Init(&md5_ctx);
		file = fopen(open, "rb");
        i = fread(buffer, 1, 16384, file);
        MD5Update(&md5_ctx, buffer, i);
        MD5Final(digest, &md5_ctx);
        fclose(file);
		
		byte2strhash(digest,16,output);
		CString str(output);
		SetDlgItemText(IDC_INPUT,str);		
	}

	else           //SHA-1
	{
		int i;
		unsigned char digest[20],output[20];
		FILE* file;
        unsigned char buffer[16384];
	    SHA1Init(&sha1_ctx);
		file = fopen(open, "rb");
        i = fread(buffer, 1, 16384, file);
        SHA1Update(&sha1_ctx, buffer, i);
        SHA1Final(digest, &sha1_ctx);
        fclose(file);
		
		byte2strhash(digest,20,output);
		CString str(output);
		SetDlgItemText(IDC_INPUT,str);
	}
}

void DMyDlg::OnChangeString() 
{
	// TODO: If this is a RICHEDIT control, the control will not
	// send this notification unless you override the CDialog::OnInitDialog()
	// function and call CRichEditCtrl().SetEventMask()
	// with the ENM_CHANGE flag ORed into the mask.
	
	// TODO: Add your control notification handler code here
	UpdateData(TRUE);     
    MD5_CTX	md5_ctx;
    SHA1_CTX sha1_ctx;

	int hashradio;
    
	hashradio=GetCheckedRadioButton(IDC_MD5_RADIO,IDC_SHA1_RADIO);
	if(hashradio==IDC_MD5_RADIO)         //MD5
	{
		unsigned char digest[16],output[16];

		UpdateData(TRUE);   
        CString context=m_string; 

        MD5Init(&md5_ctx);
		unsigned char *buf = (unsigned char*)context.GetBuffer(context.GetLength()); 
        MD5Update(&md5_ctx,buf, strlen(context));
        MD5Final(digest, &md5_ctx);
		context.ReleaseBuffer();

		byte2strhash(digest,16,output);
		CString str(output);
		SetDlgItemText(IDC_INPUT,str);

       }

	else       //SHA1
	{
		unsigned char digest[20],output[20];
		UpdateData(TRUE);   
        CString context=m_string; 

        SHA1Init(&sha1_ctx);
		unsigned char *buf = (unsigned char*)context.GetBuffer(context.GetLength()); 
        SHA1Update(&sha1_ctx,buf, strlen(context));
        SHA1Final(digest, &sha1_ctx);
		context.ReleaseBuffer();

		byte2strhash(digest,20,output);	
		CString str(output);
		SetDlgItemText(IDC_INPUT,str);
	}
}

void DMyDlg::OnSha1Radio() 
{
	// TODO: Add your control notification handler code here
	
}

void DMyDlg::OnMd5Radio() 
{
	// TODO: Add your control notification handler code here
	
}

void DMyDlg::OnEditchangeCombo() 
{
	// TODO: Add your control notification handler code here
	
}

void DMyDlg::OnButton1() 
{
	// TODO: Add your control notification handler code here
	CDialog::OnOK();
	
}

void CAboutDlg::OnOK() 
{
	// TODO: Add extra validation here	
	CDialog::OnOK();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美剧情片在线观看| 午夜影视日本亚洲欧洲精品| 久久精品国产免费| 色又黄又爽网站www久久| 欧美日韩一本到| 极品销魂美女一区二区三区| 一二三区精品视频| 久久久综合九色合综国产精品| 日日夜夜一区二区| 26uuu精品一区二区| 国产一区二区主播在线| 久久久久久久久久久99999| 美国欧美日韩国产在线播放| 日韩视频一区二区在线观看| 亚欧色一区w666天堂| 91精品国产全国免费观看| 久久精品72免费观看| 欧美高清在线一区| 777xxx欧美| 91网站最新地址| 亚洲人成亚洲人成在线观看图片| 91亚洲国产成人精品一区二三| 亚洲最新视频在线观看| 久久一夜天堂av一区二区三区| 成人免费视频app| 亚洲国产婷婷综合在线精品| 日韩视频中午一区| 欧美三级韩国三级日本一级| 美女久久久精品| 亚洲色欲色欲www| 久久蜜桃av一区二区天堂| 日韩制服丝袜先锋影音| 99久久婷婷国产| 精品国偷自产国产一区| 欧美影视一区在线| 日本中文在线一区| 久久久国产精品午夜一区ai换脸 | 日韩一二三区视频| 欧美在线免费播放| 色久综合一二码| 91福利国产精品| 91在线观看美女| 欧美专区亚洲专区| 欧美一区二区精品久久911| 欧美一区午夜精品| 欧美日韩一区在线观看| 欧美中文字幕一区| 色哟哟一区二区| av在线播放不卡| 国产露脸91国语对白| 国产一区二区在线观看免费| 日本亚洲三级在线| 精品一区二区三区免费观看| 麻豆精品精品国产自在97香蕉| 一区二区国产视频| 亚洲欧洲日韩av| 亚洲精品国产精华液| 一区二区三区欧美久久| 亚洲一区二区三区四区中文字幕| 一区二区三区视频在线看| 亚洲图片自拍偷拍| 亚洲h在线观看| 麻豆成人在线观看| 成人av动漫在线| 欧美日韩精品高清| 久久尤物电影视频在线观看| 久久色在线观看| 亚洲综合激情另类小说区| 天堂精品中文字幕在线| 国产精品一区一区三区| 91女神在线视频| 欧美一区二视频| 中文字幕一区二区三| 天堂午夜影视日韩欧美一区二区| 久久精品久久精品| 色爱区综合激月婷婷| 久久女同性恋中文字幕| 亚洲一区二区综合| 成人视屏免费看| 欧美精品一区二区三区久久久 | 丁香六月久久综合狠狠色| 欧美亚洲综合网| 国产精品久久精品日日| 美女爽到高潮91| 欧美中文字幕一二三区视频| xnxx国产精品| 成人精品小蝌蚪| 日韩午夜三级在线| 天堂蜜桃一区二区三区| 欧美调教femdomvk| 一区二区三区四区不卡在线| 成a人片亚洲日本久久| 久久久九九九九| 成人国产亚洲欧美成人综合网| 精品久久久久久久久久久久久久久久久| 一区二区久久久久| 欧美日韩激情一区二区三区| 一级做a爱片久久| 欧美色倩网站大全免费| 天堂av在线一区| 日韩欧美第一区| 国产一区二区调教| 国产欧美一区二区在线| 国产盗摄女厕一区二区三区| 国产日韩v精品一区二区| 国产福利精品一区二区| 国产精品欧美极品| 日本韩国精品在线| 天堂成人国产精品一区| 精品动漫一区二区三区在线观看| 精品一二三四区| 国产精品久久久久久久久久久免费看| a美女胸又www黄视频久久| 亚洲综合色区另类av| 欧美成人精精品一区二区频| 国产剧情一区二区三区| 亚洲精品中文字幕乱码三区| 欧美亚洲综合另类| 久草中文综合在线| 亚洲久本草在线中文字幕| 欧美撒尿777hd撒尿| 国产一区三区三区| 亚洲成人精品影院| 天堂成人国产精品一区| 伊人色综合久久天天| 91精品国产全国免费观看| 亚洲成a人片在线不卡一二三区| 91精品国产色综合久久ai换脸| 国产高清视频一区| 全部av―极品视觉盛宴亚洲| 中文字幕亚洲区| 久久婷婷综合激情| 91麻豆精品久久久久蜜臀| jizz一区二区| 国产剧情一区二区| 免费黄网站欧美| 一区二区三区免费看视频| 国产偷国产偷精品高清尤物| 欧美日韩精品二区第二页| 91国产福利在线| 一本到不卡精品视频在线观看| 国产成人日日夜夜| 丰满亚洲少妇av| 国产一本一道久久香蕉| 国产在线一区二区| 捆绑紧缚一区二区三区视频| 日韩电影免费一区| 久久99久久99小草精品免视看| 日本不卡中文字幕| 蓝色福利精品导航| 国模套图日韩精品一区二区| 久久99精品国产麻豆婷婷洗澡| 日本三级亚洲精品| 精品影视av免费| 国产精品一区二区久久精品爱涩 | 国产精品毛片久久久久久| 欧美国产日韩a欧美在线观看| 欧美国产一区在线| 亚洲精品国产一区二区精华液| 日韩av电影天堂| 精品一区二区精品| 99re这里只有精品6| 欧美性视频一区二区三区| 欧美xingq一区二区| 国产精品网站一区| 午夜电影久久久| 波多野结衣91| 欧美一级夜夜爽| 一区视频在线播放| 欧美aaa在线| 色综合久久久久| 久久精品综合网| 免费成人小视频| 欧美在线综合视频| 久久九九全国免费| 精品一区中文字幕| 欧美日韩电影在线播放| 国产精品盗摄一区二区三区| 手机精品视频在线观看| 91视频你懂的| 欧美激情一二三区| 九九国产精品视频| 欧美一级欧美一级在线播放| 亚洲免费观看高清完整版在线观看熊| 日本少妇一区二区| 欧美一区二区网站| 五月婷婷欧美视频| 欧美日韩一级黄| 亚洲v日本v欧美v久久精品| 99国产精品国产精品久久| 欧美国产综合色视频| 粉嫩aⅴ一区二区三区四区 | 有码一区二区三区| 91九色02白丝porn| 一区二区三区电影在线播| 成人av免费在线| 一区二区三区免费网站| 欧美图区在线视频| 日韩精品乱码免费| 欧美精品一区二区三区很污很色的|