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

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

?? thread.cpp

?? 一個類似爬行的程序,用于了一些數學方法,能用的,也不錯的
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// InetThread.cpp : implementation file
//
/*******************************************
Pre-emptive Multithreading Web Spider
Copyright (c) 1998 by Sim Ayers.
*******************************************************************/

#include "stdafx.h"
#include "Spider.h"
#include "ThreadParams.h"
#include "Thread.h"
#include "utily.h"


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

extern 	HANDLE hConnection;
UINT g_nEntries = 0;
CArray<CEntry*, CEntry*> g_entry;
extern long lThreadCount;
extern long lURLCount;

static const TCHAR szHeaders[] = _T("Accept: text/*\r\n");

static const TCHAR AgentName[] = _T("XYZ Spider");

static DWORD dwHttpRequestFlags =	INTERNET_FLAG_EXISTING_CONNECT |  INTERNET_FLAG_RELOAD | INTERNET_FLAG_DONT_CACHE ; 

static DWORD dwHttpRequestFlags2 =	INTERNET_FLAG_EXISTING_CONNECT |  INTERNET_FLAG_RELOAD | INTERNET_FLAG_DONT_CACHE |INTERNET_FLAG_NO_AUTO_REDIRECT;


void CMyInternetSession::OnStatusCallback(DWORD  dwContext , DWORD dwInternetStatus,
	LPVOID  lpvStatusInformation , DWORD  dwStatusInformationLen )
{
	
	CString strStatus= "";
	
	switch(dwInternetStatus)
	{
	case INTERNET_STATUS_STATE_CHANGE:	
		strStatus="Busy";
		break;

	case INTERNET_STATUS_REQUEST_COMPLETE:
		strStatus="request complete";
		break;
	case INTERNET_STATUS_CONNECTING_TO_SERVER:
		strStatus="Connecting to server...";
		break;

	case INTERNET_STATUS_RESOLVING_NAME:
		strStatus.Format("resolving name for %s", lpvStatusInformation);
		break;
	case INTERNET_STATUS_NAME_RESOLVED:	
		strStatus.Format("resolved name for %s!", lpvStatusInformation);
		break;
	case INTERNET_STATUS_CONNECTED_TO_SERVER:
		strStatus="Connected to server!";
		break;
	case INTERNET_STATUS_SENDING_REQUEST:	
		strStatus="Sending request...";
		break;
	case INTERNET_STATUS_REQUEST_SENT:	
		strStatus="Request sent";
		break;
	case INTERNET_STATUS_RECEIVING_RESPONSE:
		strStatus="Receiving response...";
		break;
	case INTERNET_STATUS_RESPONSE_RECEIVED:	
		strStatus="Response received!";
		break;
	case INTERNET_STATUS_CLOSING_CONNECTION:
		strStatus="Closing connection...";
		break;
	case INTERNET_STATUS_CONNECTION_CLOSED:	
		strStatus="Connection close!";
		break;
	case INTERNET_STATUS_HANDLE_CLOSING:
		strStatus="Closing Connection...";
	case INTERNET_STATUS_HANDLE_CREATED:
		strStatus="Connection created!";
		break;
	case INTERNET_STATUS_REDIRECT:
		strStatus ="Redirected to URL";
		break;

	case INTERNET_STATUS_CTL_RESPONSE_RECEIVED:
	default:
		strStatus.Format("Unknown status: %d", dwInternetStatus);
		break;
	}

	LPCSTR line = strStatus;

	if(m_pMainWnd !=NULL)
	{
		::SendMessage (m_pMainWnd,WM_USER_SERVER_STATUS, 0,(LPARAM)line);
		LPCSTR lpstr = m_strHttpSite;
		::SendMessage (m_pMainWnd,WM_USER_THREAD_STATUS, 0,(LPARAM)lpstr);

	}

}

// simple worker thread Proc function
UINT CSpiderThread::ThreadFunc(LPVOID pParam)
{
	ThreadParams * lpThreadParams = (ThreadParams*) pParam;
	CSpiderThread* lpThread = (CSpiderThread*) lpThreadParams->m_pThread;
	
	lpThread->ThreadRun(lpThreadParams);

	// Use  SendMessage instead of PostMessage here to keep the current thread count
	// Synchronizied. If the number of threads is greater than MAXIMUM_WAIT_OBJECTS (64)
	// the program will be come	 unresponsive to user input

	::SendMessage(lpThreadParams->m_hwndNotifyProgress,
		WM_USER_THREAD_DONE, 0, (LPARAM)lpThreadParams);  // deletes lpThreadParams and decrements the thread count

	return 0;
}

