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

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

?? smstraffic.cpp

?? 基于VC++6的GSM模塊收發短消息的程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// SmsTraffic.cpp: implementation of the CSmsTraffic class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "SmsTraffic.h"

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

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

CSmsTraffic::CSmsTraffic()
{
	m_nSendIn = 0;
	m_nSendOut = 0;
	m_nRecvIn = 0;
	m_nRecvOut = 0;
	m_nSendInTimeOut=0;
	m_nSendOutTimeOut=0;
	m_hKillThreadEvent = CreateEvent(NULL, TRUE, FALSE, NULL);
	m_hThreadKilledEvent = CreateEvent(NULL, TRUE, FALSE, NULL);

	InitializeCriticalSection(&m_csSend);
	InitializeCriticalSection(&m_csRecv);

	// 啟動子線程
	AfxBeginThread(SmThread, this, THREAD_PRIORITY_NORMAL);
}

CSmsTraffic::~CSmsTraffic()
{
	SetEvent(m_hKillThreadEvent);			// 發出關閉子線程的信號
	WaitForSingleObject(m_hThreadKilledEvent, INFINITE);	// 等待子線程關閉

	DeleteCriticalSection(&m_csSend);
	DeleteCriticalSection(&m_csRecv);

	CloseHandle(m_hKillThreadEvent);
	CloseHandle(m_hThreadKilledEvent);
}

// 將一條短消息放入發送隊列
bool CSmsTraffic::PutSendMessage(SM_PARAM* pparam)
{
	static int busy=0;
	if(busy)
		return 0;
	busy=1;
	bool Success = TRUE;
	int m_nSendIn_tmp=m_nSendIn,nDstLength;
	EnterCriticalSection(&m_csSend);
	if(pparam->TP_DCS==GSM_UCS2)
	{
		WCHAR wchar[1024];
		pparam->m_this_num=1;
		pparam->m_total_num=1;
		nDstLength = ::MultiByteToWideChar(CP_ACP, 0, pparam->TP_UD, -1, wchar, 1024);
		if(nDstLength>70)
			pparam->m_total_num=(nDstLength/66)+1;
		do 
		{
			if(nDstLength>70)
			{
				memset(pparam->TP_UD,0,sizeof(pparam->TP_UD));
				WideCharToMultiByte(CP_ACP, 0, wchar, 66, pparam->TP_UD, 160, NULL, NULL);
				memcpy(wchar,&wchar[66],(nDstLength-66)*2);
				nDstLength-=66;
			}
			else
			{
				memset(pparam->TP_UD,0,sizeof(pparam->TP_UD));
				WideCharToMultiByte(CP_ACP, 0, wchar, 70, pparam->TP_UD, 160, NULL, NULL);
				nDstLength=0;
			}
			memcpy(&m_SmSend[m_nSendIn_tmp], pparam, sizeof(SM_PARAM));
			m_nSendIn_tmp++;
			if (m_nSendIn_tmp >= MAX_SM_SEND)  m_nSendIn_tmp = 0;
			if(m_nSendIn_tmp==m_nSendOut)
			{
				Success=0;
				break;
			}
			pparam->m_this_num++;
		} while (nDstLength);
		
		if(Success)
			m_nSendIn=m_nSendIn_tmp;
	}
	else
	{
		memcpy(&m_SmSend[m_nSendIn], pparam, sizeof(SM_PARAM));
		
		m_nSendIn++;
		if (m_nSendIn >= MAX_SM_SEND)  m_nSendIn = 0;
		if(m_nSendIn==m_nSendOut)
			Success=0;
	}
	LeaveCriticalSection(&m_csSend);
	busy=0;
	return Success;
}

