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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

(44)MessageBoxA 监视器(过写拷贝,不使用 shellcode 注入)

發布時間:2025/3/21 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 (44)MessageBoxA 监视器(过写拷贝,不使用 shellcode 注入) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、研發背景

這是中級上保護模式和驅動開發章節的綜合練習。程序可以監視系統API調用,和三期的那個函數調用監視器不同,三期的只能HOOK本進程的API,而這個項目可以監視所有進程。

項目源碼:https://github.com/Kwansy98/MsgBoxAWatcher/tree/main

編譯環境是 VS2010 + WDK7600,運行環境是32位XP。

每個人做這個作業時都有不同的寫法,本文僅供參考,有什么疑問或建議,歡迎留言或私信,也可以加q群 1046088090 討論。

二、項目展示

程序輸出非常簡單,只要有進程調用了 MessageBoxA,監控程序就會打印。

這里并沒有把字符串也打印出來,原因有二:
一是要切換進程CR3讀字符串,再發給監控程序,工作量大(主要原因);
二是擴展性的考慮,我一開始是想監控所有user32.dll的導出函數的,所以直接傳參數的值(不經轉化)是最方便的。

三、涉及的技術

以下是老師在課堂上提到的,可能用到的主要的技術:

//1、自己寫代碼加載,卸載驅動程序
//2、段頁的知識;繞寫拷貝
//3、寫HOOK
//4、shellcode

老師說要用shellcode,是因為正常的做法是向某個系統dll注入shellcode,讓MessageBoxA執行時跳過去的,這是典型的Inline hook操作。

我的項目中沒有用這種方法,因此也就沒有涉及shellcode,以下是我在實際開發中使用的技術:

  • 驅動編程
  • 0環-3環通信常規方式(設備讀寫)
  • 修改PTE過寫拷貝
  • 調用門提權(我寫了一套API實現以系統權限調用用戶程序里的裸函數,支持傳參)
  • 中斷門HOOK(這個名字是我自己想的)
  • 設備擴展內存
  • 雙端鏈表模擬隊列

四、3環監控程序詳解

項目源碼:https://github.com/Kwansy98/MsgBoxAWatcher/tree/main

3環程序是一個控制臺程序,執行流程是非常清晰簡單的,只做了幾件事。

加載驅動

調用封裝函數 LoadDriver ,加載驅動,通過驅動,我們可以操作高2G的內存。

LoadDriver(DRIVER_NAME, DRIVER_PATH)

這個函數沒什么好說的,里面就是調用Windows API 加載驅動。

過寫拷貝

BypassApiWriteCopy();

寫拷貝我在之前的博客里介紹過:https://blog.csdn.net/Kwansy/article/details/109232856

過寫拷貝最簡單的辦法就是將線性地址的 R/W 位改成1,我就是這么做的,我把這步放在3環做了。為了操作頁表,我的代碼必須有系統權限,我的做法是用調用門提權,然后調用裸函數。

為了提高代碼復用,我寫了一套API,可以很方便地以0環權限調用應用程序里的裸函數。

這部分我覺得是我在這個項目里寫的最漂亮的代碼了= =

// 以0環權限調用某個裸函數,支持傳參 BOOL CallInRing0(PVOID pFuncion, PDWORD pParam, DWORD nParam);

有了這個函數,我們就可以很方便地過寫拷貝了。

// 過寫拷貝 void BypassApiWriteCopy() {// MessageBoxA 掛物理頁,不這樣操作,MessageBoxA的PTE可能是無效的__asm{mov eax, dword ptr ds:[MessageBoxA];mov eax,[eax];}// MessageBoxA過寫拷貝 DWORD pParam[3];pParam[0] = (DWORD)MessageBoxA;pParam[1] = (DWORD)GetPDE(pParam[0]);pParam[2] = (DWORD)GetPTE(pParam[0]);CallInRing0(BypassApiWriteCopyNaked, pParam,3); }

HOOK MessageBoxA