/////////////////////////////////////////////////////////////////////////////
// CSpiderThread


CSpiderThread::CSpiderThread(AFX_THREADPROC pfnThreadProc,ThreadParams *pThreadParams)
	:CWinThread(pfnThreadProc,pThreadParams)
{
	
	m_pSession = NULL;
	m_pServer =NULL;
	m_pFile= NULL;
	m_strCurrentServer = "";
	m_bDone = FALSE;
	pThreadParams->m_pThread = this;


}

CSpiderThread::~CSpiderThread()
{
	CleanUp();

}


void CSpiderThread::KillThread()
{
	// Note: this function is called in the context of other threads,
	//	not the thread itself.
	m_bDone = TRUE;
	CleanUp();
}



BOOL CSpiderThread::InitServer()
{
	
	try{
		m_pSession = new CMyInternetSession(AgentName,m_nThreadID);
		int ntimeOut = 30;  // very important, can cause a Server time-out if set to low
							// or hang the thread if set to high.
		/*
		The time-out value in milliseconds to use for Internet connection requests. 
		If a connection request takes longer than this timeout, the request is canceled.
		The default timeout is infinite. */
		m_pSession->SetOption(INTERNET_OPTION_CONNECT_TIMEOUT,1000* ntimeOut);
		
		/* The delay value in milliseconds to wait between connection retries.*/
		m_pSession->SetOption(INTERNET_OPTION_CONNECT_BACKOFF,1000);
		

		/* The retry count to use for Internet connection requests. If a connection 
		attempt still fails after the specified number of tries, the request is canceled.
		The default is five. */
		m_pSession->SetOption(INTERNET_OPTION_CONNECT_RETRIES,1);
        m_pSession->EnableStatusCallback(TRUE);

		}
		catch (CInternetException* pEx)
		{
			// catch errors from WinINet
			//pEx->ReportError();
			m_pSession = NULL;
			pEx->Delete();

			return FALSE ;
		}

	return TRUE;
}

BEGIN_MESSAGE_MAP(CSpiderThread, CWinThread)
	//{{AFX_MSG_MAP(CSpiderThread)
		// NOTE - the ClassWizard will add and remove mapping macros here.
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()


/////////////////////////////////////////////////////////////////////////////
// CSpiderThread message handlers


BOOL CSpiderThread::ThreadRun(ThreadParams *pThreadParams)
{
	
	CString str;

	BOOL bRun = FALSE;
	
	bRun = InitServer();
	if (!bRun)
		return bRun;

	if(pThreadParams->m_pszURL.IsEmpty()) return FALSE;
	if (m_bDone)
		return 0;

	m_pSession->m_pMainWnd = pThreadParams->m_hwndNotifyProgress;

	if(!ParseURL(pThreadParams)) return FALSE;
	
	PrintStatus(pThreadParams,pThreadParams->m_pszURL);

	switch(pThreadParams->m_type)
	{

	case HTTP_GET_FILE:

	if(!GetHttpFile(pThreadParams->m_strServerName, 
    pThreadParams->m_strObject,pThreadParams))
	{
		str.Format("Error in getting %s",(LPCTSTR)pThreadParams->m_pszURL);
		AfxMessageBox(str, MB_OK);
	}

	break;

	case HTTP_CHECK_URL_ROOT:

	if(GetHttpFile(pThreadParams->m_strServerName,pThreadParams->m_strObject, pThreadParams,FALSE))
	{
		if (m_bDone)
			return 0;

		CheckAllURLs(pThreadParams->m_strServerName,pThreadParams);

	}

	break;


	case HTTP_CHECK_URL:

	CheckURL(pThreadParams->m_strServerName, pThreadParams->m_strObject,pThreadParams);
	
	break;


	case HTTP_GET_HEADER:

	if(!GetServerHeader(pThreadParams->m_strServerName,pThreadParams->m_strObject,pThreadParams))
	{
		str.Format("Error in getting Server Response Header for\n%s",(LPCTSTR)pThreadParams->m_pszURL);
		AfxMessageBox(str, MB_OK);

	}

	break;

	}

	return TRUE;

}