// 從發送隊列中取一條短消息
BOOL CSmsTraffic::GetSendMessage(SM_PARAM* pparam)
{
	BOOL fSuccess = FALSE;
	
	EnterCriticalSection(&m_csSend);
	int num=0,tmp;
	tmp=m_nSendOut;
	while(tmp!=m_nSendIn)
	{
		tmp++;
		if (tmp >= MAX_SM_SEND)  tmp = 0;
		num++;
	}
	tmp=m_nSendOutTimeOut;
	while(tmp!=m_nSendInTimeOut)
	{
		tmp++;
		if (tmp >= MAX_SM_SEND)  tmp = 0;
		num++;
	}
	m_WaitNum=num;
	if (m_nSendOut != m_nSendIn)
	{
		memcpy(pparam, &m_SmSend[m_nSendOut], sizeof(SM_PARAM));
		pparam->send_times=0;
		pparam->send_type=0;

		m_nSendOut++;
		if (m_nSendOut >= MAX_SM_SEND)  m_nSendOut = 0;

		fSuccess = TRUE;
	}
	else
	{
		if (m_nSendOutTimeOut != m_nSendInTimeOut)
		{
			memcpy(pparam, &m_SmSendTimeOut[m_nSendOutTimeOut], sizeof(SM_PARAM));
			pparam->send_times=0;
			pparam->send_type=1;
			
			m_nSendOutTimeOut++;
			if (m_nSendOutTimeOut >= MAX_SM_SEND)  m_nSendOutTimeOut = 0;
			
			fSuccess = TRUE;
		}
		
	}

	LeaveCriticalSection(&m_csSend);

	return fSuccess;
}

// 將短消息放入接收隊列
void CSmsTraffic::PutRecvMessage(SM_PARAM* pparam, int nCount)
{
	EnterCriticalSection(&m_csRecv);

	for (int i = 0; i < nCount; i++)
	{
		memcpy(&m_SmRecv[m_nRecvIn], pparam, sizeof(SM_PARAM));
	
		m_nRecvIn++;
		if (m_nRecvIn >= MAX_SM_RECV)  m_nRecvIn = 0;

		pparam++;
	}

	LeaveCriticalSection(&m_csRecv);
}