HOOK這步我也放在3環完成。分為兩步:

  • 首先在0環構造一個提權中斷門,返回中斷號,例如 0x20
  • 修改MessageBoxA頭兩字節的 mov edi,edi 指令,改成 INT 0x20,剛好也是2字節。
  • 當調用 MessageBoxA,就會觸發 0x20 中斷,跳轉到0環提供的監控函數里執行。這部分我留到待會介紹驅動的時候說。

    循環打印調用記錄

    HOOK 完成后,主函數進入一個死循環,不斷地從驅動里讀取 MessageBoxA 調用記錄,并打印到控制臺。當用戶輸入Q鍵,退出循環。

    收尾工作

    取消 HOOK,卸載驅動,打印提示程序結束的信息。

    // 取消HOOK ((PUSHORT)MessageBoxA)[0] = 0xff8b; UnLoadDriver(DRIVER_NAME); printf("敲任意按鍵退出程序.\n");

    五、驅動程序詳解

    項目源碼:https://github.com/Kwansy98/MsgBoxAWatcher/tree/main

    驅動是被動響應3環監控程序的,主要功能如下:

    • 為3環構造提權調用門,返回調用門描述符
    • 為3環構造提權中斷門,返回中斷號
    • HOOK API后,通過提權中斷門跳轉到監控函數
    • 返回API調用記錄給3環

    重點說一下監控函數,監控函數有兩個,一個是觸發中斷跳轉進去的裸函數,裸函數內部調用了另一個函數(裸函數里寫C代碼不方便)

    // User32.dll 導出函數的鉤子函數 // 調用方式:修改API函數頭2字節,使API函數觸發中斷,通過提權中斷門調用本函數 void __declspec(naked) User32ApiSpyNaked() {__asm{pushad; // esp - 0x20pushfd; // esp - 0x04mov eax,[esp + 0x24]; mov ecx,[esp + 0x24 + 0x0C];push eax; // EIP3push ecx; // ESP3call User32ApiSpy;popfd;popad;iretd;} }// 此處需要完成的工作:讀取3環EIP,判斷API來源,讀取3環ESP,獲取參數,傳給3環控制程序 void __stdcall User32ApiSpy(UINT32 ESP3, UINT32 EIP3) {UINT32 ApiAddress;// EIP3-0x02是API的地址// ESP3是3環的ESP,可以用來讀參數__asm push fs;ApiAddress = EIP3 - 2;//DbgPrint("ESP3: %08x, API: %08x\n", ESP3, ApiAddress);// 判斷API地址if (ApiAddress == 0x77d507ea){PAPICALLRECORD pApiCallRecord = NULL;// 添加調用記錄到隊列,監視進程通過IRP消息讀取隊列pApiCallRecord = (PAPICALLRECORD)ExAllocatePool(PagedPool,sizeof(APICALLRECORD));pApiCallRecord->nParam = 4;pApiCallRecord->pApiAddress = ApiAddress;pApiCallRecord->Param[0] = ((PUINT32)ESP3)[1];pApiCallRecord->Param[1] = ((PUINT32)ESP3)[2];pApiCallRecord->Param[2] = ((PUINT32)ESP3)[3];pApiCallRecord->Param[3] = ((PUINT32)ESP3)[4];PushApiCallQueue(&g_ApiCallRecordQueue, (PAPICALLRECORD)pApiCallRecord);}__asm pop fs; }

    可以看到,監控函數的工作就是記錄API的地址(判斷是哪個API,MessageBoxA還是別的什么函數),以及記錄參數,這些信息都會存儲到一個隊列里,然后3環監控程序請求數據的時候,就會從隊列里彈出數據返回給3環監控程序。

    為了存儲調用記錄,我定義了一個結構體和一套隊列操作的API,詳見代碼,此處不細說。

    // API調用記錄 typedef struct _APICALLRECORD {LIST_ENTRY ApiCallRecordList; // 鏈表UINT32 pApiAddress; // API函數地址UINT32 nParam; // 參數個數UINT32 Param[32]; // 參數列表 } APICALLRECORD, *PAPICALLRECORD;void InitApiCallQueue(IN PAPICALLRECORD QueueHead); void PushApiCallQueue(IN PAPICALLRECORD QueueHead, IN PAPICALLRECORD pApiCallRecord); void PopApiCallQueue(IN PAPICALLRECORD QueueHead, OUT PAPICALLRECORD * pApiCallRecord); UINT32 GetCountApiCallQueue(IN PAPICALLRECORD QueueHead); void FreeApiCallQueue(IN PAPICALLRECORD QueueHead);

    六、開發中遇到的坑點和難點

    坑點

    1、DebugPrint與push fs
    在裸函數內調用 DebugPrint,需要保存FS

    __asm push fs; DbgPrint(...); __asm pop fs;

    2、驅動中使用全局變量和static變量
    全局變量貌似可以用,但是static就建議不要用了,調用驅動的函數時,全局變量和static變量的地址會變,還會重新初始化,這方面細節我也不是很清楚。建議使用設備擴展內存代替。

    3、MessageBoxA 線性地址 PTE 無效的處理方法
    過寫拷貝前,先讀一下 MessageBoxA 里面的數據,否則 PTE 是無效的。

    難點

    1、3環提權調用裸函數框架
    這部分主要是傳參不好寫,我用了一個DWORD數組表示參數,用一個DWORD表示參數個數,然后循環push參數。詳細請看這個函數:

    // 以0環權限調用某個裸函數,支持傳參 BOOL CallInRing0(PVOID pFuncion, PDWORD pParam, DWORD nParam)

    2、遍歷GDT/IDT
    你也可以不遍歷,比如說 0x8003f048 和 0x8003f500 這兩個就是無效的GDT和 IDT ,可以直接用,但是不保證每次都好使。遍歷的代碼在這兩個函數里:

    // 構造提權中斷門,返回中斷號 USHORT SetIntGate(UINT32 pFuncion); // 構造提權調用門,返回調用門選擇子 USHORT SetCallGate(UINT32 pFunction, UINT32 nParam);

    3、驅動中實現隊列
    這個隊列是用來存API調用記錄的,方法比較多,我這里用雙向鏈表模擬隊列實現,詳細請看驅動部分的代碼。

    4、設備擴展內存

    // 創建設備 status = IoCreateDevice(pDriver,DeviceExtendSize,&DeviceName,FILE_DEVICE_UNKNOWN,FILE_DEVICE_SECURE_OPEN,FALSE,&pDeviceObj);

    創建設備時,第二個參數是設備擴展內存的大小,你可以在這申請一塊非分頁內存,只要設備還在,就都可以用,可以用它代替全局變量。

    七、完整代碼

    雖然已經上傳了github,但是還是在這里也留一個備份吧。

    驅動

    #include <ntifs.h> #include <wdm.h>#define DEVICE_NAME L"\\Device\\MsgBoxAWatcherDriverDev" #define DRIVER_LINK L"\\??\\MsgBoxAWatcherDriverLnk"// 申請了4KB設備擴展內存,用于替代全局變量 // 0-3字節:調用門描述符地址(GDT) // 4-7字節:中斷門描述符地址(IDT) #define DeviceExtendSize 0x1000// 3環發 IRP_MJ_DEVICE_CONTROL 的操作編號 #define OPER_CALL_GATE_R0 CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) #define OPER_HOOK CTL_CODE(FILE_DEVICE_UNKNOWN,0x801,METHOD_BUFFERED,FILE_ANY_ACCESS) #define OPER_GET_APICALLRECORD CTL_CODE(FILE_DEVICE_UNKNOWN,0x802,METHOD_BUFFERED,FILE_ANY_ACCESS)// 結構聲明 typedef struct _LDR_DATA_TABLE_ENTRY {LIST_ENTRY InLoadOrderLinks;LIST_ENTRY InMemoryOrderLinks;LIST_ENTRY InInitializationOrderLinks;PVOID DllBase;PVOID EntryPoint;UINT32 SizeOfImage;UNICODE_STRING FullDllName;UNICODE_STRING BaseDllName;UINT32 Flags;USHORT LoadCount;USHORT TlsIndex;LIST_ENTRY HashLinks;PVOID SectionPointer;UINT32 CheckSum;UINT32 TimeDateStamp;PVOID LoadedImports;PVOID EntryPointActivationContext;PVOID PatchInformation; } LDR_DATA_TABLE_ENTRY, *PLDR_DATA_TABLE_ENTRY;// API調用記錄 typedef struct _APICALLRECORD {LIST_ENTRY ApiCallRecordList; // 鏈表UINT32 pApiAddress; // API函數地址UINT32 nParam; // 參數個數UINT32 Param[32]; // 參數列表 } APICALLRECORD, *PAPICALLRECORD;// 全局變量 PDEVICE_OBJECT g_pDevObj = NULL; // 自定義設備,用于和3環通信 APICALLRECORD g_ApiCallRecordQueue = { 0 }; // API調用記錄隊列,不要直接操作該鏈表,使用程序提供的API// 函數聲明 NTSTATUS DriverEntry(PDRIVER_OBJECT pDriver, PUNICODE_STRING RegPath); VOID DriverUnload(PDRIVER_OBJECT pDriver); NTSTATUS IrpCreateProc(PDEVICE_OBJECT pDevObj, PIRP pIrp); NTSTATUS IrpCloseProc(PDEVICE_OBJECT pDevObj, PIRP pIrp); NTSTATUS IrpDeviceControlProc(PDEVICE_OBJECT pDevObj, PIRP pIrp); UINT32 *GetPDE(UINT32 addr); UINT32 *GetPTE(UINT32 addr); USHORT SetCallGate(UINT32 pFunction, UINT32 nParam); USHORT SetIntGate(UINT32 pFuncion); void User32ApiSpyNaked(); void __stdcall User32ApiSpy(UINT32 ESP3, UINT32 EIP3); void InitApiCallQueue(IN PAPICALLRECORD QueueHead); void PushApiCallQueue(IN PAPICALLRECORD QueueHead, IN PAPICALLRECORD pApiCallRecord); void PopApiCallQueue(IN PAPICALLRECORD QueueHead, OUT PAPICALLRECORD * pApiCallRecord); UINT32 GetCountApiCallQueue(IN PAPICALLRECORD QueueHead); void FreeApiCallQueue(IN PAPICALLRECORD QueueHead);// 入口函數 NTSTATUS DriverEntry(PDRIVER_OBJECT pDriver, PUNICODE_STRING RegPath){NTSTATUS status;ULONG uIndex = 0;PDEVICE_OBJECT pDeviceObj = NULL; // 設備對象指針UNICODE_STRING DeviceName; // 設備名,0環用UNICODE_STRING SymbolicLinkName; // 符號鏈接名,3環用// 初始化調用記錄隊列InitApiCallQueue(&g_ApiCallRecordQueue);// 創建設備名稱RtlInitUnicodeString(&DeviceName,DEVICE_NAME);// 創建設備 status = IoCreateDevice(pDriver,DeviceExtendSize,&DeviceName,FILE_DEVICE_UNKNOWN,FILE_DEVICE_SECURE_OPEN,FALSE,&pDeviceObj);if (status != STATUS_SUCCESS){IoDeleteDevice(pDeviceObj);DbgPrint("創建設備失敗.\n");return status;}// 全局變量依賴于設備擴展內存// 初始化全局設備指針g_pDevObj = pDeviceObj; // 初始化設備擴展數據memset(pDeviceObj->DeviceExtension,0,DeviceExtendSize);//DbgPrint("創建設備成功.\n");// 設置交互數據的方式pDeviceObj->Flags |= DO_BUFFERED_IO;// 創建符號鏈接RtlInitUnicodeString(&SymbolicLinkName, DRIVER_LINK);IoCreateSymbolicLink(&SymbolicLinkName, &DeviceName);// 設置分發函數pDriver->MajorFunction[IRP_MJ_CREATE] = IrpCreateProc;pDriver->MajorFunction[IRP_MJ_CLOSE] = IrpCloseProc;pDriver->MajorFunction[IRP_MJ_DEVICE_CONTROL] = IrpDeviceControlProc;// 設置卸載函數pDriver->DriverUnload = DriverUnload;return STATUS_SUCCESS; }// 卸載驅動 VOID DriverUnload(PDRIVER_OBJECT pDriver) {UNICODE_STRING SymbolicLinkName;// 刪除GDT表項中的調用門memset((PVOID)((PUINT32)(pDriver->DeviceObject->DeviceExtension))[0],0,8);// 刪除IDT表中的中斷門memset((PVOID)(((PUINT32)(pDriver->DeviceObject->DeviceExtension))[1]),0,8);// 釋放隊列內存//DbgPrint("隊列長度:%d\n", GetCountApiCallQueue(&g_ApiCallRecordQueue));FreeApiCallQueue(&g_ApiCallRecordQueue);//DbgPrint("隊列長度:%d\n", GetCountApiCallQueue(&g_ApiCallRecordQueue));// 刪除符號鏈接,刪除設備RtlInitUnicodeString(&SymbolicLinkName, DRIVER_LINK);IoDeleteSymbolicLink(&SymbolicLinkName);IoDeleteDevice(pDriver->DeviceObject);DbgPrint("驅動卸載成功\n"); }// 不設置這個函數,則Ring3調用CreateFile會返回1 // IRP_MJ_CREATE 處理函數 NTSTATUS IrpCreateProc(PDEVICE_OBJECT pDevObj, PIRP pIrp) {//DbgPrint("應用層連接設備.\n");// 返回狀態如果不設置,Ring3返回值是失敗pIrp->IoStatus.Status = STATUS_SUCCESS;pIrp->IoStatus.Information = 0;IoCompleteRequest(pIrp, IO_NO_INCREMENT);return STATUS_SUCCESS; }// IRP_MJ_CLOSE 處理函數 NTSTATUS IrpCloseProc(PDEVICE_OBJECT pDevObj, PIRP pIrp) {//DbgPrint("應用層斷開連接設備.\n");// 返回狀態如果不設置,Ring3返回值是失敗pIrp->IoStatus.Status = STATUS_SUCCESS;pIrp->IoStatus.Information = 0;IoCompleteRequest(pIrp, IO_NO_INCREMENT);return STATUS_SUCCESS; }// IRP_MJ_DEVICE_CONTROL 處理函數 NTSTATUS IrpDeviceControlProc(PDEVICE_OBJECT pDevObj, PIRP pIrp) {NTSTATUS status = STATUS_INVALID_DEVICE_REQUEST;PIO_STACK_LOCATION pIrpStack;ULONG uIoControlCode;PVOID pIoBuffer;ULONG uInLength;ULONG uOutLength;// 獲取IRP數據pIrpStack = IoGetCurrentIrpStackLocation(pIrp);// 獲取控制碼uIoControlCode = pIrpStack->Parameters.DeviceIoControl.IoControlCode;// 獲取緩沖區地址(輸入輸出是同一個)pIoBuffer = pIrp->AssociatedIrp.SystemBuffer;// Ring3 發送數據的長度uInLength = pIrpStack->Parameters.DeviceIoControl.InputBufferLength;// Ring0 發送數據的長度uOutLength = pIrpStack->Parameters.DeviceIoControl.OutputBufferLength;switch (uIoControlCode){case OPER_CALL_GATE_R0:{UINT32 pFunction; // 3環函數指針UINT32 nParam; // 參數個數// 給3環傳進來的函數指針設置一個調用門pFunction = ((PUINT32)pIoBuffer)[0];nParam = ((PUINT32)pIoBuffer)[1];// 設置狀態,返回數據((PUSHORT)pIoBuffer)[0] = SetCallGate(pFunction, nParam); // 返回調用門選擇子pIrp->IoStatus.Information = 2; // 返回給3環的數據量status = STATUS_SUCCESS;break;}case OPER_HOOK:{// 返回給3環的中斷號,3環根據中斷號HOOK APIUSHORT IntGateNum;// 構造提權中斷門IntGateNum = SetIntGate((UINT32)User32ApiSpyNaked);// 返回中斷號*(PUSHORT)pIoBuffer = IntGateNum;// 設置狀態,返回數據pIrp->IoStatus.Information = 2; // 返回給3環的數據量status = STATUS_SUCCESS;break;}case OPER_GET_APICALLRECORD:{PAPICALLRECORD record = NULL;PopApiCallQueue(&g_ApiCallRecordQueue, &record);if (record == NULL){// 設置狀態,返回數據pIrp->IoStatus.Information = 0; // 返回給3環的數據量status = STATUS_SUCCESS;}else{memcpy(pIoBuffer, record, sizeof(APICALLRECORD));// 設置狀態,返回數據pIrp->IoStatus.Information = sizeof(APICALLRECORD); // 返回給3環的數據量status = STATUS_SUCCESS;}break;}}// 返回狀態如果不設置,Ring3返回值是失敗pIrp->IoStatus.Status = status;IoCompleteRequest(pIrp, IO_NO_INCREMENT);return STATUS_SUCCESS; }// 構造提權中斷門,返回中斷號 USHORT SetIntGate(UINT32 pFuncion) { UCHAR IDT[6]; // IDT寄存器UINT32 IdtAddr,IdtLen;UINT32 IntGateHi = 0,IntGateLo = 0; // 中斷門描述符UINT32 *pPreIntGateAddr = (UINT32*)g_pDevObj->DeviceExtension + 1;UINT32 i;// 構造中斷門描述符IntGateLo = ((pFuncion & 0x0000FFFF) | 0x00080000);IntGateHi = ((pFuncion & 0xFFFF0000) | 0x0000EE00);// 遍歷IDT,找無效項__asm{sidt fword ptr IDT;}IdtAddr = *(PULONG)(IDT+2);IdtLen = *(PUSHORT)IDT;// 遍歷IDT,找一個P=0的(跳過第一項)if ((*pPreIntGateAddr) == 0){ for (i = 8; i < IdtLen; i+=8){if ((((PUINT32)(IdtAddr + i))[1] & 0x00008000) == 0){// P=0,此處GDT表項無效,可以使用((PUINT32)(IdtAddr + i))[0] = IntGateLo;((PUINT32)(IdtAddr + i))[1] = IntGateHi;(*pPreIntGateAddr) = IdtAddr + i; break;}}}else{((PUINT32)(*pPreIntGateAddr))[0] = IntGateLo;((PUINT32)(*pPreIntGateAddr))[1] = IntGateHi;}//DbgPrint("*pPreIntGateAddr: %p.\n", *pPreIntGateAddr);//DbgPrint("INT %02X\n", (USHORT)((*pPreIntGateAddr - IdtAddr) / 8));if (*pPreIntGateAddr == 0) return 0;return (USHORT)((*pPreIntGateAddr - IdtAddr) / 8); }// 構造提權調用門,返回調用門選擇子 USHORT SetCallGate(UINT32 pFunction, UINT32 nParam) { UINT32 CallGateHi = 0,CallGateLo = 0; // 調用門描述符UCHAR GDT[6]; // GDT寄存器UINT32 GdtAddr,GdtLen;UINT32 i;UINT32 *pPreCallGateAddr = (UINT32*)g_pDevObj->DeviceExtension;// 構造調用門CallGateHi = (pFunction & 0xFFFF0000);CallGateHi |= 0x0000EC00;CallGateHi |= nParam;CallGateLo = (pFunction & 0x0000FFFF);CallGateLo |= 0x00080000;// 獲取GDT基址和大小__asm{sgdt fword ptr GDT;}GdtAddr = *(PULONG)(GDT+2);GdtLen = *(PUSHORT)GDT;// 遍歷GDT,找一個P=0的(跳過第一項)if ((*pPreCallGateAddr) == 0){ for (i = 8; i < GdtLen; i+=8){//DbgPrint("%p\n",(PUINT32)(GdtAddr + i));if ((((PUINT32)(GdtAddr + i))[1] & 0x00008000) == 0){// P=0,此處GDT表項無效,可以使用((PUINT32)(GdtAddr + i))[0] = CallGateLo;((PUINT32)(GdtAddr + i))[1] = CallGateHi;(*pPreCallGateAddr) = GdtAddr + i;break;}}}else{((PUINT32)(*pPreCallGateAddr))[0] = CallGateLo;((PUINT32)(*pPreCallGateAddr))[1] = CallGateHi;}if (*pPreCallGateAddr == 0) return 0;return (USHORT)((*pPreCallGateAddr) - GdtAddr); }// 獲取PDE UINT32 *GetPDE(UINT32 addr) {return (UINT32 *)(0xc0600000 + ((addr >> 18) & 0x3ff8)); }// 獲取PTE UINT32 *GetPTE(UINT32 addr) {return (UINT32 *)(0xc0000000 + ((addr >> 9) & 0x7ffff8)); }// User32.dll 導出函數的鉤子函數 // 調用方式:修改API函數頭2字節,使API函數觸發中斷,通過提權中斷門調用本函數 void __declspec(naked) User32ApiSpyNaked() {__asm{pushad; // esp - 0x20pushfd; // esp - 0x04mov eax,[esp + 0x24]; mov ecx,[esp + 0x24 + 0x0C];push eax; // EIP3push ecx; // ESP3call User32ApiSpy;popfd;popad;iretd;} }// 此處需要完成的工作:讀取3環EIP,判斷API來源,讀取3環ESP,獲取參數,傳給3環控制程序 void __stdcall User32ApiSpy(UINT32 ESP3, UINT32 EIP3) {UINT32 ApiAddress;// EIP3-0x02是API的地址// ESP3是3環的ESP,可以用來讀參數__asm push fs;ApiAddress = EIP3 - 2;//DbgPrint("ESP3: %08x, API: %08x\n", ESP3, ApiAddress);// 判斷API地址if (ApiAddress == 0x77d507ea){PAPICALLRECORD pApiCallRecord = NULL;// 添加調用記錄到隊列,監視進程通過IRP消息讀取隊列pApiCallRecord = (PAPICALLRECORD)ExAllocatePool(PagedPool,sizeof(APICALLRECORD));pApiCallRecord->nParam = 4;pApiCallRecord->pApiAddress = ApiAddress;pApiCallRecord->Param[0] = ((PUINT32)ESP3)[1];pApiCallRecord->Param[1] = ((PUINT32)ESP3)[2];pApiCallRecord->Param[2] = ((PUINT32)ESP3)[3];pApiCallRecord->Param[3] = ((PUINT32)ESP3)[4];PushApiCallQueue(&g_ApiCallRecordQueue, (PAPICALLRECORD)pApiCallRecord);}__asm pop fs; }// 初始化隊列 void InitApiCallQueue(IN PAPICALLRECORD QueueHead) {QueueHead->ApiCallRecordList.Flink = QueueHead->ApiCallRecordList.Blink = (PLIST_ENTRY)QueueHead; }// 插入一條調用記錄到隊尾 void PushApiCallQueue(IN PAPICALLRECORD QueueHead, IN PAPICALLRECORD pApiCallRecord) {// 原隊尾的下一個節點指向新隊尾QueueHead->ApiCallRecordList.Blink->Flink = (PLIST_ENTRY)pApiCallRecord;// 新隊尾的上一個節點指向原隊尾pApiCallRecord->ApiCallRecordList.Blink = QueueHead->ApiCallRecordList.Blink;// 新隊尾的下一個節點指向隊列頭pApiCallRecord->ApiCallRecordList.Flink = (PLIST_ENTRY)QueueHead;// 隊列頭的上一個節點指向新隊尾QueueHead->ApiCallRecordList.Blink = (PLIST_ENTRY)pApiCallRecord; }// 從隊首彈出一條調用記錄 void PopApiCallQueue(IN PAPICALLRECORD QueueHead, OUT PAPICALLRECORD * pApiCallRecord) {// 記錄要彈出的節點*pApiCallRecord = (PAPICALLRECORD)(QueueHead->ApiCallRecordList.Flink);// 如果隊列為空,返回NULLif (*pApiCallRecord == &g_ApiCallRecordQueue){*pApiCallRecord = NULL;}// 第二個節點的上一個節點指向隊首QueueHead->ApiCallRecordList.Flink->Flink->Blink = (PLIST_ENTRY)QueueHead;// 隊首的下一個節點指向第二個節點QueueHead->ApiCallRecordList.Flink = QueueHead->ApiCallRecordList.Flink->Flink; }// 計算隊列長度 UINT32 GetCountApiCallQueue(IN PAPICALLRECORD QueueHead) {UINT32 cnt = 0;PLIST_ENTRY pList = QueueHead->ApiCallRecordList.Flink;while (pList != (PLIST_ENTRY)QueueHead){pList = pList->Flink;cnt++;}return cnt; }// 釋放隊列內存 void FreeApiCallQueue(IN PAPICALLRECORD QueueHead) {PAPICALLRECORD pApiCallRecord;while(QueueHead->ApiCallRecordList.Flink != (PLIST_ENTRY)QueueHead){ PopApiCallQueue(QueueHead, &pApiCallRecord);ExFreePool(pApiCallRecord);} }

    監控程序

    // MsgBoxAWatcher_Ring3.cpp : 定義控制臺應用程序的入口點。 // //1、自己寫代碼加載,卸載驅動程序 //2、段頁的知識;繞寫拷貝 //3、寫HOOK //4、shellcode#include "stdafx.h" #include <Windows.h>#define DRIVER_NAME L"MsgBoxAWatcher_Ring0" #define DRIVER_PATH L"MsgBoxAWatcher_Ring0.sys" #define DRIVER_LINK L"\\\\.\\MsgBoxAWatcherDriverLnk"#define OPER_CALL_GATE_R0 CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) #define OPER_HOOK CTL_CODE(FILE_DEVICE_UNKNOWN,0x801,METHOD_BUFFERED,FILE_ANY_ACCESS) #define OPER_GET_APICALLRECORD CTL_CODE(FILE_DEVICE_UNKNOWN,0x802,METHOD_BUFFERED,FILE_ANY_ACCESS)// API調用記錄父類 typedef struct _APICALLRECORD {LIST_ENTRY ApiCallRecordList; // 鏈表UINT32 pApiAddress; // API函數地址UINT32 nParam; // 參數個數UINT32 Param[32]; // 參數列表 } APICALLRECORD, *PAPICALLRECORD;BOOL LoadDriver(PCWSTR lpszDriverName, PCWSTR lpszDriverPath); void UnLoadDriver(PCWSTR lpszDriverName); DWORD *GetPDE(DWORD addr); DWORD *GetPTE(DWORD addr); USHORT CreateCallGate(DWORD pBaseAddress, DWORD nParam); BOOL CallInRing0(PVOID pFuncion, PDWORD pParam, DWORD nParam); void BypassApiWriteCopyNaked(); void BypassApiWriteCopy(); BOOL HookUser32Api(); void UpdateApiCallRecord();int _tmain(int argc, _TCHAR* argv[]) { // 加載驅動if (!LoadDriver(DRIVER_NAME, DRIVER_PATH)){printf("驅動服務加載失敗.\n");getchar();return 1;}else{printf("驅動服務加載成功.\n");}// 過寫拷貝BypassApiWriteCopy();// HOOK MessageBoxAif (HookUser32Api()){printf("HOOK MessageBoxA 成功,現在可以在其他程序里調用 MessageBoxA.\n"); }else{printf("HOOK MessageBoxA 失敗.\n");}// 讀取調用記錄UpdateApiCallRecord();// 取消HOOK((PUSHORT)MessageBoxA)[0] = 0xff8b;UnLoadDriver(DRIVER_NAME);printf("敲任意按鍵退出程序.\n");getchar();return 0; }// 加載驅動 BOOL LoadDriver(PCWSTR lpszDriverName, PCWSTR lpszDriverPath) {// 獲取驅動完整路徑WCHAR szDriverFullPath[MAX_PATH] = { 0 };GetFullPathNameW(lpszDriverPath,MAX_PATH,szDriverFullPath,NULL);//printf("%s\n", szDriverFullPath);// 打開服務控制管理器SC_HANDLE hServiceMgr = NULL; // SCM管理器句柄 hServiceMgr = OpenSCManagerW(NULL,NULL,SC_MANAGER_ALL_ACCESS);if (NULL == hServiceMgr){printf("OpenSCManagerW 失敗, %d\n", GetLastError());return FALSE;}//printf("打開服務控制管理器成功.\n");// 創建驅動服務SC_HANDLE hServiceDDK = NULL; // NT驅動程序服務句柄hServiceDDK = CreateServiceW(hServiceMgr,lpszDriverName,lpszDriverName,SERVICE_ALL_ACCESS,SERVICE_KERNEL_DRIVER,SERVICE_DEMAND_START,SERVICE_ERROR_IGNORE,szDriverFullPath,NULL,NULL,NULL,NULL,NULL);if (NULL == hServiceDDK){DWORD dwErr = GetLastError();if (dwErr != ERROR_IO_PENDING && dwErr != ERROR_SERVICE_EXISTS){printf("創建驅動服務失敗, %d\n", dwErr);return FALSE;}}//printf("創建驅動服務成功.\n");// 驅動服務已經創建,打開服務hServiceDDK = OpenServiceW(hServiceMgr,lpszDriverName,SERVICE_ALL_ACCESS);if (!StartService(hServiceDDK, NULL, NULL)){DWORD dwErr = GetLastError();if (dwErr != ERROR_SERVICE_ALREADY_RUNNING){printf("運行驅動服務失敗, %d\n", dwErr);return FALSE;}}//printf("運行驅動服務成功.\n");if (hServiceDDK){CloseServiceHandle(hServiceDDK);}if (hServiceMgr){CloseServiceHandle(hServiceMgr);}return TRUE; }// 卸載驅動 void UnLoadDriver(PCWSTR lpszDriverName) {SC_HANDLE hServiceMgr = OpenSCManagerW(0,0,SC_MANAGER_ALL_ACCESS);SC_HANDLE hServiceDDK = OpenServiceW(hServiceMgr,lpszDriverName,SERVICE_ALL_ACCESS);SERVICE_STATUS SvrStatus;ControlService(hServiceDDK,SERVICE_CONTROL_STOP,&SvrStatus);DeleteService(hServiceDDK);if (hServiceDDK){CloseServiceHandle(hServiceDDK);}if (hServiceMgr){CloseServiceHandle(hServiceMgr);} }// 獲取PDE DWORD *GetPDE(DWORD addr) {return (DWORD *)(0xc0600000 + ((addr >> 18) & 0x3ff8)); }// 獲取PTE DWORD *GetPTE(DWORD addr) {return (DWORD *)(0xc0000000 + ((addr >> 9) & 0x7ffff8)); }// 構建調用門(提權、有參) USHORT CreateCallGate(DWORD pBaseAddress, DWORD nParam) {HANDLE hDevice = CreateFileW(DRIVER_LINK,GENERIC_READ|GENERIC_WRITE,0,0,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,0);if (hDevice == INVALID_HANDLE_VALUE){return 0;}USHORT CallGateDescriptor; // 調用門選擇子DWORD dwRetBytes; // 返回的字節數DWORD InBuffer[2];InBuffer[0] = pBaseAddress;InBuffer[1] = nParam;DeviceIoControl(hDevice,OPER_CALL_GATE_R0,InBuffer,8,&CallGateDescriptor,sizeof(USHORT),&dwRetBytes,NULL);if (dwRetBytes != 2 || CallGateDescriptor == 0){printf("構造調用門失敗.\n");return 0;}CloseHandle(hDevice);return CallGateDescriptor; }// 以0環權限調用某個裸函數,支持傳參 BOOL CallInRing0(PVOID pFuncion, PDWORD pParam, DWORD nParam) {// 命令驅動構建調用門USHORT CallGateDescriptor = CreateCallGate((DWORD)pFuncion,nParam);if (CallGateDescriptor == 0){return FALSE;}// 構造調用門描述符USHORT buff[3] = {0};buff[2] = CallGateDescriptor;// 參數壓棧if (nParam && pParam){for (DWORD i = 0; i < nParam; i++){__asm{mov eax,pParam;push [eax];}pParam++;}} // 調用門調用__asm call fword ptr [buff]; // 長調用,使用調用門提權return TRUE; }// API函數過寫拷貝,其實就是將函數線性地址的PDE,PTE改成可寫 // 參數0:要過寫拷貝的函數地址 // 參數1:PDE線性地址 // 參數2:PTE線性地址 void __declspec(naked) BypassApiWriteCopyNaked() {__asm{pushad;pushfd;}__asm{ // R/W = 1, U/S = 1mov eax,[esp+0x24+0x8+0x0]; // 參數2,PTE的地址or dword ptr [eax],0x00000006;mov eax,[esp+0x24+0x8+0x4]; // 參數1,PDE的地址or dword ptr [eax],0x00000006;mov eax,[esp+0x24+0x8+0x8]; // 參數0,要過寫拷貝的函數地址invlpg [eax]; // 清除TLB緩存}__asm{popfd;popad;retf 0xC;} }// 過寫拷貝 void BypassApiWriteCopy() {// MessageBoxA 掛物理頁,不這樣操作,MessageBoxA的PTE可能是無效的__asm{mov eax, dword ptr ds:[MessageBoxA];mov eax,[eax];}// MessageBoxA過寫拷貝 DWORD pParam[3];pParam[0] = (DWORD)MessageBoxA;pParam[1] = (DWORD)GetPDE(pParam[0]);pParam[2] = (DWORD)GetPTE(pParam[0]);CallInRing0(BypassApiWriteCopyNaked, pParam,3); }// HOOK MessageBoxA // 理論上可以 HOOK User32.dll 里的任意函數 BOOL HookUser32Api() {HANDLE hDevice = CreateFileW(DRIVER_LINK,GENERIC_READ|GENERIC_WRITE,0,0,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,0);if (hDevice == INVALID_HANDLE_VALUE){printf("打開設備失敗.\n");return FALSE;}USHORT IntGateNum; // 中斷號DWORD dwRetBytes; // 返回的字節數DeviceIoControl(hDevice,OPER_HOOK,NULL,0,&IntGateNum,sizeof(USHORT),&dwRetBytes,NULL);if (dwRetBytes != 2 || IntGateNum == 0){printf("構造中斷門失敗.\n");return FALSE;}CloseHandle(hDevice);// HOOK MessageBoxAUSHORT IntInstructions = (IntGateNum << 8);IntInstructions |= (USHORT)0x00CD; *(PUSHORT)MessageBoxA = IntInstructions;return TRUE; }// 從驅動獲取調用記錄 void UpdateApiCallRecord() {HANDLE hDevice = CreateFileW(DRIVER_LINK,GENERIC_READ|GENERIC_WRITE,0,0,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,0);if (hDevice == INVALID_HANDLE_VALUE){printf("打開設備失敗.\n");return;}APICALLRECORD ApiCallRecord;DWORD dwRetBytes; // 返回的字節數while (!GetAsyncKeyState('Q')){Sleep(50);DeviceIoControl(hDevice,OPER_GET_APICALLRECORD,NULL,0,&ApiCallRecord,sizeof(ApiCallRecord),&dwRetBytes,NULL);if (dwRetBytes == 0) {//printf("無API調用記錄.\n");continue;}if (ApiCallRecord.pApiAddress == (DWORD)MessageBoxA){printf("MessageBoxA(%x, %x, %x, %x);\n", \ApiCallRecord.Param[0],ApiCallRecord.Param[1],ApiCallRecord.Param[2],ApiCallRecord.Param[3]);}}CloseHandle(hDevice); }

    總結

    以上是生活随笔為你收集整理的(44)MessageBoxA 监视器(过写拷贝,不使用 shellcode 注入)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    免费午夜在线视频 | 91成熟丰满女人少妇 | 西西人体4444www高清视频 | 日产乱码一二三区别免费 | 亚洲电影一区二区 | 日韩欧美一区二区三区在线 | 日韩免费在线观看视频 | 天天摸天天操天天舔 | 91丨九色丨国产丨porny精品 | 亚洲精品午夜久久久久久久久久久 | 欧美一级性视频 | 丝袜美腿在线 | 中文字幕亚洲欧美 | 日本精品视频一区 | 九九九九九九精品 | 狠狠色丁香九九婷婷综合五月 | 国产在线视频不卡 | 国产精品大片 | 一区二区三区在线免费观看 | www黄在线 | 国产在线视频一区 | 欧美精品久| 狠狠狠狠干| 精品成人a区在线观看 | 中文字幕在线观看完整 | 黄色软件在线看 | 99精品免费网 | 天天干夜夜操视频 | 在线中文字幕av观看 | 免费在线观看黄 | 黄色亚洲片 | 日本天天操| 国产色综合| 欧美精品黑人性xxxx | 精品亚洲成人 | 午夜视频在线观看一区二区三区 | .国产精品成人自产拍在线观看6 | 粉嫩av一区二区三区免费 | 婷婷射五月 | 69国产精品成人在线播放 | 日韩av免费观看网站 | 超碰在线97国产 | 97色综合| 日韩专区在线观看 | 亚洲mv大片欧洲mv大片免费 | 久久99中文字幕 | 国产一级大片在线观看 | 美女在线黄 | 国产一区二区三区免费视频 | 久久99在线观看 | 91亚洲精品国产 | 一区二区三区在线播放 | av成人在线播放 | 久久人人精品 | 国产视频1区2区3区 久久夜视频 | 久久婷婷视频 | 久久99九九99精品 | 91中文视频 | 亚洲精品免费在线观看视频 | 伊人伊成久久人综合网小说 | 爱av在线网| 免费男女羞羞的视频网站中文字幕 | 成人啊 v | 国产精品美女久久久久久久久久久 | 久久草在线视频国产 | 九九在线高清精品视频 | 久久精品这里热有精品 | 在线看中文字幕 | 久久8精品| 国产亚洲精品久久久久久久久久久久 | www免费网站在线观看 | 99免费看片 | 久草视频精品 | 韩国一区视频 | 亚洲久草网 | 日韩欧美在线中文字幕 | av高清网站在线观看 | 欧美日韩高清在线 | av成人免费观看 | 欧美日韩精品二区第二页 | 国产精品综合久久久 | 天天综合成人网 | 久久国产高清视频 | 美州a亚洲一视本频v色道 | 中文字幕在线观看播放 | 97在线视频观看 | 97香蕉久久国产在线观看 | 天天天天天天操 | 亚洲 欧美 精品 | 日韩av一区二区三区四区 | 夜夜操天天干 | 香蕉视频在线网站 | 精品国产一区二区三区久久久蜜月 | 97色资源| 麻豆国产视频下载 | 麻豆视频免费看 | 久草久草久草久草 | 久久久久国产一区二区 | 91看片在线 | 亚洲综合色视频在线观看 | 亚洲美女免费精品视频在线观看 | 国产成视频在线观看 | 黄色免费电影网站 | 911免费视频| 五月开心婷婷 | 99免费在线| 国产女人免费看a级丨片 | 久久人人爽爽 | 欧美成年网站 | 视频直播国产精品 | 久久精品成人 | 久久久久久久久电影 | 亚洲综合成人在线 | 97超碰在线免费观看 | 天天操夜夜操国产精品 | 国产美女精品 | 四虎影视久久久 | 日批在线观看 | 亚洲精品一区二区三区高潮 | 久久国产精品一区二区三区 | 久久久久国产成人免费精品免费 | 手机在线免费av | 中文字幕在线观看你懂的 | www.天天色.com| 欧美激情精品久久 | av线上免费观看 | 97在线观看视频国产 | 日韩精品免费在线视频 | 欧美精品一级视频 | 国产99色| 国产做aⅴ在线视频播放 | 99久精品 | 国产精品av在线免费观看 | 丁香激情视频 | 91传媒免费观看 | 字幕网资源站中文字幕 | 国内精品久久久久久久影视简单 | 久九视频 | 在线欧美a | 一级特黄aaa大片在线观看 | 亚洲精品中文字幕在线 | www.干| 欧美在线观看视频一区二区三区 | 久久伦理电影 | 亚洲一区二区麻豆 | 自拍超碰在线 | 91九色porn在线资源 | 久草视频在线免费播放 | 丁香婷婷综合激情五月色 | 中文字幕乱码电影 | 久久综合加勒比 | 天天操天天摸天天爽 | 三级小视频在线观看 | 在线国产片 | 91亚洲精品久久久蜜桃网站 | 69亚洲精品| 六月色| 麻豆免费视频网站 | av色网站 | 久久久久影视 | 日韩免费观看av | 色婷婷五 | 丁香激情网 | 国产成人福利在线 | 中文字幕久久亚洲 | 国产成在线观看免费视频 | 免费在线观看av网址 | 日本少妇久久久 | 激情综合五月天 | 中文字幕亚洲综合久久五月天色无吗'' | 91探花系列在线播放 | 91片黄在线观| 欧美色噜噜 | 在线观看岛国av | 91精品国自产在线观看 | 国产精品日韩欧美一区二区 | 精品中文字幕视频 | 天堂网一区二区三区 | 亚洲精品国产片 | 国产成人一区二区在线观看 | 国产精品成久久久久三级 | 久久久国产影视 | 狠狠色丁香久久婷婷综合五月 | 欧美一区二区免费在线观看 | 亚洲精品一区二区在线观看 | 久久综合九色综合97_ 久久久 | 午夜在线观看一区 | 国产精品专区h在线观看 | 在线免费观看国产黄色 | 亚洲免费在线观看视频 | 亚洲人成人在线 | 97精品国产97久久久久久免费 | 成片视频免费观看 | 色片网站在线观看 | 99色在线播放 | 久久精品国产第一区二区三区 | 国产综合香蕉五月婷在线 | 色噜噜狠狠色综合中国 | 色干综合 | 美女免费黄网站 | 国产99精品在线观看 | 91成年人网站 | 国产小视频网站 | 日韩av一卡二卡三卡 | 免费av在线 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 五月天堂网 | 国产一区二区在线免费 | 在线观看的av | 亚洲女同videos | 又黄又爽又无遮挡的视频 | 国产精品免费麻豆入口 | 国产中文字幕视频在线观看 | 久久久精品免费观看 | 日韩在线观看不卡 | 国产日产精品一区二区三区四区的观看方式 | 中文字幕丝袜一区二区 | 久久五月婷婷丁香社区 | 免费av网址在线观看 | 免费看色网站 | 中文成人字幕 | 国产不卡精品 | 99视 | 国产一区二区视频在线 | 97福利社 | 婷婷五月色综合 | 日韩精品中文字幕久久臀 | 久久99视频 | 亚洲综合欧美精品电影 | 国产无套精品久久久久久 | 成人免费在线观看av | 一区二区三区中文字幕在线 | 激情在线免费视频 | 99色视频在线| 视频三区| 久久经典国产 | 午夜精品一区二区三区免费 | 精产嫩模国品一二三区 | 久久久在线观看 | 中文字幕精 | 久久高视频 | 丁五月婷婷 | 毛片二区 | 国产精品精 | av电影免费在线看 | 国产成人久久精品一区二区三区 | 五月花婷婷 | 国产午夜一区二区 | 激情丁香 | 国产精品久久电影网 | 日韩精品三区四区 | 亚洲妇女av| 色综合 久久精品 | 懂色av一区二区三区蜜臀 | 99久久久久成人国产免费 | 国产视频在线免费 | 久久99精品久久久久久久久久久久 | 免费视频一级片 | 亚洲精品中文在线 | 手机在线黄色网址 | 国产小视频网站 | 丁香六月中文字幕 | 右手影院亚洲欧美 | 中文在线www| 欧美亚洲成人免费 | 91中文字幕在线 | 欧美a在线看 | 精品亚洲成a人在线观看 | 久久精品一二三区白丝高潮 | 亚洲黄色免费网站 | 国内精品视频在线 | 成年人免费电影 | 91大片网站| 人人插人人玩 | 岛国av在线不卡 | 色婷婷免费视频 | 国产精品一区二区久久精品爱涩 | 91精品国产高清自在线观看 | 天天色天天搞 | 五月婷香蕉久色在线看 | 四虎永久免费在线观看 | 精品国产自在精品国产精野外直播 | 久久久久久激情 | 一区二区三区三区在线 | 狠狠操天天射 | 日韩二区在线播放 | 99亚洲精品视频 | 日韩黄色免费看 | 午夜性色 | 97热久久免费频精品99 | av日韩国产 | 91.精品高清在线观看 | 九九九视频精品 | 欧美激情视频一区二区三区 | 丁香婷婷综合色啪 | 国产一区欧美在线 | a久久久久久 | 性色xxxxhd | 女人18片 | 欧美精品九九99久久 | 国产亚洲午夜高清国产拍精品 | 亚洲成人精品久久 | 日本精品久久久久中文字幕 | 亚洲.www| 在线视频精品 | av日韩av | 99国产情侣在线播放 | 免费a现在观看 | 国产探花视频在线播放 | 丁香花中文在线免费观看 | 四虎国产视频 | 婷婷色社区| 午夜精品久久久久久久99 | 日本深夜福利视频 | 天天色天天操综合 | 成人免费观看在线视频 | 91热爆视频 | 96看片 | 亚洲婷婷综合色高清在线 | 成年人看片 | 天天草视频 | 天天干天天爽 | 免费观看一级一片 | 99精品视频免费观看 | 97超级碰碰碰碰久久久久 | 国产精品毛片一区二区在线 | 欧美地下肉体性派对 | 久久国产精品99久久久久久老狼 | 中文免费在线观看 | 精品一区二区免费 | av高清免费 | 国产精品免费麻豆入口 | 91桃色视频| 国产成人不卡 | 久久黄视频 | 午夜久久影视 | 国产视频九色蝌蚪 | 国产午夜精品一区二区三区四区 | 24小时日本在线www免费的 | 久久久久免费电影 | 免费观看黄色av | 中文字幕亚洲综合久久五月天色无吗'' | 欧美激情综合色 | 日韩大片在线免费观看 | 婷婷色婷婷 | 蜜臀久久99精品久久久酒店新书 | 国内外成人在线 | 日韩在线大片 | 911久久香蕉国产线看观看 | 天天操夜夜摸 | 2022久久国产露脸精品国产 | 日韩精品一区二区三区中文字幕 | 色偷偷男人的天堂av | 天天色天天 | 久草免费新视频 | 天天色.com | 蜜臀av夜夜澡人人爽人人 | 97电影网手机版 | 精品一区二区在线看 | 91九色国产 | 天天射天天搞 | 亚洲精品人人 | av在线播放快速免费阴 | 午夜精品视频一区 | 日本在线视频一区二区三区 | 亚洲人成网站精品片在线观看 | 久久国产精品免费视频 | 中文十次啦 | 国产免费久久精品 | 久久一级电影 | 国产一区二区不卡视频 | 高清日韩一区二区 | 深夜福利视频在线观看 | 日韩高清久久 | 在线一二区| 伊人狠狠色 | 99久久精品国产系列 | 亚洲经典视频 | 午夜美女福利 | 日韩免费不卡av | 亚洲91精品在线观看 | 国产污视频在线观看 | 手机看片国产日韩 | 91九色在线视频观看 | 国产午夜激情视频 | 久久国产品 | 西西大胆啪啪 | 天天综合日 | 国产中文在线视频 | 韩国av一区二区 | av免费电影在线 | 精品国产免费一区二区三区五区 | 在线视频你懂 | 99精品免费观看 | 国产伦理一区二区三区 | 福利一区二区 | 精品国产视频在线观看 | 九九九在线 | 伊人久久国产精品 | 亚洲精品av在线 | 玖玖999| 欧美日韩国产在线一区 | 色婷婷播放 | av福利在线看 | 中文字幕在线观看第一区 | 国产成人99久久亚洲综合精品 | 日日夜夜噜噜噜 | 国产精品久久久久久久久久妇女 | 国产视频一区二区在线观看 | 美女露久久 | 久久久久久久国产精品 | 久久国产精品99久久久久久老狼 | 久久久蜜桃一区二区 | 国产亚洲日| 国产日韩精品一区二区在线观看播放 | 久久久久免费视频 | 9在线观看免费高清完整版在线观看明 | 精品国产一区二区三区日日嗨 | 亚洲国产成人精品在线 | 水蜜桃亚洲一二三四在线 | 99久久精品国 | 国产日本亚洲高清 | 一二三区视频在线 | 美女福利视频 | 天天操天天摸天天爽 | 久久久精品国产一区二区电影四季 | 在线观看av小说 | 中文字幕av一区二区三区四区 | 91视频麻豆 | 成人黄色大片在线免费观看 | 色偷偷88888欧美精品久久 | 亚洲干 | 视频国产精品 | 四虎www com | 色狠狠婷婷 | 亚洲最新av在线网站 | 福利一区视频 | 亚洲精品在线视频播放 | 国产成在线观看免费视频 | 亚洲黄色在线观看 | 欧美另类网站 | 人人添人人澡人人澡人人人爽 | 亚洲美女精品 | 国产做爰视频 | 日韩激情第一页 | 国产精品久久久999 国产91九色视频 | 亚洲一区网 | 97视频在线观看免费 | 伊人www22综合色 | 97福利| 午夜电影中文字幕 | 欧美亚洲一区二区在线 | 国产精品亚洲人在线观看 | 久久艹综合 | 3d黄动漫免费看 | 成人av教育 | 国产成人在线播放 | 婷婷色网视频在线播放 | 久久久亚洲网站 | 国产成人一区二区三区免费看 | 狠狠操综合网 | 久久国产精品影视 | 国产精品成人一区二区 | 国产精久久久 | 国产一区二区播放 | 国产亚洲婷婷免费 | 不卡av免费在线观看 | 亚洲午夜精品久久久久久久久 | 日韩在线观看一区二区 | 亚洲欧美国产精品va在线观看 | 美女视频a美女大全免费下载蜜臀 | 中文字幕免费高清在线观看 | 狠狠色狠狠色综合日日92 | 日本少妇久久久 | 国产va在线 | av在线短片| 日本在线免费看 | 91看片在线免费观看 | 日韩有码欧美 | 成年人在线看视频 | 久久论理 | 超碰国产97| 日本在线观看视频一区 | 国产亚洲一区二区在线观看 | 免费av观看网站 | av网站免费在线 | 久久天天草 | 日本性生活免费看 | 精品久久久久国产 | 肉色欧美久久久久久久免费看 | 日韩一区二区免费播放 | 最近日本韩国中文字幕 | 亚洲成av人片在线观看无 | 日韩黄色免费电影 | 中文字幕国产视频 | 三级av小说 | 丁香在线 | 黄色精品一区 | 日韩精品一区电影 | 蜜臀av性久久久久蜜臀av | 不卡精品视频 | 在线免费视频 你懂得 | 五月激情丁香 | 麻花豆传媒mv在线观看网站 | 在线观看完整版 | av大全免费在线观看 | 国产精品一区二区三区在线 | 狠狠色免费 | 成人免费91 | 日韩成人精品一区二区三区 | 黄色三级在线看 | 久久久免费电影 | 久久久久久久久久久久久国产精品 | 国产视频资源在线观看 | 婷婷精品在线 | 国产aaa大片| 91香蕉视频好色先生 | 97精品免费视频 | 国产亚洲在线 | 成人免费视频播放 | 亚洲国产无 | 一区二区三区av在线 | 韩国av免费观看 | 91一区二区三区久久久久国产乱 | 日韩精品在线视频免费观看 | 麻豆视频免费在线观看 | 久草视频免费在线播放 | 午夜视频免费在线观看 | 国内精品视频一区二区三区八戒 | 97在线观看免费高清完整版在线观看 | av电影久久 | 日p视频在线观看 | ,久久福利影视 | 日韩av免费观看网站 | a色视频| 依人成人综合网 | 黄色精品免费 | www.午夜 | 91夫妻视频 | 欧美精品免费一区二区 | 欧美一级片免费观看 | 日韩黄色在线电影 | 欧美激情操 | 久久免费国产电影 | 婷婷亚洲最大 | 丁香婷婷综合五月 | 免费的黄色的网站 | av 在线观看 | 91免费视频国产 | 在线观看中文字幕 | av黄色在线观看 | 精品1区2区3区 | 国产原创在线视频 | 黄色影院在线观看 | 91在线观看视频网站 | 少妇视频在线播放 | 欧美大片在线观看一区 | 久久久99精品免费观看 | 丁香婷婷久久久综合精品国产 | 日韩视频在线不卡 | 永久免费观看视频 | 8x成人免费视频 | av一级在线| 不卡精品视频 | av观看久久久 | 日本丶国产丶欧美色综合 | 在线 成人 | 日本中文不卡 | 国产一级片视频 | 日韩电影在线一区二区 | 日韩高清av在线 | 午夜av在线 | 日韩av黄 | 黄色毛片一级 | 久久一久久 | 色婷五月天 | 爱色婷婷| 婷婷网址| 亚av在线| 国产在线欧美在线 | 久久视频精品在线观看 | 97成人精品视频在线播放 | 国产99久久久精品 | 天天天操操操 | 亚洲另类久久 | 波多野结衣电影一区二区三区 | 亚洲天堂网视频在线观看 | 欧美在线日韩在线 | 亚洲精品国产欧美在线观看 | 国内精品久久久久久久影视简单 | 91高清视频免费 | 日韩一区二区三区在线看 | 国产精品久久久久久久久久久免费看 | 91av在线免费播放 | 久久久国产精品视频 | 国产视频精品久久 | 成人天堂网 | 国产色道 | 免费a视频 | 91欧美视频网站 | 免费久久久 | 久久一区二区三区四区 | 亚洲精品影视 | 精品播放 | 午夜精品久久久久久久99婷婷 | 亚洲视频综合在线 | 久久久www免费电影网 | 黄色免费视频在线观看 | 国产免费人人看 | 国产一二区免费视频 | 久久精品日本啪啪涩涩 | 一区二区精品国产 | 久久久这里有精品 | 久久久久国产成人免费精品免费 | 在线免费观看麻豆视频 | 成人一区电影 | 99精品国产在热久久下载 | 最近免费中文字幕mv在线视频3 | 天天操天天曰 | 国产精品自产拍在线观看桃花 | 日韩高清一二区 | 亚洲精品在线免费看 | 九色琪琪久久综合网天天 | 国产亚洲高清视频 | 免费中文字幕在线观看 | 欧美精品久久久久性色 | 美女免费视频一区 | 97视频人人澡人人爽 | 91精品网站在线观看 | 欧美激情另类文学 | 国产尤物在线 | 一本到在线| 午夜电影中文字幕 | 亚洲精品中文在线资源 | 午夜美女福利 | 日韩av手机在线看 | 婷婷伊人五月天 | 精品1区2区3区| 91精品一区二区三区蜜臀 | 日韩美女免费线视频 | 婷婷播播网 | 99色人| 国产香蕉av | 免费av小说 | 久久午夜精品视频 | 2023年中文无字幕文字 | 免费观看日韩 | 99久久久国产精品免费99 | 中文日韩在线 | 色综合天天综合 | 婷五月激情 | 久久天天综合网 | 黄色小视频在线观看免费 | 四虎国产免费 | 亚洲激情久久 | 亚洲一区在线看 | 国产毛片在线 | 在线观看小视频 | 久久看看 | 激情五月色播五月 | 精品一区二区三区在线播放 | 伊人狠狠操 | 五月综合在线观看 | 国产精品白浆 | a在线免费观看视频 | 国产一区二区不卡视频 | 亚洲日本国产精品 | 久久精品123 | 国内外激情视频 | 狠狠的操你 | 麻豆影视在线观看 | 日韩在线不卡av | 五月婷婷久 | 天天综合五月天 | 天天干天天干天天干天天干天天干天天干 | 国产一级免费观看 | 欧美aa一级 | 手机在线观看国产精品 | 九九热av| 97超碰色偷偷 | 久久 亚洲视频 | 又长又大又黑又粗欧美 | 狠狠的操狠狠的干 | 天天·日日日干 | 国产精品美女久久久久aⅴ 干干夜夜 | 亚洲精品大全 | 亚洲毛片一区二区三区 | 免费黄色av | 国产伦理久久精品久久久久_ | 国产一级一片免费播放放 | 丁香午夜婷婷 | 成人久久免费视频 | 日本公妇在线观看高清 | 91精品蜜桃 | 国产精品九九热 | 视频一区二区在线观看 | 国产精品一区二区在线 | 81国产精品久久久久久久久久 | 国产aa免费视频 | 日本黄色免费看 | 免费看片网址 | 国产中文字幕在线免费观看 | 日韩高清在线一区 | 国产黄视频在线观看 | 中文字幕影视 | 久久看片网 | 久久综合狠狠综合 | 亚洲精欧美一区二区精品 | 欧美日韩一级久久久久久免费看 | 六月丁香激情综合 | 九九综合久久 | 久久久污 | 国产这里只有精品 | 久久一区二区三区日韩 | 色综合久久88色综合天天6 | 在线99| 免费在线国产视频 | 91av电影| 久久久久久久久久网 | 97在线视频免费 | 亚洲2019精品 | 国产精品一区二区三区久久久 | 五月婷在线播放 | 国产精品免费在线播放 | 日韩二区精品 | 日本公妇在线观看高清 | 国际精品网 | 亚洲欧美日本国产 | 高清av免费一区中文字幕 | 在线观看一区二区精品 | 久久精品之 | 亚洲日韩中文字幕 | 久久精品区| 9ⅰ精品久久久久久久久中文字幕 | 久久综合偷偷噜噜噜色 | 美女免费视频一区 | 久久久国产一区 | 日韩a在线 | 亚洲精品乱码久久久久久9色 | 日日弄天天弄美女bbbb | 99精品欧美一区二区 | 中文在线亚洲 | 97精品国产97久久久久久久久久久久 | 视频一区二区在线观看 | 中文字幕一区二 | 午夜av在线电影 | 欧美经典久久 | 一个色综合网站 | 日本精品中文字幕在线观看 | 中文字幕亚洲五码 | 日日夜夜网| 国产黄色精品视频 | 国产小视频你懂的 | 日韩一区在线播放 | 久久人人精品 | 亚洲欧洲精品久久 | 在线观看视频福利 | 在线99热 | 97人人精品 | 99色在线| 伊人五月天 | av片在线观看免费 | 色搞搞 | 国产成人综合在线观看 | 日韩午夜精品 | 日韩啪啪小视频 | 99久久精品免费看国产四区 | 国产精品福利在线 | 顶级bbw搡bbbb搡bbbb | 人人干人人艹 | 亚洲精品视频第一页 | 在线精品一区二区 | 欧美日韩在线观看不卡 | 久久av网址 | 色综合五月天 | 日韩欧美区 | 久久综合色一综合色88 | av网站播放 | www.五月天婷婷 | 欧美日韩高清在线一区 | 国内小视频在线观看 | 日本成人a | 国产无遮挡又黄又爽馒头漫画 | 日韩高清不卡一区二区三区 | 免费网站看av片 | 西西大胆啪啪 | 色亚洲网 | 色五月色开心色婷婷色丁香 | 午夜资源站 | 精品国产伦一区二区三区观看说明 | 免费福利在线视频 | 久久在线 | 91亚洲在线观看 | 久久久久久久久久久影视 | 在线观看中文字幕2021 | 波多野结衣一区二区 | 久久久不卡影院 | 亚洲精品视频偷拍 | 99国产在线观看 | 国产精品一区二区三区四 | 国产精品久久久久久69 | 丁香电影小说免费视频观看 | 在线观看中文字幕网站 | 欧美色图p| 一级黄色片在线 | 中文字幕免费看 | 成人性生交大片免费观看网站 | 免费手机黄色网址 | 免费在线观看中文字幕 | 日日夜夜狠狠干 | 日韩视频免费 | 亚洲黄色免费在线 | 久草免费在线视频 | 国产成人在线免费观看 | 五月婷婷综合网 | 国产一区二区在线视频观看 | 日韩精品在线视频免费观看 | 有码中文字幕 | 91色网址 | 国产精品一区二区三区视频免费 | 国产91粉嫩白浆在线观看 | 欧美精品v国产精品 | 日韩免费一级a毛片在线播放一级 | 91精品国产一区 | 天天色天天射综合网 | 九九热视频在线免费观看 | 在线观看成人一级片 | 免费在线色电影 | 青青河边草观看完整版高清 | 97精品国产aⅴ | 一区二区三区四区在线 | 免费网站黄 | 免费三级影片 | 午夜免费在线观看 | 黄色在线观看污 | 亚洲国产精品第一区二区 | 五月婷婷综合在线 | 久久国产福利 | 亚洲免费在线看 | 九九99 | 国产麻豆剧果冻传媒视频播放量 | 久久久婷| 日韩va欧美va亚洲va久久 | 免费进去里的视频 | 欧美性爽爽| 中文字幕av全部资源www中文字幕在线观看 | 亚洲精品视频 | 九九免费在线观看视频 | 色婷婷88av视频一二三区 | 欧美性黄网官网 | 丝袜+亚洲+另类+欧美+变态 | 在线黄频| 香蕉影视| 久久久久久久久久久免费 | 日日爱夜夜爱 | 麻豆国产精品永久免费视频 | 亚洲视频99| www.天天色.com | 九九免费观看全部免费视频 | 狠狠色噜噜狠狠狠狠 | 久草在线中文视频 | 国产尤物在线视频 | 国产精品videoxxxx | 日韩啪啪小视频 | 中字幕视频在线永久在线观看免费 | 国产视频 亚洲精品 | 久久在线| 欧美日韩精品在线一区二区 | 国产三级精品三级在线观看 | 最近高清中文在线字幕在线观看 | a√资源在线 | avav片| 久久国产精品99久久久久久丝袜 | 91成熟丰满女人少妇 | 中文字幕乱视频 | 日韩一区二区三区高清在线观看 | 中国一级片在线观看 | 狠狠躁夜夜躁人人爽视频 | 日韩成人精品 | 久久久久久久久久免费视频 | 久久久午夜精品理论片中文字幕 | 国产成人精品999在线观看 | 欧洲精品码一区二区三区免费看 | 操久在线 | 97超碰人 | 日韩av女优视频 | 四虎成人免费影院 | 成人黄色片免费看 | 国产黄免费看 | 色久五月 | 一区二区三区 中文字幕 | 丁香六月伊人 | 久久久精品久久日韩一区综合 | 日韩午夜三级 | 天天碰天天操视频 | 日韩二区在线播放 | av黄在线播放 | 久久午夜免费观看 | 免费视频国产 | 精品欧美在线视频 | 日韩在线观看免费 | 久久久久久久久久久成人 | 97超碰人人看 | 欧美精品v国产精品 | 国内精品亚洲 | 在线观看视频在线观看 | 成+人+色综合 | 精品999久久久 | 久久免费在线视频 | 婷婷av网 | av免费线看 | 天天综合网在线 | 欧美人体xx | 激情五月***国产精品 | 久久精品久久精品久久39 | 国色天香永久免费 | 国产成人三级 | 国产韩国精品一区二区三区 | 久久女同性恋中文字幕 | 国产98色在线 | 日韩 | 91在线看| 国产在线观看,日本 | 日本精品视频在线观看 | 久草视频免费在线播放 | 91女人18片女毛片60分钟 | 中文字幕刺激在线 | 久久久久久久久久久久久久av | 日韩艹| 久久综合九色综合97婷婷女人 | www.com.日本一级 | 狠狠操精品 | 天堂中文在线视频 | 伊人精品在线 | 在线视频中文字幕一区 | 日韩精品一二三 | 国产又粗又硬又爽视频 | 少妇bbb搡bbbb搡bbbb′ | av网站在线观看播放 | 黄色片免费电影 | 99国产免费网址 | 国产糖心vlog在线观看 | 日日干av| 日韩系列在线观看 | 激情综合亚洲精品 | 国产麻豆剧果冻传媒视频播放量 | 在线观看不卡的av | 在线不卡视频 | 手机看片中文字幕 | 国产97色在线 | 久草精品视频在线播放 | 精品在线观 | 91理论片午午伦夜理片久久 | 成人a在线观看 | 久久精品理论 | 久久爱资源网 | 成全免费观看视频 | 九九热在线视频 | 久久99精品国产91久久来源 | 亚洲一级二级 | 国产视频在线看 | 婷婷中文在线 | 日本久久不卡视频 | 国产精品1区2区3区在线观看 | 在线国产福利 | 国产一级免费片 | av成人在线网站 | 久久精品国产成人精品 | 99精品视频在线观看 | 久久人人插 | 国产九色在线播放九色 | 午夜精品久久久久99热app | 在线观看视频你懂的 | 免费看三片 | 精品91 | 看毛片的网址 | 国内外成人在线 | 久久综合九色综合久99 | 国产美女免费视频 | 久久免费av | 国产精品第二页 | 成人av免费在线看 | 国产成人精品综合久久久久99 | 中文字幕免费观看 | 亚洲在线黄色 | 亚洲丝袜中文 | 天天视频色 | 狠狠干天天干 | 日韩av在线一区二区 | 国产精品毛片一区二区在线看 | 黄色录像av| 精品国产一区在线观看 | 91成人精品 | 久久久久成人精品亚洲国产 | 18+视频网站链接 | 欧美亚洲专区 | 狠狠干 狠狠操 | 国产一区二区高清不卡 | 亚洲成人黄色网址 |