BOOL CSpiderThread::GetServerHeader(LPCTSTR ServerName, LPCTSTR strObject,ThreadParams *pThreadParams)
{

	if(ServerName == NULL || strObject == NULL) return 0;

	DWORD dwRet = GetHttpStatus(ServerName, strObject);

	pThreadParams->m_Status = dwRet;

	if (m_bDone)
		return 0;
	
	if(dwRet <200  || dwRet > 400) return FALSE;

	if(m_pFile != NULL && m_pServer != NULL && m_pSession != NULL)
	{

			CString rString;
			m_pFile->QueryInfo(HTTP_QUERY_RAW_HEADERS_CRLF,rString);
			PrintLine(pThreadParams,rString);

	}
	
  return TRUE;

}

BOOL CSpiderThread::GetHttpFile(LPCTSTR ServerName,LPCTSTR strObject,ThreadParams *pThreadParams,BOOL ViewFile)
{

	CString rString;
	LPCTSTR lpsz;
	LPCTSTR lpszStop;
	int pdest,j=0;
	TCHAR sz[4096];
	memset(sz,'\0',sizeof(sz));
	pThreadParams->m_Contents = "";		

	if(strObject  == NULL) return FALSE;


	if(GetHttpStatus(ServerName, strObject)!= 200)
		return FALSE;
	if(m_pFile != NULL && m_pServer != NULL)
	{
		m_pFile->QueryInfo(HTTP_QUERY_CONTENT_TYPE,rString);
	
		pdest = rString.Find("text");
		if(pdest < 0 ) return FALSE;
	}

	if(m_pFile != NULL && m_pServer != NULL && m_pSession != NULL)
	{
		try
		{
			while (m_pFile->ReadString(sz, 4095))
			{
					rString = "";		
					lpsz = sz;
					if(lpsz != NULL)
					{
						lpszStop = sz + lstrlen(sz);
						j=0;
						while (lpsz < lpszStop)
						{
							if(*lpsz =='\n')	rString += "\r\n";

							else rString += sz[j];

							++lpsz;
							j++;

						}

						pThreadParams->m_Contents += rString;
					}
			}

		}

		catch (CInternetException* pEx)
		{
			// catch errors from WinINet
			//pEx->ReportError();
			m_pFile= NULL;
			pEx->Delete();
			return 0;
		}


		
	}

		
	if(ViewFile)
		::SendMessage(pThreadParams->m_hwndNotifyProgress,
				WM_USER_THREAD_FILE, pThreadParams->m_threadID, (LPARAM)pThreadParams);

	return TRUE;
}

int LookUpEntry(LPCTSTR pszURL)
{

	if(pszURL == NULL) return -1;
	
	CriticalSectionLock  plock;
	
	CString URL,strTemp;
	URL.Format("%s",(LPCTSTR)pszURL);
	int pdest = URL.Find(":");
	if(pdest>0)
		strTemp = URL.Right(URL.GetLength()-1 - pdest - 2);
	else
		strTemp = URL;

	int nRet = -1;
	for (UINT i = 0; i < g_nEntries; i ++)
	{
		if(strTemp.CompareNoCase(g_entry[i]->m_URL)==0)
		{
			nRet = i;
			break;
		}
	}


	return nRet;
}
int AddEntry(URLStatus * lpEntry)
{
	

	CriticalSectionLock  plock;
	
	if(lpEntry->m_URL.IsEmpty())
	{
	
		return -1;
	}
		
	for (UINT i = 0; i < g_nEntries; i ++)	{	// only add entry once
		if(lpEntry->m_URL.Compare(g_entry[i]->m_URL)==0)
		{
			
			return -1;
		}
	}

	CEntry* newEntry = new CEntry;

	newEntry->m_URL = lpEntry->m_URL;
	newEntry->m_URLPage = lpEntry->m_URLPage;

	newEntry->m_Status = lpEntry->m_Status;
	newEntry->m_StatusString = lpEntry->m_StatusString;
	newEntry->m_LastModified = lpEntry->m_LastModified;
	newEntry->m_ContentType = lpEntry->m_ContentType;
	newEntry->m_ContentLength = lpEntry->m_ContentLength;

	g_nEntries++;

	// store in the array and get retVal to pass to the view for updating
	int retVal = g_entry.Add(newEntry);

	return retVal;
}