// 從接收隊列中取一條短消息
BOOL CSmsTraffic::GetRecvMessage(SM_PARAM* pparam)
{
	BOOL fSuccess = FALSE;

	EnterCriticalSection(&m_csRecv);

	if (m_nRecvOut != m_nRecvIn)
	{
		memcpy(pparam, &m_SmRecv[m_nRecvOut], sizeof(SM_PARAM));

		m_nRecvOut++;
		if (m_nRecvOut >= MAX_SM_RECV)  m_nRecvOut = 0;

		fSuccess = TRUE;
	}

	LeaveCriticalSection(&m_csRecv);

	return fSuccess;
}
void CSmsTraffic::SendTimeOut(SM_PARAM* pparam)
{
	if(pparam->send_type)
	{
//		m_nSendOutTimeOut++;
//		if (m_nSendOutTimeOut >= MAX_SM_SEND)  m_nSendOutTimeOut = 0;
	}
	else
	{
		memcpy(&m_SmSendTimeOut[m_nSendInTimeOut], pparam, sizeof(SM_PARAM));
		m_nSendInTimeOut++;
		if (m_nSendInTimeOut >= MAX_SM_SEND)  m_nSendInTimeOut = 0;
	}
}
UINT CSmsTraffic::SmThread(LPVOID lParam)
{
	CSmsTraffic* p=(CSmsTraffic *)lParam;	// this
	int nMsg;				// 收到短消息條數
	int nDelete;			// 目前正在刪除的短消息編號
	SM_BUFF buff;			// 接收短消息列表的緩沖區
	SM_PARAM param[256];	// 發送/接收短消息緩沖區
	CTime tmOrg, tmNow;		// 上次和現在的時間,計算超時用
	enum {
		stBeginRest,				// 開始休息/延時
		stContinueRest,				// 繼續休息/延時
		stSendMessageRequest,		// 發送短消息
		stSendMessageResponse,		// 讀取短消息列表到緩沖區
		stSendMessageWaitIdle,		// 發送不成功,等待GSM就緒
		stReadMessageRequest,		// 發送讀取短消息列表的命令
		stReadMessageResponse,		// 讀取短消息列表到緩沖區
		stDeleteMessageRequest,		// 刪除短消息
		stDeleteMessageResponse,	// 刪除短消息
		stDeleteMessageWaitIdle,	// 刪除不成功,等待GSM就緒
		stExitThread				// 退出
	} nState;				// 處理過程的狀態

	// 初始狀態
	nState = stBeginRest;

	// 發送和接收處理的狀態循環
	while (nState != stExitThread)
	{
		switch(nState)
		{
			case stBeginRest:
//				TRACE("State=stBeginRest\n");
				tmOrg = CTime::GetCurrentTime();
				nState = stContinueRest;
				break;

			case stContinueRest:
//				TRACE("State=stContinueRest\n");
				Sleep(300);
				tmNow = CTime::GetCurrentTime();
				if (p->GetSendMessage(&param[0]))
				{
					nState = stSendMessageRequest;	// 有待發短消息,就不休息了
				}
				else 
					if (tmNow - tmOrg >= 5)		// 待發短消息隊列空,休息5秒
					{
						nState = stReadMessageRequest;	// 轉到讀取短消息狀態
					}
					break;
					
			case stSendMessageRequest:
				//				TRACE("State=stSendMessageRequest\n");
				p->gsmSendMessage(&param[0]);
				memset(&buff, 0, sizeof(buff));
				tmOrg = CTime::GetCurrentTime();
				nState = stSendMessageResponse;
				break;

			case stSendMessageResponse:
//				TRACE("State=stSendMessageResponse\n");
				Sleep(100);
				tmNow = CTime::GetCurrentTime();
				switch (p->gsmGetResponse(&buff))
				{
					case GSM_OK: 
//						TRACE("  GSM_OK %d\n", tmNow - tmOrg);
						nState = stBeginRest;
						break;
					case GSM_ERR:
//						TRACE("  GSM_ERR %d\n", tmNow - tmOrg);
						nState = stSendMessageWaitIdle;
						break;
					default:
//						TRACE("  GSM_WAIT %d\n", tmNow - tmOrg);
						if (tmNow - tmOrg >= 10)		// 10秒超時
						{
//							TRACE("  Timeout!\n");
							nState = stSendMessageWaitIdle;
						}
				}
				break;

			case stSendMessageWaitIdle:
				param[0].send_times++;
				if(param[0].send_type)
					Sleep((5000));
				else
					Sleep(500);
				if(param[0].send_times>10)
				{
					p->SendTimeOut(&param[0]);
					nState = stBeginRest;
				}
				else
					nState = stSendMessageRequest;		// 超時次數未到繼續發送
				break;
				
			case stReadMessageRequest:
//				TRACE("State=stReadMessageRequest\n");
				p->gsmReadMessageList();
				memset(&buff, 0, sizeof(buff));
				tmOrg = CTime::GetCurrentTime();
				nState = stReadMessageResponse;
				break;

			case stReadMessageResponse:
//				TRACE("State=stReadMessageResponse\n");
				Sleep(100);
				tmNow = CTime::GetCurrentTime();
				switch (p->gsmGetResponse(&buff))
				{
					case GSM_OK: 
//						TRACE("  GSM_OK %d\n", tmNow - tmOrg);
						nMsg = p->gsmParseMessageList(param, &buff);
						if (nMsg > 0)
						{
							p->PutRecvMessage(param, nMsg);
							nDelete = 0;
							nState = stDeleteMessageRequest;
						}
						else
						{
							nState = stBeginRest;
						}
						break;
					case GSM_ERR:
//						TRACE("  GSM_ERR %d\n", tmNow - tmOrg);
						nState = stBeginRest;
						break;
					default:
//						TRACE("  GSM_WAIT %d\n", tmNow - tmOrg);
						if (tmNow - tmOrg >= 15)		// 15秒超時
						{
//							TRACE("  Timeout!\n");
							nState = stBeginRest;
						}
				}
				break;

			case stDeleteMessageRequest:
//				TRACE("State=stDeleteMessageRequest\n");
				if (nDelete < nMsg)
				{
					p->gsmDeleteMessage(param[nDelete].index);
					memset(&buff, 0, sizeof(buff));
					tmOrg = CTime::GetCurrentTime();
					nState = stDeleteMessageResponse;
				}
				else
				{
					nState = stBeginRest;
				}
				break;

			case stDeleteMessageResponse:
//				TRACE("State=stDeleteMessageResponse\n");
				Sleep(100);
				tmNow = CTime::GetCurrentTime();
				switch (p->gsmGetResponse(&buff))
				{
					case GSM_OK: 
//						TRACE("  GSM_OK %d\n", tmNow - tmOrg);
						nDelete++;
						nState = stDeleteMessageRequest;
						break;
					case GSM_ERR:
//						TRACE("  GSM_ERR %d\n", tmNow - tmOrg);
						nState = stDeleteMessageWaitIdle;
						break;
					default:
//						TRACE("  GSM_WAIT %d\n", tmNow - tmOrg);
						if (tmNow - tmOrg >= 5)		// 5秒超時
						{
//							TRACE("  Timeout!\n");
							nState = stBeginRest;
						}
				}
				break;

			case stDeleteMessageWaitIdle:
//				TRACE("State=stDeleteMessageWaitIdle\n");
				Sleep(500);
				nState = stDeleteMessageRequest;		// 直到刪除成功為止
				break;
		}

		// 檢測是否有關閉本線程的信號
		DWORD dwEvent = WaitForSingleObject(p->m_hKillThreadEvent, 20);
		if (dwEvent == WAIT_OBJECT_0)  nState = stExitThread;
	}

	// 置該線程結束標志
	SetEvent(p->m_hThreadKilledEvent);

	return 9999;
}
// 可打印字符串轉換為字節數據
// 如:"C8329BFD0E01" --> {0xC8, 0x32, 0x9B, 0xFD, 0x0E, 0x01}
// 輸入: pSrc - 源字符串指針
//       nSrcLength - 源字符串長度
// 輸出: pDst - 目標數據指針
// 返回: 目標數據長度
int CSmsTraffic::gsmString2Bytes(const char* pSrc, unsigned char* pDst, int nSrcLength)
{
	for (int i = 0; i < nSrcLength; i += 2)
	{
		// 輸出高4位
		if ((*pSrc >= '0') && (*pSrc <= '9'))
		{
			*pDst = (*pSrc - '0') << 4;
		}
		else
		{
			*pDst = (*pSrc - 'A' + 10) << 4;
		}

		pSrc++;

		// 輸出低4位
		if ((*pSrc>='0') && (*pSrc<='9'))
		{
			*pDst |= *pSrc - '0';
		}
		else
		{
			*pDst |= *pSrc - 'A' + 10;
		}

		pSrc++;
		pDst++;
	}

	// 返回目標數據長度
	return (nSrcLength / 2);
}

// 字節數據轉換為可打印字符串
// 如:{0xC8, 0x32, 0x9B, 0xFD, 0x0E, 0x01} --> "C8329BFD0E01" 
// 輸入: pSrc - 源數據指針
//       nSrcLength - 源數據長度
// 輸出: pDst - 目標字符串指針
// 返回: 目標字符串長度
 int CSmsTraffic::gsmBytes2String(const unsigned char* pSrc, char* pDst, int nSrcLength)
{
	const char tab[]="0123456789ABCDEF";	// 0x0-0xf的字符查找表

	for (int i = 0; i < nSrcLength; i++)
	{
		*pDst++ = tab[*pSrc >> 4];		// 輸出高4位
		*pDst++ = tab[*pSrc & 0x0f];	// 輸出低4位
		pSrc++;
	}

	// 輸出字符串加個結束符
	*pDst = '\0';

	// 返回目標字符串長度
	return (nSrcLength * 2);
}

// 7bit編碼
// 輸入: pSrc - 源字符串指針
//       nSrcLength - 源字符串長度
// 輸出: pDst - 目標編碼串指針
// 返回: 目標編碼串長度
int CSmsTraffic::gsmEncode7bit(const char* pSrc, unsigned char* pDst, int nSrcLength)
{
	int nSrc;		// 源字符串的計數值
	int nDst;		// 目標編碼串的計數值
	int nChar;		// 當前正在處理的組內字符字節的序號,范圍是0-7
	unsigned char nLeft;	// 上一字節殘余的數據

	// 計數值初始化
	nSrc = 0;
	nDst = 0;

	// 將源串每8個字節分為一組,壓縮成7個字節
	// 循環該處理過程,直至源串被處理完
	// 如果分組不到8字節,也能正確處理
	while (nSrc < nSrcLength)
	{
		// 取源字符串的計數值的最低3位
		nChar = nSrc & 7;

		// 處理源串的每個字節
		if(nChar == 0)
		{
			// 組內第一個字節,只是保存起來,待處理下一個字節時使用
			nLeft = *pSrc;
		}
		else
		{
			// 組內其它字節,將其右邊部分與殘余數據相加,得到一個目標編碼字節
			*pDst = (*pSrc << (8-nChar)) | nLeft;

			// 將該字節剩下的左邊部分,作為殘余數據保存起來
			nLeft = *pSrc >> nChar;

			// 修改目標串的指針和計數值
			pDst++;
			nDst++;
		}

		// 修改源串的指針和計數值
		pSrc++;
		nSrc++;
	}

	// 返回目標串長度
	return nDst;
}