BOOL CSpiderThread::CheckURL(LPCTSTR ServerName, LPCTSTR strObject,ThreadParams *pThreadParams)
{
	if(ServerName == NULL || strObject==NULL) return FALSE;
	DWORD dwRet;
	CString rString = "";
	rString.Format("%s%s",ServerName,strObject);

	int npos = LookUpEntry((LPCTSTR)rString);
	if (m_bDone)	return 0;

	if(npos >= 0  && g_entry[npos]->m_Status != ERROR_INTERNET_TIMEOUT) // just print the status out to the view window if we have already visited the web page in question
	{
		pThreadParams->m_pStatus.m_URL = rString;
		pThreadParams->m_pStatus.m_URLPage = pThreadParams->m_pszURL;
		pThreadParams->m_pStatus.m_Status = g_entry[npos]->m_Status;
		pThreadParams->m_pStatus.m_ContentType = g_entry[npos]->m_ContentType;
		pThreadParams->m_pStatus.m_ContentLength = g_entry[npos]->m_ContentLength;
		pThreadParams->m_pStatus.m_LastModified = g_entry[npos]->m_LastModified;
		pThreadParams->m_pStatus.m_StatusString = g_entry[npos]->m_StatusString;
	}

	else
	{
	
		dwRet = GetHttpStatus(ServerName, strObject);
		pThreadParams->m_Status = dwRet;

		pThreadParams->m_pStatus.m_URL = rString;
		pThreadParams->m_pStatus.m_URLPage = pThreadParams->m_pszURL;
		pThreadParams->m_pStatus.m_Status = dwRet;
		pThreadParams->m_pStatus.m_ContentType ="";
		pThreadParams->m_pStatus.m_ContentLength = "";
		pThreadParams->m_pStatus.m_LastModified ="";
		if (m_bDone)	return 0;

		if(m_pFile != NULL && m_pServer != NULL)
		{
			m_pFile->QueryInfo(HTTP_QUERY_CONTENT_TYPE,pThreadParams->m_pStatus.m_ContentType);
			m_pFile->QueryInfo(HTTP_QUERY_CONTENT_LENGTH,pThreadParams->m_pStatus.m_ContentLength);
			m_pFile->QueryInfo(HTTP_QUERY_LAST_MODIFIED,pThreadParams->m_pStatus.m_LastModified);
		}
		if (m_bDone)	return 0;

		switch(dwRet)
		{
		case 200:
				pThreadParams->m_pStatus.m_StatusString = _T("ok");
				break;
		case 301:
				pThreadParams->m_pStatus.m_StatusString = _T("redirected to a new URL");
				break;
		case 302:
				pThreadParams->m_pStatus.m_StatusString = _T("resides under a different URL");
				break;
		case 401:
				pThreadParams->m_pStatus.m_StatusString = _T("auth required");
				break;
		case 402:
				pThreadParams->m_pStatus.m_StatusString = _T("payment required");
				break;
		case 403:
				pThreadParams->m_pStatus.m_StatusString = _T("forbidden");
				break;
		case 404:
				pThreadParams->m_pStatus.m_StatusString = _T("not found");
				break;
		case 400:
				pThreadParams->m_pStatus.m_StatusString = _T("Unintelligble request");
				break;
		case 405:
				pThreadParams->m_pStatus.m_StatusString = _T("requested method not supported");
				break;
		case 500:
				pThreadParams->m_pStatus.m_StatusString = _T("Unknown server error");
				break;
		case 501:
				pThreadParams->m_pStatus.m_StatusString = _T("Not implemented on Server");
				break;
		case 502:
				pThreadParams->m_pStatus.m_StatusString = _T("Server temporarily overloaded,busy");
				break;
		case 503:
				pThreadParams->m_pStatus.m_StatusString = _T("Server capacity reached, busy");
				break;
		case ERROR_INTERNET_TIMEOUT:
				pThreadParams->m_pStatus.m_StatusString = _T("Connection timed out");
				break;
		case ERROR_INTERNET_INVALID_URL:
				pThreadParams->m_pStatus.m_StatusString = _T("URL is invalid");
				break;
		case ERROR_INTERNET_NAME_NOT_RESOLVED:
		case 12029: // this seems to be the error for unresolved host names
				pThreadParams->m_pStatus.m_StatusString = _T("Could not resolve host name. Check it, and try again");
				break;
		case ERROR_INTERNET_SHUTDOWN:
				pThreadParams->m_pStatus.m_StatusString = _T("Win32 internet functions have been shut down");
				break;
		case ERROR_INTERNET_CONNECTION_ABORTED:
				pThreadParams->m_pStatus.m_StatusString = _T("Connection was aborted prematurely");
				break;
		
		case 0:
		case 1:
		case 2:
		default:
				pThreadParams->m_pStatus.m_StatusString = _T("no connection");
				break;
		}
	}
	
	AddEntry(&pThreadParams->m_pStatus);
	if (m_bDone)	return 0;

		if(pThreadParams->m_hwndNotifyView != NULL)
			::SendMessage(pThreadParams->m_hwndNotifyView,WM_USER_CHECK_DONE, 0, (LPARAM) &pThreadParams->m_pStatus);

	
	if(dwRet != 200) return FALSE;

	
	return TRUE;
}
DWORD CSpiderThread::NewConnection(LPCTSTR ServerName,LPCTSTR strObject)
{

	if(ServerName  == NULL || strObject == NULL) return 0;
	DWORD dwRet =  HTTP_STATUS_OK;
   INTERNET_PORT nPort = INTERNET_DEFAULT_HTTP_PORT;

   try{
		m_pSession = new CMyInternetSession(ServerName,m_nThreadID);
		
		int ntimeOut = 30;
		/*
		The time-out value in milliseconds to use for Internet connection requests. 
		If a connection request takes longer than this timeout, the request is canceled.
		The default timeout is infinite. */
		m_pSession->SetOption(INTERNET_OPTION_CONNECT_TIMEOUT,1000* ntimeOut);
		
		/* The delay value in milliseconds to wait between connection retries.*/
		m_pSession->SetOption(INTERNET_OPTION_CONNECT_BACKOFF,1000);
		
		/* The retry count to use for Internet connection requests. If a connection 
		attempt still fails after the specified number of tries, the request is canceled.
		The default is five. */
		m_pSession->SetOption(INTERNET_OPTION_CONNECT_RETRIES,2);

     m_pSession->EnableStatusCallback(TRUE);
	m_pSession->m_strHttpSite.Format("%s%s",ServerName,strObject);


	}
	catch (CInternetException* pEx)
	{
		// catch errors from WinINet
		dwRet = pEx->m_dwError;
		m_pSession=NULL;
		pEx->Delete();
		return  dwRet;

	}

	try
	{

		m_pServer = m_pSession->GetHttpConnection(ServerName,nPort);
	}

	catch (CInternetException* pEx)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本在线播放一区二区三区| 欧美区视频在线观看| 亚洲天堂成人网| 日韩三级伦理片妻子的秘密按摩| 国产精品亚洲一区二区三区妖精| 一区二区三区中文字幕精品精品| 日韩一区二区中文字幕| 国产精品久久久久久久久免费樱桃 | www.99精品| 在线欧美日韩国产| 国产精品乱码人人做人人爱| 久久国产综合精品| 日韩美女视频在线| 7777精品伊人久久久大香线蕉完整版 | 1024精品合集| 精品国产一区二区三区不卡| 色天天综合色天天久久| 成人动漫中文字幕| 国产在线不卡视频| 日韩电影在线观看电影| 一卡二卡三卡日韩欧美| 国产精品婷婷午夜在线观看| 亚洲一区二区三区爽爽爽爽爽| 久久精品一区二区三区av| 91精品婷婷国产综合久久性色| 色网站国产精品| 91看片淫黄大片一级在线观看| 国产精品456露脸| 久久精品999| 日韩中文字幕麻豆| 亚洲夂夂婷婷色拍ww47| 亚洲乱码国产乱码精品精小说| 亚洲国产精品成人综合色在线婷婷| 欧美mv和日韩mv国产网站| 欧美一区二区三区喷汁尤物| 欧美视频一区在线| 欧美影视一区在线| 欧美亚洲一区二区三区四区| 色偷偷久久一区二区三区| 色综合中文字幕国产 | 欧美亚洲一区二区在线观看| 91视频在线观看| 色综合久久久久网| 色婷婷久久久亚洲一区二区三区| 成人18精品视频| 91在线视频在线| 在线免费亚洲电影| 欧洲精品在线观看| 欧美图区在线视频| 欧美日韩国产精品自在自线| 欧美裸体bbwbbwbbw| 欧美日韩久久一区| 欧美一级久久久久久久大片| 欧美一二三在线| 精品国产欧美一区二区| 久久久久久黄色| 中文欧美字幕免费| 亚洲免费在线视频| 老鸭窝一区二区久久精品| 日本乱码高清不卡字幕| 一本大道久久a久久精品综合| 欧美写真视频网站| 51午夜精品国产| 欧美精品一区二区三区在线播放| 26uuu久久天堂性欧美| 国产精品久线在线观看| 亚洲一区二区三区四区的| 免费成人美女在线观看| 成人免费电影视频| 欧美专区在线观看一区| 欧美日韩国产区一| 久久久久国产精品人| 自拍偷在线精品自拍偷无码专区| 午夜精品久久久久影视| 韩国精品久久久| 91首页免费视频| 欧美成人一级视频| 亚洲人xxxx| 精品亚洲国产成人av制服丝袜| 国产成人aaa| 欧美久久免费观看| 国产三级三级三级精品8ⅰ区| 亚洲精品国产无天堂网2021| 久久国产剧场电影| 日本道色综合久久| 欧美精品一区二区三区在线| 成人免费在线视频| 理论片日本一区| 91久久精品午夜一区二区| 欧美一级一级性生活免费录像| 欧美国产日韩亚洲一区| 日本欧美在线看| 日本久久一区二区三区| 26uuu精品一区二区| 亚洲成人高清在线| 成人免费va视频| 欧美mv日韩mv国产| 午夜电影一区二区三区| 白白色 亚洲乱淫| 日韩欧美精品在线视频| 亚洲激情五月婷婷| 国产成人夜色高潮福利影视| 欧美高清你懂得| 国产精品欧美一级免费| 8x8x8国产精品| 亚洲猫色日本管| 懂色av中文一区二区三区 | 97se亚洲国产综合自在线不卡| 欧美一区二区三区白人| 中文字幕佐山爱一区二区免费| 久久精品二区亚洲w码| 91精品国产综合久久久久久久 | 精品在线观看免费| 欧美日韩综合不卡| 无码av免费一区二区三区试看| 色哦色哦哦色天天综合| 亚洲视频 欧洲视频| 成人性生交大片免费| 国产精品麻豆视频| 99久久久精品免费观看国产蜜| 久久久www成人免费无遮挡大片| 蜜桃av噜噜一区| 久久久国产综合精品女国产盗摄| 国产美女娇喘av呻吟久久| 亚洲色图视频网站| 欧美一级免费观看| 欧洲精品中文字幕| 久久aⅴ国产欧美74aaa| 欧美tickle裸体挠脚心vk| 亚洲精品国产第一综合99久久 | 国产综合色精品一区二区三区| 极品少妇一区二区三区精品视频 | 午夜在线成人av| 日本精品视频一区二区| 日韩美女视频一区二区| aaa欧美色吧激情视频| 亚洲国产成人自拍| 成人免费高清在线| 国产精品久久久久天堂| 色悠悠久久综合| 亚洲一区二区欧美| 国产亚洲视频系列| 在线看国产日韩| 高清久久久久久| 亚洲美腿欧美偷拍| 日韩视频中午一区| 欧美在线免费播放| 国产在线视频不卡二| 日韩伦理电影网| 国产色产综合产在线视频| 亚洲欧美日韩国产成人精品影院| 日韩av中文字幕一区二区| 久久九九久久九九| 成人性生交大片免费看中文| 国产欧美精品一区二区色综合朱莉| 国产精品18久久久久久久久| 久久久91精品国产一区二区精品| 成人爽a毛片一区二区免费| 国产精品视频一二三区| 色综合久久中文综合久久97| 亚洲国产另类av| 日韩欧美卡一卡二| 粉嫩在线一区二区三区视频| 亚洲欧美日韩国产一区二区三区| 欧美蜜桃一区二区三区| 欧美三级电影网站| 亚洲观看高清完整版在线观看| 欧美一区欧美二区| 国产成人福利片| 一区二区三区在线播| 日韩女优av电影| 91丨九色丨尤物| 乱一区二区av| 亚洲人妖av一区二区| 91精品国产综合久久婷婷香蕉| 国产中文字幕一区| 一区二区三区在线观看动漫| 日韩精品一区二区三区三区免费| 99久久综合国产精品| 日本伊人午夜精品| 亚洲欧洲av在线| 精品久久久久久久久久久院品网| 99国产精品99久久久久久| 免费精品视频最新在线| |精品福利一区二区三区| 538在线一区二区精品国产| 成人高清视频免费观看| 日韩av一区二区三区四区| 日韩一区在线播放| 精品国产一区二区三区av性色| 91美女片黄在线观看| 精品亚洲国内自在自线福利| 一卡二卡三卡日韩欧美| 国产日韩欧美不卡| 911精品产国品一二三产区| 成人激情小说网站| 久久99精品国产91久久来源| 亚洲欧美日韩综合aⅴ视频| 欧美v日韩v国产v| 欧美日韩一本到|