// 7bit解碼
// 輸入: pSrc - 源編碼串指針
//       nSrcLength - 源編碼串長度
// 輸出: pDst - 目標字符串指針
// 返回: 目標字符串長度
int CSmsTraffic::gsmDecode7bit(const unsigned char* pSrc, char* pDst, int nSrcLength)
{
	int nSrc;		// 源字符串的計數值
	int nDst;		// 目標解碼串的計數值
	int nByte;		// 當前正在處理的組內字節的序號,范圍是0-6
	unsigned char nLeft;	// 上一字節殘余的數據

	// 計數值初始化
	nSrc = 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜日韩在线电影| 亚洲成av人片一区二区三区| 一区二区三区高清| 久久精品久久精品| 色悠悠久久综合| 精品av久久707| 亚洲123区在线观看| 99久久99精品久久久久久| 欧美电影免费观看高清完整版在| 亚洲精品网站在线观看| 国产成人精品免费在线| 日韩一级在线观看| 五月天精品一区二区三区| 99re66热这里只有精品3直播 | 精品亚洲成av人在线观看| 精品视频免费看| 亚洲素人一区二区| 成人国产精品免费观看动漫| 精品国产91乱码一区二区三区 | 国产精品国产三级国产普通话三级 | 裸体在线国模精品偷拍| 欧美午夜理伦三级在线观看| ...xxx性欧美| 99国产麻豆精品| 国产精品色在线| 成人动漫在线一区| 国产精品久久毛片av大全日韩| 国产成人午夜精品影院观看视频| 精品国免费一区二区三区| 美腿丝袜亚洲三区| 精品日韩在线观看| 韩国av一区二区三区四区| 精品国产乱码久久久久久牛牛| 日韩国产高清影视| 日韩精品一区二区三区四区| 久久国产生活片100| 日韩免费观看高清完整版在线观看| 日本aⅴ亚洲精品中文乱码| 91精品久久久久久蜜臀| 免费成人美女在线观看.| 日韩美女主播在线视频一区二区三区| 日韩精品亚洲一区二区三区免费| 欧美久久婷婷综合色| 秋霞影院一区二区| 久久久噜噜噜久噜久久综合| 国产精品一区二区三区四区| 国产精品沙发午睡系列990531| eeuss鲁一区二区三区| 亚洲麻豆国产自偷在线| 欧美视频在线一区二区三区| 日本中文字幕不卡| 久久久久久99久久久精品网站| 国产成人精品一区二区三区四区| 亚洲三级在线播放| 欧美日本在线观看| 狠狠色狠狠色综合系列| 国产精品乱码人人做人人爱| 欧洲av在线精品| 久久99国产精品久久| 国产欧美日韩激情| 欧美中文字幕一二三区视频| 日本午夜一区二区| 国产欧美日韩在线| 欧洲国产伦久久久久久久| 久久成人免费网站| 成人免费在线播放视频| 欧美一区三区二区| zzijzzij亚洲日本少妇熟睡| 亚洲地区一二三色| 欧美激情中文字幕一区二区| 欧美日韩在线播放| 国产成人免费在线观看不卡| 亚洲aaa精品| 中文一区在线播放| 欧美一区二区三区四区在线观看| 成人午夜电影久久影院| 肉肉av福利一精品导航| 中文字幕亚洲一区二区va在线| 欧美日韩国产在线播放网站| 粉嫩一区二区三区性色av| 午夜激情一区二区三区| 国产精品超碰97尤物18| 欧美一区二区久久久| 色综合天天狠狠| 国产高清在线精品| 日产国产欧美视频一区精品| 亚洲永久免费av| 国产精品区一区二区三区| 日韩欧美一区中文| 欧美亚洲愉拍一区二区| 成人av网站在线| 国产精品资源网| 蜜臀av性久久久久av蜜臀妖精| 一个色综合网站| 亚洲少妇屁股交4| 国产欧美va欧美不卡在线| 日韩欧美色综合| 欧美视频中文一区二区三区在线观看 | 热久久久久久久| 亚洲成人精品在线观看| 亚洲久草在线视频| 国产精品欧美一级免费| 久久精品综合网| 久久久午夜精品| 久久噜噜亚洲综合| 久久综合色天天久久综合图片| 欧美一级高清片| 这里只有精品99re| 欧美一区二区私人影院日本| 欧美老女人第四色| 51精品秘密在线观看| 7777精品伊人久久久大香线蕉完整版 | 51精品视频一区二区三区| 欧美色成人综合| 欧美嫩在线观看| 欧美一区午夜精品| 亚洲精品在线电影| 久久久91精品国产一区二区三区| 久久综合一区二区| 国产亚洲精品aa| 中文字幕一区二区三区在线播放 | 亚洲精品va在线观看| 一二三区精品视频| 亚洲国产乱码最新视频| 亚洲成人黄色小说| 舔着乳尖日韩一区| 精品一区二区影视| 高清久久久久久| 色综合久久精品| 欧美日韩大陆在线| 精品少妇一区二区三区在线播放 | 欧美午夜精品理论片a级按摩| 8x8x8国产精品| 久久久国产精品麻豆| 亚洲国产激情av| 亚洲黄色av一区| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产美女视频一区| 99久久久无码国产精品| 欧美日韩卡一卡二| 久久免费午夜影院| 亚洲欧美aⅴ...| 免费观看一级欧美片| 成人性生交大片免费看视频在线| 色猫猫国产区一区二在线视频| 欧美人xxxx| 中文字幕av一区二区三区免费看| 亚洲一卡二卡三卡四卡无卡久久| 美国十次了思思久久精品导航| 大尺度一区二区| 在线成人av影院| 欧美极品美女视频| 日韩高清一级片| 成人动漫一区二区在线| 欧美一区二区黄| 18涩涩午夜精品.www| 久久99国产精品免费网站| 在线亚洲+欧美+日本专区| 欧美精品一区二区三区视频| 一区二区在线观看视频| 国产一区在线看| 欧美日韩一区国产| 国产精品素人视频| 美国欧美日韩国产在线播放| 91国产成人在线| 亚洲国产精品精华液ab| 免费观看91视频大全| 欧美日韩在线免费视频| 亚洲欧洲日韩av| 国产老妇另类xxxxx| 欧美日韩精品一区二区三区四区| 国产欧美一区二区精品性| 久久国产尿小便嘘嘘尿| 欧美三级视频在线| 一区二区中文视频| 国产超碰在线一区| 久久亚洲一区二区三区四区| 日韩激情一二三区| 欧美艳星brazzers| 亚洲欧美视频在线观看视频| 国产黄色成人av| 久久综合九色综合97_久久久| 丝袜诱惑亚洲看片| 欧美亚一区二区| 亚洲免费毛片网站| 91年精品国产| 国产精品二三区| av一区二区三区四区| 中文字幕巨乱亚洲| 国产精品一区二区视频| 久久久99久久| 粉嫩在线一区二区三区视频| 国产欧美一区二区精品婷婷 | 中文字幕亚洲精品在线观看| 成人小视频免费观看| 国产调教视频一区| 国产成人免费视频精品含羞草妖精| 亚洲精品一区二区三区99| 久久精品国产**网站演员| 精品少妇一区二区三区视频免付费|