3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

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

编程问答

【转】PE文件结构详解--(完整版)

發布時間:2023/12/10 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【转】PE文件结构详解--(完整版) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

(一)基本概念

PE(Portable Execute)文件是Windows下可執行文件的總稱,常見的有DLL,EXE,OCX,SYS等,事實上,一個文件是否是PE文件與其擴展名無關,PE文件可以是任何擴展名。那Windows是怎么區分可執行文件和非可執行文件的呢?我們調用LoadLibrary傳遞了一個文件名,系統是如何判斷這個文件是一個合法的動態庫呢?這就涉及到PE文件結構了。

PE文件的結構一般來說如下圖所示:從起始位置開始依次是DOS頭,NT頭,節表以及具體的節。

DOS頭是用來兼容MS-DOS操作系統的,目的是當這個文件在MS-DOS上運行時提示一段文字,大部分情況下是:This program cannot be run in DOS mode.還有一個目的,就是指明NT頭在文件中的位置。
NT頭包含windows PE文件的主要信息,其中包括一個‘PE’字樣的簽名,PE文件頭(IMAGE_FILE_HEADER)和PE可選頭(IMAGE_OPTIONAL_HEADER32),頭部的詳細結構以及其具體意義在PE文件頭文章中詳細描述。
節表:是PE文件后續節的描述,windows根據節表的描述加載每個節。
節:每個節實際上是一個容器,可以包含代碼、數據等等,每個節可以有獨立的內存權限,比如代碼節默認有讀/執行權限,節的名字和數量可以自己定義,未必是上圖中的三個。
當一個PE文件被加載到內存中以后,我們稱之為“映象”(image),一般來說,PE文件在硬盤上和在內存里是不完全一樣的,被加載到內存以后其占用的虛擬地址空間要比在硬盤上占用的空間大一些,這是因為各個節在硬盤上是連續的,而在內存中是按頁對齊的,所以加載到內存以后節之間會出現一些“空洞”。

因為存在這種對齊,所以在PE結構內部,表示某個位置的地址采用了兩種方式,針對在硬盤上存儲文件中的地址,稱為原始存儲地址或物理地址表示距離文件頭的偏移;另外一種是針對加載到內存以后映象中的地址,稱為相對虛擬地址(RVA),表示相對內存映象頭的偏移。

然而CPU的某些指令是需要使用絕對地址的,比如取全局變量的地址,傳遞函數的地址編譯以后的匯編指令中肯定需要用到絕對地址而不是相對映象頭的偏移,因此PE文件會建議操作系統將其加載到某個內存地址(這個叫基地址),編譯器便根據這個地址求出代碼中一些全局變量和函數的地址,并將這些地址用到對應的指令中。例如在IDA里看上去是這個樣子:

這種表示方式叫做虛擬地址(VA)。

也許有人要問,既然有VA這么簡單的表示方式為什么還要有前面的RVA呢?因為雖然PE文件為自己指定加載的基地址,但是windows有茫茫多的DLL,而且每個軟件也有自己的DLL,如果指定的地址已經被別的DLL占了怎么辦?如果PE文件無法加載到預期的地址,那么系統會幫他重新選擇一個合適的基地址將他加載到此處,這時原有的VA就全部失效了,NT頭保存了PE文件加載所需的信息,在不知道PE會加載到哪個基地址之前,VA是無效的,所以在PE文件頭中大部分是使用RVA來表示地址的,而在代碼中是用VA表示全局變量和函數地址的。那又有人要問了,既然加載基址變了以后VA都失效了,那存在于代碼中的那些VA怎么辦呢?答案是:重定位。系統有自己的辦法修正這些值,到后續重定位表的文章中會詳細描述。既然有重定位,為什么NT頭不能依靠重定位采用VA表示地址呢(十萬個為什么)?因為不是所有的PE都有重定位,早期的EXE就是沒有重定位的。

我們都知道PE文件可以導出函數讓其他的PE文件使用,也可以從其他PE文件導入函數,這些是如何做到的?PE文件通過導出表指明自己導出那些函數,通過導入表指明需要從哪些模塊導入哪些函數。導入和導出表的具體結構會在單獨的文章中詳細解釋。

(二)可執行文件頭

在PE文件結構詳解(一)基本概念里,解釋了一些PE文件的一些基本概念,從這篇開始,將詳細講解PE文件中的重要結構。

了解一個文件的格式,最應該首先了解的就是這個文件的文件頭的含義,因為幾乎所有的文件格式,重要的信息都包含在頭部,順著頭部的信息,可以引導系統解析整個文件。所以,我們先來認識一下PE文件的頭部格式。還記得上篇里的那個圖嗎?

DOS頭和NT頭就是PE文件中兩個重要的文件頭。

一、DOS頭
DOS頭的作用是兼容MS-DOS操作系統中的可執行文件,對于32位PE文件來說,DOS所起的作用就是顯示一行文字,提示用戶:我需要在32位windows上才可以運行。我認為這是個善意的玩笑,因為他并不像顯示的那樣不能運行,其實已經運行了,只是在DOS上沒有干用戶希望看到的工作而已,好吧,我承認這不是重點。但是,至少我們看一下這個頭是如何定義的:

?

  • typedef struct _IMAGE_DOS_HEADER { ? ? ?// DOS .EXE header

  • ? ? WORD ? e_magic; ? ? ? ? ? ? ? ? ? ? // Magic number

  • ? ? WORD ? e_cblp; ? ? ? ? ? ? ? ? ? ? ?// Bytes on last page of file

  • ? ? WORD ? e_cp; ? ? ? ? ? ? ? ? ? ? ? ?// Pages in file

  • ? ? WORD ? e_crlc; ? ? ? ? ? ? ? ? ? ? ?// Relocations

  • ? ? WORD ? e_cparhdr; ? ? ? ? ? ? ? ? ? // Size of header in paragraphs

  • ? ? WORD ? e_minalloc; ? ? ? ? ? ? ? ? ?// Minimum extra paragraphs needed

  • ? ? WORD ? e_maxalloc; ? ? ? ? ? ? ? ? ?// Maximum extra paragraphs needed

  • ? ? WORD ? e_ss; ? ? ? ? ? ? ? ? ? ? ? ?// Initial (relative) SS value

  • ? ? WORD ? e_sp; ? ? ? ? ? ? ? ? ? ? ? ?// Initial SP value

  • ? ? WORD ? e_csum; ? ? ? ? ? ? ? ? ? ? ?// Checksum

  • ? ? WORD ? e_ip; ? ? ? ? ? ? ? ? ? ? ? ?// Initial IP value

  • ? ? WORD ? e_cs; ? ? ? ? ? ? ? ? ? ? ? ?// Initial (relative) CS value

  • ? ? WORD ? e_lfarlc; ? ? ? ? ? ? ? ? ? ?// File address of relocation table

  • ? ? WORD ? e_ovno; ? ? ? ? ? ? ? ? ? ? ?// Overlay number

  • ? ? WORD ? e_res[4]; ? ? ? ? ? ? ? ? ? ?// Reserved words

  • ? ? WORD ? e_oemid; ? ? ? ? ? ? ? ? ? ? // OEM identifier (for e_oeminfo)

  • ? ? WORD ? e_oeminfo; ? ? ? ? ? ? ? ? ? // OEM information; e_oemid specific

  • ? ? WORD ? e_res2[10]; ? ? ? ? ? ? ? ? ?// Reserved words

  • ? ? LONG ? e_lfanew; ? ? ? ? ? ? ? ? ? ?// File address of new exe header

  • ? } IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;

  • 我們只需要關注兩個域:

    e_magic:一個WORD類型,值是一個常數0x4D5A,用文本編輯器查看該值位‘MZ’,可執行文件必須都是'MZ'開頭。

    e_lfanew:為32位可執行文件擴展的域,用來表示DOS頭之后的NT頭相對文件起始地址的偏移。

    二、NT頭
    順著DOS頭中的e_lfanew,我們很容易可以找到NT頭,這個才是32位PE文件中最有用的頭,定義如下:

  • typedef struct _IMAGE_NT_HEADERS {

  • ? ? DWORD Signature;

  • ? ? IMAGE_FILE_HEADER FileHeader;

  • ? ? IMAGE_OPTIONAL_HEADER32 OptionalHeader;

  • } IMAGE_NT_HEADERS32, *PIMAGE_NT_HEADERS32;


  • 下圖是一張真實的PE文件頭結構以及其各個域的取值:


    Signature:類似于DOS頭中的e_magic,其高16位是0,低16是0x4550,用字符表示是'PE‘。

    IMAGE_FILE_HEADER是PE文件頭,c語言的定義是這樣的:

  • typedef struct _IMAGE_FILE_HEADER {

  • ? ? WORD ? ?Machine;

  • ? ? WORD ? ?NumberOfSections;

  • ? ? DWORD ? TimeDateStamp;

  • ? ? DWORD ? PointerToSymbolTable;

  • ? ? DWORD ? NumberOfSymbols;

  • ? ? WORD ? ?SizeOfOptionalHeader;

  • ? ? WORD ? ?Characteristics;

  • } IMAGE_FILE_HEADER, *PIMAGE_FILE_HEADER;


  • 每個域的具體含義如下:

    Machine:該文件的運行平臺,是x86、x64還是I64等等,可以是下面值里的某一個。

  • #define IMAGE_FILE_MACHINE_UNKNOWN ? ? ? ? ? 0

  • #define IMAGE_FILE_MACHINE_I386 ? ? ? ? ? ? ?0x014c ?// Intel 386.

  • #define IMAGE_FILE_MACHINE_R3000 ? ? ? ? ? ? 0x0162 ?// MIPS little-endian, 0x160 big-endian

  • #define IMAGE_FILE_MACHINE_R4000 ? ? ? ? ? ? 0x0166 ?// MIPS little-endian

  • #define IMAGE_FILE_MACHINE_R10000 ? ? ? ? ? ?0x0168 ?// MIPS little-endian

  • #define IMAGE_FILE_MACHINE_WCEMIPSV2 ? ? ? ? 0x0169 ?// MIPS little-endian WCE v2

  • #define IMAGE_FILE_MACHINE_ALPHA ? ? ? ? ? ? 0x0184 ?// Alpha_AXP

  • #define IMAGE_FILE_MACHINE_SH3 ? ? ? ? ? ? ? 0x01a2 ?// SH3 little-endian

  • #define IMAGE_FILE_MACHINE_SH3DSP ? ? ? ? ? ?0x01a3

  • #define IMAGE_FILE_MACHINE_SH3E ? ? ? ? ? ? ?0x01a4 ?// SH3E little-endian

  • #define IMAGE_FILE_MACHINE_SH4 ? ? ? ? ? ? ? 0x01a6 ?// SH4 little-endian

  • #define IMAGE_FILE_MACHINE_SH5 ? ? ? ? ? ? ? 0x01a8 ?// SH5

  • #define IMAGE_FILE_MACHINE_ARM ? ? ? ? ? ? ? 0x01c0 ?// ARM Little-Endian

  • #define IMAGE_FILE_MACHINE_THUMB ? ? ? ? ? ? 0x01c2

  • #define IMAGE_FILE_MACHINE_AM33 ? ? ? ? ? ? ?0x01d3

  • #define IMAGE_FILE_MACHINE_POWERPC ? ? ? ? ? 0x01F0 ?// IBM PowerPC Little-Endian

  • #define IMAGE_FILE_MACHINE_POWERPCFP ? ? ? ? 0x01f1

  • #define IMAGE_FILE_MACHINE_IA64 ? ? ? ? ? ? ?0x0200 ?// Intel 64

  • #define IMAGE_FILE_MACHINE_MIPS16 ? ? ? ? ? ?0x0266 ?// MIPS

  • #define IMAGE_FILE_MACHINE_ALPHA64 ? ? ? ? ? 0x0284 ?// ALPHA64

  • #define IMAGE_FILE_MACHINE_MIPSFPU ? ? ? ? ? 0x0366 ?// MIPS

  • #define IMAGE_FILE_MACHINE_MIPSFPU16 ? ? ? ? 0x0466 ?// MIPS

  • #define IMAGE_FILE_MACHINE_AXP64 ? ? ? ? ? ? IMAGE_FILE_MACHINE_ALPHA64

  • #define IMAGE_FILE_MACHINE_TRICORE ? ? ? ? ? 0x0520 ?// Infineon

  • #define IMAGE_FILE_MACHINE_CEF ? ? ? ? ? ? ? 0x0CEF

  • #define IMAGE_FILE_MACHINE_EBC ? ? ? ? ? ? ? 0x0EBC ?// EFI Byte Code

  • #define IMAGE_FILE_MACHINE_AMD64 ? ? ? ? ? ? 0x8664 ?// AMD64 (K8)

  • #define IMAGE_FILE_MACHINE_M32R ? ? ? ? ? ? ?0x9041 ?// M32R little-endian

  • #define IMAGE_FILE_MACHINE_CEE ? ? ? ? ? ? ? 0xC0EE


  • NumberOfSections:該PE文件中有多少個節,也就是節表中的項數。

    TimeDateStamp:PE文件的創建時間,一般有連接器填寫。

    PointerToSymbolTable:COFF文件符號表在文件中的偏移。

    NumberOfSymbols:符號表的數量。

    SizeOfOptionalHeader:緊隨其后的可選頭的大小。

    Characteristics:可執行文件的屬性,可以是下面這些值按位相或。

    ?

  • #define IMAGE_FILE_RELOCS_STRIPPED ? ? ? ? ? 0x0001 ?// Relocation info stripped from file.

  • #define IMAGE_FILE_EXECUTABLE_IMAGE ? ? ? ? ?0x0002 ?// File is executable ?(i.e. no unresolved externel references).

  • #define IMAGE_FILE_LINE_NUMS_STRIPPED ? ? ? ?0x0004 ?// Line nunbers stripped from file.

  • #define IMAGE_FILE_LOCAL_SYMS_STRIPPED ? ? ? 0x0008 ?// Local symbols stripped from file.

  • #define IMAGE_FILE_AGGRESIVE_WS_TRIM ? ? ? ? 0x0010 ?// Agressively trim working set

  • #define IMAGE_FILE_LARGE_ADDRESS_AWARE ? ? ? 0x0020 ?// App can handle >2gb addresses

  • #define IMAGE_FILE_BYTES_REVERSED_LO ? ? ? ? 0x0080 ?// Bytes of machine word are reversed.

  • #define IMAGE_FILE_32BIT_MACHINE ? ? ? ? ? ? 0x0100 ?// 32 bit word machine.

  • #define IMAGE_FILE_DEBUG_STRIPPED ? ? ? ? ? ?0x0200 ?// Debugging info stripped from file in .DBG file

  • #define IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP ? 0x0400 ?// If Image is on removable media, copy and run from the swap file.

  • #define IMAGE_FILE_NET_RUN_FROM_SWAP ? ? ? ? 0x0800 ?// If Image is on Net, copy and run from the swap file.

  • #define IMAGE_FILE_SYSTEM ? ? ? ? ? ? ? ? ? ?0x1000 ?// System File.

  • #define IMAGE_FILE_DLL ? ? ? ? ? ? ? ? ? ? ? 0x2000 ?// File is a DLL.

  • #define IMAGE_FILE_UP_SYSTEM_ONLY ? ? ? ? ? ?0x4000 ?// File should only be run on a UP machine

  • #define IMAGE_FILE_BYTES_REVERSED_HI ? ? ? ? 0x8000 ?// Bytes of machine word are reversed.


  • 可以看出,PE文件頭定義了PE文件的一些基本信息和屬性,這些屬性會在PE加載器加載時用到,如果加載器發現PE文件頭中定義的一些屬性不滿足當前的運行環境,將會終止加載該PE。

    另一個重要的頭就是PE可選頭,別看他名字叫可選頭,其實一點都不能少,不過,它在不同的平臺下是不一樣的,例如32位下是IMAGE_OPTIONAL_HEADER32,而在64位下是IMAGE_OPTIONAL_HEADER64。為了簡單起見,我們只看32位。

  • typedef struct _IMAGE_OPTIONAL_HEADER {

  • ? ? WORD ? ?Magic;

  • ? ? BYTE ? ?MajorLinkerVersion;

  • ? ? BYTE ? ?MinorLinkerVersion;

  • ? ? DWORD ? SizeOfCode;

  • ? ? DWORD ? SizeOfInitializedData;

  • ? ? DWORD ? SizeOfUninitializedData;

  • ? ? DWORD ? AddressOfEntryPoint;

  • ? ? DWORD ? BaseOfCode;

  • ? ? DWORD ? BaseOfData;

  • ? ? DWORD ? ImageBase;

  • ? ? DWORD ? SectionAlignment;

  • ? ? DWORD ? FileAlignment;

  • ? ? WORD ? ?MajorOperatingSystemVersion;

  • ? ? WORD ? ?MinorOperatingSystemVersion;

  • ? ? WORD ? ?MajorImageVersion;

  • ? ? WORD ? ?MinorImageVersion;

  • ? ? WORD ? ?MajorSubsystemVersion;

  • ? ? WORD ? ?MinorSubsystemVersion;

  • ? ? DWORD ? Win32VersionValue;

  • ? ? DWORD ? SizeOfImage;

  • ? ? DWORD ? SizeOfHeaders;

  • ? ? DWORD ? CheckSum;

  • ? ? WORD ? ?Subsystem;

  • ? ? WORD ? ?DllCharacteristics;

  • ? ? DWORD ? SizeOfStackReserve;

  • ? ? DWORD ? SizeOfStackCommit;

  • ? ? DWORD ? SizeOfHeapReserve;

  • ? ? DWORD ? SizeOfHeapCommit;

  • ? ? DWORD ? LoaderFlags;

  • ? ? DWORD ? NumberOfRvaAndSizes;

  • ? ? IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];

  • } IMAGE_OPTIONAL_HEADER32, *PIMAGE_OPTIONAL_HEADER32;

  • Magic:表示可選頭的類型。

  • #define IMAGE_NT_OPTIONAL_HDR32_MAGIC ? ? ?0x10b ?// 32位PE可選頭

  • #define IMAGE_NT_OPTIONAL_HDR64_MAGIC ? ? ?0x20b ?// 64位PE可選頭

  • #define IMAGE_ROM_OPTIONAL_HDR_MAGIC ? ? ? 0x107 ?


  • MajorLinkerVersion和MinorLinkerVersion:鏈接器的版本號。

    SizeOfCode:代碼段的長度,如果有多個代碼段,則是代碼段長度的總和。

    SizeOfInitializedData:初始化的數據長度。

    SizeOfUninitializedData:未初始化的數據長度。

    AddressOfEntryPoint:程序入口的RVA,對于exe這個地址可以理解為WinMain的RVA。對于DLL,這個地址可以理解為DllMain的RVA,如果是驅動程序,可以理解為DriverEntry的RVA。當然,實際上入口點并非是WinMain,DllMain和DriverEntry,在這些函數之前還有一系列初始化要完成,當然,這些不是本文的重點。

    BaseOfCode:代碼段起始地址的RVA。

    BaseOfData:數據段起始地址的RVA。

    ImageBase:映象(加載到內存中的PE文件)的基地址,這個基地址是建議,對于DLL來說,如果無法加載到這個地址,系統會自動為其選擇地址。

    SectionAlignment:節對齊,PE中的節被加載到內存時會按照這個域指定的值來對齊,比如這個值是0x1000,那么每個節的起始地址的低12位都為0。

    FileAlignment:節在文件中按此值對齊,SectionAlignment必須大于或等于FileAlignment。

    MajorOperatingSystemVersion、MinorOperatingSystemVersion:所需操作系統的版本號,隨著操作系統版本越來越多,這個好像不是那么重要了。

    MajorImageVersion、MinorImageVersion:映象的版本號,這個是開發者自己指定的,由連接器填寫。

    MajorSubsystemVersion、MinorSubsystemVersion:所需子系統版本號。

    Win32VersionValue:保留,必須為0。

    SizeOfImage:映象的大小,PE文件加載到內存中空間是連續的,這個值指定占用虛擬空間的大小。

    SizeOfHeaders:所有文件頭(包括節表)的大小,這個值是以FileAlignment對齊的。

    CheckSum:映象文件的校驗和。

    Subsystem:運行該PE文件所需的子系統,可以是下面定義中的某一個:

  • #define IMAGE_SUBSYSTEM_UNKNOWN ? ? ? ? ? ? ?0 ? // Unknown subsystem.

  • #define IMAGE_SUBSYSTEM_NATIVE ? ? ? ? ? ? ? 1 ? // Image doesn't require a subsystem.

  • #define IMAGE_SUBSYSTEM_WINDOWS_GUI ? ? ? ? ?2 ? // Image runs in the Windows GUI subsystem.

  • #define IMAGE_SUBSYSTEM_WINDOWS_CUI ? ? ? ? ?3 ? // Image runs in the Windows character subsystem.

  • #define IMAGE_SUBSYSTEM_OS2_CUI ? ? ? ? ? ? ?5 ? // image runs in the OS/2 character subsystem.

  • #define IMAGE_SUBSYSTEM_POSIX_CUI ? ? ? ? ? ?7 ? // image runs in the Posix character subsystem.

  • #define IMAGE_SUBSYSTEM_NATIVE_WINDOWS ? ? ? 8 ? // image is a native Win9x driver.

  • #define IMAGE_SUBSYSTEM_WINDOWS_CE_GUI ? ? ? 9 ? // Image runs in the Windows CE subsystem.

  • #define IMAGE_SUBSYSTEM_EFI_APPLICATION ? ? ?10 ?//

  • #define IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER ?11 ? //

  • #define IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER ? 12 ?//

  • #define IMAGE_SUBSYSTEM_EFI_ROM ? ? ? ? ? ? ?13

  • #define IMAGE_SUBSYSTEM_XBOX ? ? ? ? ? ? ? ? 14

  • #define IMAGE_SUBSYSTEM_WINDOWS_BOOT_APPLICATION 16

  • DllCharacteristics:DLL的文件屬性,只對DLL文件有效,可以是下面定義中某些的組合:

  • #define IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE 0x0040 ? ? // DLL can move.

  • #define IMAGE_DLLCHARACTERISTICS_FORCE_INTEGRITY ? ?0x0080 ? ? // Code Integrity Image

  • #define IMAGE_DLLCHARACTERISTICS_NX_COMPAT ? ?0x0100 ? ? // Image is NX compatible

  • #define IMAGE_DLLCHARACTERISTICS_NO_ISOLATION 0x0200 ? ? // Image understands isolation and doesn't want it

  • #define IMAGE_DLLCHARACTERISTICS_NO_SEH ? ? ? 0x0400 ? ? // Image does not use SEH. ?No SE handler may reside in this image

  • #define IMAGE_DLLCHARACTERISTICS_NO_BIND ? ? ?0x0800 ? ? // Do not bind this image.

  • // ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?0x1000 ? ? // Reserved.

  • #define IMAGE_DLLCHARACTERISTICS_WDM_DRIVER ? 0x2000 ? ? // Driver uses WDM model

  • // ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?0x4000 ? ? // Reserved.

  • #define IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE ? ? 0x8000

  • SizeOfStackReserve:運行時為每個線程棧保留內存的大小。
    SizeOfStackCommit:運行時每個線程棧初始占用內存大小。

    SizeOfHeapReserve:運行時為進程堆保留內存大小。

    SizeOfHeapCommit:運行時進程堆初始占用內存大小。

    LoaderFlags:保留,必須為0。

    NumberOfRvaAndSizes:數據目錄的項數,即下面這個數組的項數。

    DataDirectory:數據目錄,這是一個數組,數組的項定義如下:

    ?

  • typedef struct _IMAGE_DATA_DIRECTORY {

  • ? ? DWORD ? VirtualAddress;

  • ? ? DWORD ? Size;

  • } IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY;


  • VirtualAddress:是一個RVA。
    Size:是一個大小。

    這兩個數有什么用呢?一個是地址,一個是大小,可以看出這個數據目錄項定義的是一個區域。那他定義的是什么東西的區域呢?前面說了,DataDirectory是個數組,數組中的每一項對應一個特定的數據結構,包括導入表,導出表等等,根據不同的索引取出來的是不同的結構,頭文件里定義各個項表示哪個結構,如下面的代碼所示:

  • #define IMAGE_DIRECTORY_ENTRY_EXPORT ? ? ? ? ?0 ? // Export Directory

  • #define IMAGE_DIRECTORY_ENTRY_IMPORT ? ? ? ? ?1 ? // Import Directory

  • #define IMAGE_DIRECTORY_ENTRY_RESOURCE ? ? ? ?2 ? // Resource Directory

  • #define IMAGE_DIRECTORY_ENTRY_EXCEPTION ? ? ? 3 ? // Exception Directory

  • #define IMAGE_DIRECTORY_ENTRY_SECURITY ? ? ? ?4 ? // Security Directory

  • #define IMAGE_DIRECTORY_ENTRY_BASERELOC ? ? ? 5 ? // Base Relocation Table

  • #define IMAGE_DIRECTORY_ENTRY_DEBUG ? ? ? ? ? 6 ? // Debug Directory

  • // ? ? ?IMAGE_DIRECTORY_ENTRY_COPYRIGHT ? ? ? 7 ? // (X86 usage)

  • #define IMAGE_DIRECTORY_ENTRY_ARCHITECTURE ? ?7 ? // Architecture Specific Data

  • #define IMAGE_DIRECTORY_ENTRY_GLOBALPTR ? ? ? 8 ? // RVA of GP

  • #define IMAGE_DIRECTORY_ENTRY_TLS ? ? ? ? ? ? 9 ? // TLS Directory

  • #define IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG ? ?10 ? // Load Configuration Directory

  • #define IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT ? 11 ? // Bound Import Directory in headers

  • #define IMAGE_DIRECTORY_ENTRY_IAT ? ? ? ? ? ?12 ? // Import Address Table

  • #define IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT ? 13 ? // Delay Load Import Descriptors

  • #define IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR 14 ? // COM Runtime descriptor


  • 看到這么多的定義,大家估計要頭疼了,好不容易要把PE文件頭學習完了,又“從天而降”一大波的結構。不用緊張,有了前面的知識,后面的部分就迎刃而解了。下一篇開始將沿著這個數據目錄分解其余部分,繼續關注哦~
    ?

    (三)PE導出表

    上篇文章?PE文件結構詳解(二)可執行文件頭?的結尾出現了一個大數組,這個數組中的每一項都是一個特定的結構,通過函數獲取數組中的項可以用RtlImageDirectoryEntryToData函數,DataDirectory中的每一項都可以用這個函數獲取,函數原型如下:

    PVOID NTAPI RtlImageDirectoryEntryToData(PVOID Base, BOOLEAN MappedAsImage, USHORT Directory, PULONG Size);

    Base:模塊基地址。

    MappedAsImage:是否映射為映象。

    Directory:數據目錄項的索引。

  • #define IMAGE_DIRECTORY_ENTRY_EXPORT ? ? ? ? ?0 ? // Export Directory

  • #define IMAGE_DIRECTORY_ENTRY_IMPORT ? ? ? ? ?1 ? // Import Directory

  • #define IMAGE_DIRECTORY_ENTRY_RESOURCE ? ? ? ?2 ? // Resource Directory

  • #define IMAGE_DIRECTORY_ENTRY_EXCEPTION ? ? ? 3 ? // Exception Directory

  • #define IMAGE_DIRECTORY_ENTRY_SECURITY ? ? ? ?4 ? // Security Directory

  • #define IMAGE_DIRECTORY_ENTRY_BASERELOC ? ? ? 5 ? // Base Relocation Table

  • #define IMAGE_DIRECTORY_ENTRY_DEBUG ? ? ? ? ? 6 ? // Debug Directory

  • // ? ? ?IMAGE_DIRECTORY_ENTRY_COPYRIGHT ? ? ? 7 ? // (X86 usage)

  • #define IMAGE_DIRECTORY_ENTRY_ARCHITECTURE ? ?7 ? // Architecture Specific Data

  • #define IMAGE_DIRECTORY_ENTRY_GLOBALPTR ? ? ? 8 ? // RVA of GP

  • #define IMAGE_DIRECTORY_ENTRY_TLS ? ? ? ? ? ? 9 ? // TLS Directory

  • #define IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG ? ?10 ? // Load Configuration Directory

  • #define IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT ? 11 ? // Bound Import Directory in headers

  • #define IMAGE_DIRECTORY_ENTRY_IAT ? ? ? ? ? ?12 ? // Import Address Table

  • #define IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT ? 13 ? // Delay Load Import Descriptors

  • #define IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR 14 ? // COM Runtime descriptor

  • Size:對應數據目錄項的大小,比如Directory為0,則表示導出表的大小。

    返回值表示數據目錄項的起始地址。

    這次來看看第一項:導出表。
    導出表是用來描述模塊中的導出函數的結構,如果一個模塊導出了函數,那么這個函數會被記錄在導出表中,這樣通過GetProcAddress函數就能動態獲取到函數的地址。函數導出的方式有兩種,一種是按名字導出,一種是按序號導出。這兩種導出方式在導出表中的描述方式也不相同。模塊的導出函數可以通過Dependency walker工具來查看:

    上圖中紅框位置顯示的就是模塊的導出函數,有時候顯示的導出函數名字中有一些符號,像 ??0CP2PDownloadUIInterface@@QAE@ABV0@@Z,這種是導出了C++的函數名,編譯器將名字進行了修飾。

    下面看一下導出表的定義吧:

  • typedef struct _IMAGE_EXPORT_DIRECTORY {

  • ? ? DWORD ? Characteristics;

  • ? ? DWORD ? TimeDateStamp;

  • ? ? WORD ? ?MajorVersion;

  • ? ? WORD ? ?MinorVersion;

  • ? ? DWORD ? Name;

  • ? ? DWORD ? Base;

  • ? ? DWORD ? NumberOfFunctions;

  • ? ? DWORD ? NumberOfNames;

  • ? ? DWORD ? AddressOfFunctions; ? ? // RVA from base of image

  • ? ? DWORD ? AddressOfNames; ? ? ? ? // RVA from base of image

  • ? ? DWORD ? AddressOfNameOrdinals; ?// RVA from base of image

  • } IMAGE_EXPORT_DIRECTORY, *PIMAGE_EXPORT_DIRECTORY;

  • 結構還算比較簡單,具體每一項的含義如下:
    Characteristics:現在沒有用到,一般為0。

    TimeDateStamp:導出表生成的時間戳,由連接器生成。

    MajorVersion,MinorVersion:看名字是版本,實際貌似沒有用,都是0。

    Name:模塊的名字。

    Base:序號的基數,按序號導出函數的序號值從Base開始遞增。

    NumberOfFunctions:所有導出函數的數量。

    NumberOfNames:按名字導出函數的數量。

    AddressOfFunctions:一個RVA,指向一個DWORD數組,數組中的每一項是一個導出函數的RVA,順序與導出序號相同。

    AddressOfNames:一個RVA,依然指向一個DWORD數組,數組中的每一項仍然是一個RVA,指向一個表示函數名字。

    AddressOfNameOrdinals:一個RVA,還是指向一個WORD數組,數組中的每一項與AddressOfNames中的每一項對應,表示該名字的函數在AddressOfFunctions中的序號。

    第一次接觸這個結構的童鞋被后面的5項搞暈了吧,理解這個結構比結構本身看上去要復雜一些,文字描述不管怎么說都顯得晦澀,所謂一圖勝千言,無圖無真相,直接上圖:

    在上圖中,AddressOfNames指向一個數組,數組里保存著一組RVA,每個RVA指向一個字符串,這個字符串即導出的函數名,與這個函數名對應的是AddressOfNameOrdinals中的對應項。獲取導出函數地址時,先在AddressOfNames中找到對應的名字,比如Func2,他在AddressOfNames中是第二項,然后從AddressOfNameOrdinals中取出第二項的值,這里是2,表示函數入口保存在AddressOfFunctions這個數組中下標為2的項里,即第三項,取出其中的值,加上模塊基地址便是導出函數的地址。如果函數是以序號導出的,那么查找的時候直接用序號減去Base,得到的值就是函數在AddressOfFunctions中的下標。

    用代碼實現如下:

    ?

  • DWORD* CEAT::SearchEAT( const char* szName)

  • {

  • ? ? if (IS_VALID_PTR(m_pTable))

  • ? ? {

  • ? ? ? ? bool bByOrdinal = HIWORD(szName) == 0;

  • ? ? ? ? DWORD* pProcs = (DWORD*)((char*)RVA2VA(m_pTable->AddressOfFunctions));

  • ? ? ? ? if (bByOrdinal)

  • ? ? ? ? {

  • ? ? ? ? ? ? DWORD dwOrdinal = (DWORD)szName;?

  • ? ? ? ? ? ? if (dwOrdinal < m_pTable->NumberOfFunctions && dwOrdinal >= m_pTable->Base)

  • ? ? ? ? ? ? {

  • ? ? ? ? ? ? ? ? return &pProcs[dwOrdinal-m_pTable->Base];

  • ? ? ? ? ? ? }

  • ? ? ? ? }

  • ? ? ? ? else

  • ? ? ? ? {

  • ? ? ? ? ? ? WORD* pOrdinals = (WORD*)((char*)RVA2VA(m_pTable->AddressOfNameOrdinals));

  • ? ? ? ? ? ? DWORD* pNames = (DWORD*)((char*)RVA2VA(m_pTable->AddressOfNames));

  • ? ? ? ? ? ? for (unsigned int i=0; i<m_pTable->NumberOfNames; ++i)

  • ? ? ? ? ? ? {

  • ? ? ? ? ? ? ? ? char* pNameVA = (char*)RVA2VA(pNames[i]);

  • ? ? ? ? ? ? ? ? if (strcmp(szName, pNameVA) != 0)

  • ? ? ? ? ? ? ? ? {

  • ? ? ? ? ? ? ? ? ? ? continue;

  • ? ? ? ? ? ? ? ? }

  • ? ? ? ? ? ? ? ? return &pProcs[pOrdinals[i]];

  • ? ? ? ? ? ? }

  • ? ? ? ? }

  • ? ? }

  • ? ? return NULL;

  • }

  • (四)PE導入表

    PE文件結構詳解(二)可執行文件頭的最后展示了一個數組,PE文件結構詳解(三)PE導出表中解釋了其中第一項的格式,本篇文章來揭示這個數組中的第二項:IMAGE_DIRECTORY_ENTRY_IMPORT,即導入表。

    也許大家注意到過,在IMAGE_DATA_DIRECTORY中,有幾項的名字都和導入表有關系,其中包括:IMAGE_DIRECTORY_ENTRY_IMPORT,IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT,IMAGE_DIRECTORY_ENTRY_IAT和IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT這幾個導入都是用來干什么的,他們之間又是什么關系呢?聽我慢慢道來。

    IMAGE_DIRECTORY_ENTRY_IMPORT就是我們通常所知道的導入表,在PE文件加載時,會根據這個表里的內容加載依賴的DLL,并填充所需函數的地址。
    IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT叫做綁定導入表,在第一種導入表導入地址的修正是在PE加載時完成,如果一個PE文件導入的DLL或者函數多那么加載起來就會略顯的慢一些,所以出現了綁定導入,在加載以前就修正了導入表,這樣就會快一些。
    IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT叫做延遲導入表,一個PE文件也許提供了很多功能,也導入了很多其他DLL,但是并非每次加載都會用到它提供的所有功能,也不一定會用到它需要導入的所有DLL,因此延遲導入就出現了,只有在一個PE文件真正用到需要的DLL,這個DLL才會被加載,甚至于只有真正使用某個導入函數,這個函數地址才會被修正。
    IMAGE_DIRECTORY_ENTRY_IAT是導入地址表,前面的三個表其實是導入函數的描述,真正的函數地址是被填充在導入地址表中的。
    舉個實際的例子,看一下下面這張圖:


    這個代碼調用了一個RegOpenKeyW的導入函數,我們看到其opcode是FF 15 00 00 19 30氣質FF 15表示這是一個間接調用,即call dword ptr?[30190000] ;這表示要調用的地址存放在30190000這個地址中,而30190000這個地址在導入地址表的范圍內,當模塊加載時,PE 加載器會根據導入表中描述的信息修正30190000這個內存中的內容。

    那么導入表里到底記錄了那些信息,如何根據這些信息修正IAT呢?我們一起來看一下導入表的定義:

    ?

  • typedef struct _IMAGE_IMPORT_DESCRIPTOR {

  • ? ? union {

  • ? ? ? ? DWORD ? Characteristics; ? ? ? ? ? ?// 0 for terminating null import descriptor

  • ? ? ? ? DWORD ? OriginalFirstThunk; ? ? ? ? // RVA to original unbound IAT (PIMAGE_THUNK_DATA)

  • ? ? } DUMMYUNIONNAME;

  • ? ? DWORD ? TimeDateStamp; ? ? ? ? ? ? ? ? ?// 0 if not bound,

  • ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? // -1 if bound, and real date\time stamp

  • ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? // ? ? in IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT (new BIND)

  • ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? // O.W. date/time stamp of DLL bound to (Old BIND)

  • ?

  • ? ? DWORD ? ForwarderChain; ? ? ? ? ? ? ? ? // -1 if no forwarders

  • ? ? DWORD ? Name;

  • ? ? DWORD ? FirstThunk; ? ? ? ? ? ? ? ? ? ? // RVA to IAT (if bound this IAT has actual addresses)

  • } IMAGE_IMPORT_DESCRIPTOR;

  • typedef IMAGE_IMPORT_DESCRIPTOR UNALIGNED *PIMAGE_IMPORT_DESCRIPTOR;


  • 使用RtlImageDirectoryEntryToData并將索引號傳1,會得到一個如上結構的指針,實際上指向一個上述結構的數組,每個導入的DLL都會成為數組中的一項,也就是說,一個這樣的結構對應一個導入的DLL。
    Characteristics和OriginalFirstThunk:一個聯合體,如果是數組的最后一項Characteristics為0,否則OriginalFirstThunk保存一個RVA,指向一個IMAGE_THUNK_DATA的數組,這個數組中的每一項表示一個導入函數。

    TimeDateStamp:映象綁定前,這個值是0,綁定后是導入模塊的時間戳。

    ForwarderChain:轉發鏈,如果沒有轉發器,這個值是-1。

    Name:一個RVA,指向導入模塊的名字,所以一個IMAGE_IMPORT_DESCRIPTOR描述一個導入的DLL。

    FirstThunk:也是一個RVA,也指向一個IMAGE_THUNK_DATA數組。
    既然OriginalFirstThunk與FirstThunk都指向一個IMAGE_THUNK_DATA數組,而且這兩個域的名字都長得很像,他倆有什么區別呢?為了解答這個問題,先來認識一下IMAGE_THUNK_DATA結構:

    ?

  • typedef struct _IMAGE_THUNK_DATA32 {

  • ? ? union {

  • ? ? ? ? DWORD ForwarderString; ? ? ?// PBYTE?

  • ? ? ? ? DWORD Function; ? ? ? ? ? ? // PDWORD

  • ? ? ? ? DWORD Ordinal;

  • ? ? ? ? DWORD AddressOfData; ? ? ? ?// PIMAGE_IMPORT_BY_NAME

  • ? ? } u1;

  • } IMAGE_THUNK_DATA32;

  • typedef IMAGE_THUNK_DATA32 * PIMAGE_THUNK_DATA32;


  • ForwarderString是轉發用的,暫時不用考慮,Function表示函數地址,如果是按序號導入Ordinal就有用了,若是按名字導入AddressOfData便指向名字信息。可以看出這個結構體就是一個大的union,大家都知道union雖包含多個域但是在不同時刻代表不同的意義那到底應該是名字還是序號,該如何區分呢?可以通過Ordinal判斷,如果Ordinal的最高位是1,就是按序號導入的,這時候,低16位就是導入序號,如果最高位是0,則AddressOfData是一個RVA,指向一個IMAGE_IMPORT_BY_NAME結構,用來保存名字信息,由于Ordinal和AddressOfData實際上是同一個內存空間,所以AddressOfData其實只有低31位可以表示RVA,但是一個PE文件不可能超過2G,所以最高位永遠為0,這樣設計很合理的利用了空間。實際編寫代碼的時候微軟提供兩個宏定義處理序號導入:IMAGE_SNAP_BY_ORDINAL判斷是否按序號導入,IMAGE_ORDINAL用來獲取導入序號。
    這時我們可以回頭看看OriginalFirstThunk與FirstThunk,OriginalFirstThunk指向的IMAGE_THUNK_DATA數組包含導入信息,在這個數組中只有Ordinal和AddressOfData是有用的,因此可以通過OriginalFirstThunk查找到函數的地址。FirstThunk則略有不同,在PE文件加載以前或者說在導入表未處理以前,他所指向的數組與OriginalFirstThunk中的數組雖不是同一個,但是內容卻是相同的,都包含了導入信息,而在加載之后,FirstThunk中的Function開始生效,他指向實際的函數地址,因為FirstThunk實際上指向IAT中的一個位置,IAT就充當了IMAGE_THUNK_DATA數組,加載完成后,這些IAT項就變成了實際的函數地址,即Function的意義。還是上個圖對比一下:

    上圖是加載前。

    上圖是加載后。

    最后總結一下:

    導入表其實是一個IMAGE_IMPORT_DESCRIPTOR的數組,每個導入的DLL對應一個IMAGE_IMPORT_DESCRIPTOR。
    IMAGE_IMPORT_DESCRIPTOR包含兩個IMAGE_THUNK_DATA數組,數組中的每一項對應一個導入函數。
    加載前OriginalFirstThunk與FirstThunk的數組都指向名字信息,加載后FirstThunk數組指向實際的函數地址。

    (五)延遲導入表

    PE文件結構詳解(四)PE導入表講了一般的PE導入表,這次我們來看一下另外一種導入表:延遲導入(Delay Import)。看名字就知道,這種導入機制導入其他DLL的時機比較“遲”,為什么要遲呢?因為有些導入函數可能使用的頻率比較低,或者在某些特定的場合才會用到,而有些函數可能要在程序運行一段時間后才會用到,這些函數可以等到他實際使用的時候再去加載對應的DLL,而沒必要再程序一裝載就初始化好。

    這個機制聽起來很誘人,因為他可以加快啟動速度,我們應該如何利用這項機制呢?VC有一個選項,可以讓我們很方便的使用到這項特性,如下圖所示:

    ?

    在這一項后面填寫需要延遲導入的DLL名稱,連接器就會自動幫我們將這些DLL的導入變為延遲導入。

    現在我們知道如何使用延遲導入了,那這個看上去很厲害的機制是如何實現的呢?接下來我們來探索一番。在IMAGE_DATA_DIRECTORY中,有一項為IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT,這一項便延遲導入表,IMAGE_DATA_DIRECTORY.VirtualAddress就指向延遲導入表的起始地址。既然是表,肯定又是一個數組,每一項都是一個ImgDelayDescr結構體,和導入表一樣,每一項都代表一個導入的DLL,來看看定義:

  • [cpp]?view plaincopy

  • ?
  • typedef?struct?ImgDelayDescr?{??

  • ????DWORD???????????grAttrs;????????//?attributes??

  • ????RVA?????????????rvaDLLName;?????//?RVA?to?dll?name??

  • ????RVA?????????????rvaHmod;????????//?RVA?of?module?handle??

  • ????RVA?????????????rvaIAT;?????????//?RVA?of?the?IAT??

  • ????RVA?????????????rvaINT;?????????//?RVA?of?the?INT??

  • ????RVA?????????????rvaBoundIAT;????//?RVA?of?the?optional?bound?IAT??

  • ????RVA?????????????rvaUnloadIAT;???//?RVA?of?optional?copy?of?original?IAT??

  • ????DWORD???????????dwTimeStamp;????//?0?if?not?bound,??

  • ????????????????????????????????????//?O.W.?date/time?stamp?of?DLL?bound?to?(Old?BIND)??

  • }?ImgDelayDescr,?*?PImgDelayDescr;??

  • typedef?const?ImgDelayDescr?*???PCImgDelayDescr;??

  • grAttrs:用來區分版本,1是新版本,0是舊版本,舊版本中后續的rvaxxxxxx域使用的都是指針,而新版本中都用RVA,我們只討論新版本。

    ?

    rvaDLLName:一個RVA,指向導入DLL的名字。

    rvaHmod:一個RVA,指向導入DLL的模塊基地址,這個基地址在DLL真正被導入前是NULL,導入后才是實際的基地址。

    rvaIAT:一個RVA,表示導入函數表,實際上指向IAT,在DLL加載前,IAT里存放的是一小段代碼的地址,加載后才是真正的導入函數地址。

    rvaINT:一個RVA,指向導入函數的名字表。

    rvaUnloadIAT:延遲導入函數卸載表。

    dwTimeStamp:延遲導入DLL的時間戳。

    定義知道了,那他是怎么被處理的呢?前面提到了,在延遲導入函數指向的IAT里,默認保存的是一段代碼的地址,當程序第一次調用到這個延遲導入函數時,流程會走到那段代碼,這段代碼用來干什么呢?請看一個真實的延遲導入函數的例子:

    ?

  • [cpp]?view plaincopy

  • ?
  • .text:75C7A363?__imp_load__InternetConnectA@32:????????;?InternetConnectA(x,x,x,x,x,x,x,x)??

  • .text:75C7A363?????????????????mov?????eax,?offset?__imp__InternetConnectA@32??

  • .text:75C7A368?????????????????jmp?????__tailMerge_WININET??


  • 這段代碼其實只有兩行匯編,第一行把導入函數IAT項的地址放到eax中,然后用一個jmp跳轉走,那么他跳轉到哪里了呢?我們繼續跟蹤:

    ?

  • [cpp]?view plaincopy

  • ?
  • __tailMerge_WININET?proc?near?????????????

  • .text:75C6BEF0?????????????????push????ecx??

  • .text:75C6BEF1?????????????????push????edx??

  • .text:75C6BEF2?????????????????push????eax??

  • .text:75C6BEF3?????????????????push????offset?__DELAY_IMPORT_DESCRIPTOR_WININET??

  • .text:75C6BEF8?????????????????call????__delayLoadHelper??

  • .text:75C6BEFD?????????????????pop?????edx??

  • .text:75C6BEFE?????????????????pop?????ecx??

  • .text:75C6BEFF?????????????????jmp?????eax??

  • .text:75C6BEFF?__tailMerge_WININET?endp??

  • ?

    其中最重要的是push了一個__DELAY_IMPORT_DESCRIPTOR_WININET,這個就是上文中看到的ImgDelayDescr結構,他的DLL名字是wininet.dll。之后,CALL了一個__delayLoadHelper,在這個函數里,執行了加載DLL,查找導出函數,填充導入表等一系列操作,函數結束時IAT中已經是真正的導入函數的地址,這個函數同時返回了導入函數的地址,因此之后的eax里保存的就是函數地址,最后的jmp eax就跳轉到了真實的導入函數中。

    這個過程很完美,也很靈巧,但是如果仔細觀察就會發現什么地方有點不對勁,你發現了嗎?__delayLoadHelper的參數中只有IAT項的偏移和整個模塊的延遲導入描述__DELAY_IMPORT_DESCRIPTOR_WININET,但是參數中并沒有要導入函數的名字。也許你說,名字在__DELAY_IMPORT_DESCRIPTOR_WININET的名字表中,是的,那里確實有名字,但是別忘了,那是個表,里面存的是所有要從該模塊導入的函數名字,而不是“當前”這個被調用函數的函數名。或許你覺得參數中應該有個索引號,用來表示名字列表中的第幾項是即將被導入的那個函數的名字,不幸的是我們也沒有看到參數中有這樣的信息存在,那Windows執行到這里是如何得到名字的呢?MS在這里使用了一個巧妙的辦法:__DELAY_IMPORT_DESCRIPTOR_WININET中有一項是rvaIAT,前面提到了,這里實際上就是指向了IAT,而且是該模塊第一個導入函數的IAT的偏移,現在我們有兩個偏移,即將導入的函數IAT項的偏移(記作RVA1)和要導入模塊第一個函數IAT項的偏移(記作RVA0),(RVA1-RVA0)/4 = 導入函數IAT項在rvaIAT中的下標,rvaINT中的名字順序與rvaIAT中的順序是相同的,所以下標也相同,這樣就能獲取到導入函數的名字了。有了模塊名和函數名,用GetProcAddress就可以獲取到導入函數的地址了。

    上述流程用一張圖來總結一下:

    最后還有兩點要提醒大家:

    延遲導入的加載只發生在函數第一次被調用的時候,之后IAT就填充為正確函數地址,不會再走__delayLoadHelper了。

    延遲導入一次只會導入一個函數,而不是一次導入整個模塊的所有函數。

    (六)重定位

    前面兩篇?PE文件結構詳解(四)PE導入表?和?PE文件結構詳解(五)延遲導入表?介紹了PE文件中比較常用的兩種導入方式,不知道大家有沒有注意到,在調用導入函數時系統生成的代碼是像下面這樣的:

    在這里,IE的iexplorer.exe導入了Kernel32.dll的GetCommandLineA函數,可以看到這是個間接call,00401004這個地址的內存里保存了目的地址,根據圖中顯示的符號信息可知,00401004這個地址是存在于iexplorer.exe模塊中的,實際上也就是一項IAT的地址。這個是IE6的exe中的例子,當然在dll中如果導入其他dll中的函數,結果也是一樣的。這樣就有一個問題,代碼里call的地址是一個模塊內的地址,而且是一個VA,那么如果模塊基地址發生了變化,這個地址豈不是就無效了?這個問題如何解決?

    答案是:Windows使用重定位機制保證以上代碼無論模塊加載到哪個基址都能正確被調用。聽起來很神奇,是怎么做到的呢?其實原理并不很復雜,這個過程分三步:

    1.編譯的時候由編譯器識別出哪些項使用了模塊內的直接VA,比如push一個全局變量、函數地址,這些指令的操作數在模塊加載的時候就需要被重定位。

    2.鏈接器生成PE文件的時候將編譯器識別的重定位的項紀錄在一張表里,這張表就是重定位表,保存在DataDirectory中,序號是?IMAGE_DIRECTORY_ENTRY_BASERELOC。

    3.PE文件加載時,PE 加載器分析重定位表,將其中每一項按照現在的模塊基址進行重定位。

    以上三步,前兩部涉及到了編譯和鏈接的知識,跟本文的關系不大,我們直接看第三步,這一步符合本系列的特征。

    在查看重定位表的定義前,我們先了解一下他的存儲方式,有助于后面的理解。按照常規思路,每個重定位項應該是一個DWORD,里面保存需要重定位的RVA,這樣只需要簡單操作便能找到需要重定位的項。然而,Windows并沒有這樣設計,原因是這樣存放太占用空間了,試想一下,加入一個文件有n個重定位項,那么就需要占用4*n個字節。所以Windows采用了分組的方式,按照重定位項所在的頁面分組,每組保存一個頁面其實地址的RVA,頁內的每項重定位項使用一個WORD保存重定位項在頁內的偏移,這樣就大大縮小了重定位表的大小。

    有了上面的概念,我們現在可以來看一下基址重定位表的定義了:

    ?

  • typedef struct _IMAGE_BASE_RELOCATION {

  • ? ? DWORD ? VirtualAddress;

  • ? ? DWORD ? SizeOfBlock;

  • // ?WORD ? ?TypeOffset[1];

  • } IMAGE_BASE_RELOCATION;

  • typedef IMAGE_BASE_RELOCATION UNALIGNED * PIMAGE_BASE_RELOCATION;


  • VirtualAddress:頁起始地址RVA。
    SizeOfBlock:表示該分組保存了幾項重定位項。

    TypeOffset:這個域有兩個含義,大家都知道,頁內偏移用12位就可以表示,剩下的高4位用來表示重定位的類型。而事實上,Windows只用了一種類型IMAGE_REL_BASED_HIGHLOW ?數值是 3。

    好了,有了以上知識,相信大家可以很容易的寫出自己修正重定位表的代碼,不如自己做個練習驗證一下吧。

    本文?by evil.eagle 轉載的時候請注明出處。http://blog.csdn.net/evileagle/article/details/12886949

    最后,還是總結一下,哪些項目需要被重定位呢?

    1.代碼中使用全局變量的指令,因為全局變量一定是模塊內的地址,而且使用全局變量的語句在編譯后會產生一條引用全局變量基地址的指令。

    2.將模塊函數指針賦值給變量或作為參數傳遞,因為賦值或傳遞參數是會產生mov和push指令,這些指令需要直接地址。

    3.C++中的構造函數和析構函數賦值虛函數表指針,虛函數表中的每一項本身就是重定位項,為什么呢?大家自己考慮一下吧,不難哦~


    ---------------------?
    作者:evileagle?
    來源:CSDN?
    原文:https://blog.csdn.net/evileagle/article/details/12886949?
    版權聲明:本文為博主原創文章,轉載請附上博文鏈接!

    創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

    總結

    以上是生活随笔為你收集整理的【转】PE文件结构详解--(完整版)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    四虎永久在线精品免费网址 | 性做久久久久久久久 | 国产色精品久久人妻 | 一区二区传媒有限公司 | 亚洲成a人一区二区三区 | 欧美激情内射喷水高潮 | 国产精品亚洲综合色区韩国 | 国产成人无码a区在线观看视频app | 蜜桃av抽搐高潮一区二区 | 成人性做爰aaa片免费看不忠 | 精品无人国产偷自产在线 | 国产午夜福利亚洲第一 | 国产做国产爱免费视频 | 国产人妻人伦精品 | 亚洲精品国产品国语在线观看 | 亚洲国产精品无码久久久久高潮 | 国产成人精品必看 | 野外少妇愉情中文字幕 | 国产精品丝袜黑色高跟鞋 | 国产精品久久久久久亚洲毛片 | 色综合天天综合狠狠爱 | 影音先锋中文字幕无码 | 亚洲精品中文字幕乱码 | 精品久久8x国产免费观看 | 久久国内精品自在自线 | 久久精品女人天堂av免费观看 | 国产亚洲精品久久久久久久久动漫 | 国产精品高潮呻吟av久久 | 中文字幕日产无线码一区 | 人妻与老人中文字幕 | 欧美午夜特黄aaaaaa片 | 亚洲成a人片在线观看无码 | 成 人 网 站国产免费观看 | 天天摸天天透天天添 | 老司机亚洲精品影院无码 | 无码国模国产在线观看 | 风流少妇按摩来高潮 | 蜜桃臀无码内射一区二区三区 | 又色又爽又黄的美女裸体网站 | 2020最新国产自产精品 | 国产偷抇久久精品a片69 | 国产猛烈高潮尖叫视频免费 | 天堂亚洲2017在线观看 | 成人无码影片精品久久久 | 99er热精品视频 | 亚洲日韩av片在线观看 | 国产精品18久久久久久麻辣 | 无码精品人妻一区二区三区av | 国产精品永久免费视频 | 亚洲中文字幕在线无码一区二区 | 亚洲日韩av一区二区三区四区 | a在线观看免费网站大全 | 国产肉丝袜在线观看 | 欧美性生交活xxxxxdddd | 无码播放一区二区三区 | 免费人成网站视频在线观看 | 极品尤物被啪到呻吟喷水 | 亚洲精品一区二区三区在线观看 | 日本精品少妇一区二区三区 | 中文字幕无码热在线视频 | 玩弄少妇高潮ⅹxxxyw | 国产精品亚洲lv粉色 | 内射欧美老妇wbb | 麻豆国产人妻欲求不满谁演的 | 亚洲精品国产精品乱码视色 | 国产极品美女高潮无套在线观看 | 暴力强奷在线播放无码 | 性欧美牲交在线视频 | 青青草原综合久久大伊人精品 | 强伦人妻一区二区三区视频18 | 国产超碰人人爽人人做人人添 | 国产激情无码一区二区app | 天天燥日日燥 | 国产莉萝无码av在线播放 | 国产美女精品一区二区三区 | 久久久精品人妻久久影视 | 国产av人人夜夜澡人人爽麻豆 | 国产精品久久久 | 国产va免费精品观看 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲区欧美区综合区自拍区 | 亚洲成av人综合在线观看 | 三级4级全黄60分钟 | 欧美猛少妇色xxxxx | 日本一区二区更新不卡 | 欧美人与善在线com | 2020久久香蕉国产线看观看 | 巨爆乳无码视频在线观看 | 国内精品人妻无码久久久影院 | 无码帝国www无码专区色综合 | 性做久久久久久久免费看 | 亚洲另类伦春色综合小说 | 国内丰满熟女出轨videos | 强辱丰满人妻hd中文字幕 | 亚洲另类伦春色综合小说 | 国产亚洲精品久久久闺蜜 | 亚洲の无码国产の无码影院 | 亚洲日韩av片在线观看 | 日韩成人一区二区三区在线观看 | 国产午夜视频在线观看 | 亚洲中文无码av永久不收费 | 久久久久成人精品免费播放动漫 | 成人片黄网站色大片免费观看 | 亚洲中文字幕在线观看 | 18无码粉嫩小泬无套在线观看 | 宝宝好涨水快流出来免费视频 | 人妻中文无码久热丝袜 | 少妇人妻偷人精品无码视频 | 中文字幕无码av激情不卡 | 人人超人人超碰超国产 | av人摸人人人澡人人超碰下载 | 日韩欧美中文字幕公布 | 丁香啪啪综合成人亚洲 | 国产精品久久久久无码av色戒 | 久久无码人妻影院 | 免费视频欧美无人区码 | 精品久久久无码中文字幕 | 女人被男人爽到呻吟的视频 | 欧美xxxxx精品 | 日韩精品成人一区二区三区 | 日韩精品无码免费一区二区三区 | 一区二区三区乱码在线 | 欧洲 | 亚洲国产精华液网站w | 成人动漫在线观看 | 亚洲成av人片在线观看无码不卡 | 久久综合色之久久综合 | 夜夜躁日日躁狠狠久久av | 日韩精品乱码av一区二区 | 欧美兽交xxxx×视频 | 午夜福利试看120秒体验区 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲成熟女人毛毛耸耸多 | 撕开奶罩揉吮奶头视频 | 牲欲强的熟妇农村老妇女 | 国产激情一区二区三区 | 久久熟妇人妻午夜寂寞影院 | 亚洲色欲色欲天天天www | 色噜噜亚洲男人的天堂 | 在线亚洲高清揄拍自拍一品区 | 亚洲综合无码久久精品综合 | 精品国精品国产自在久国产87 | 成人三级无码视频在线观看 | 欧美人与禽猛交狂配 | 国产精品久久精品三级 | 久久99久久99精品中文字幕 | 中文无码精品a∨在线观看不卡 | 黑人粗大猛烈进出高潮视频 | 自拍偷自拍亚洲精品被多人伦好爽 | 日本www一道久久久免费榴莲 | 国产精品亚洲一区二区三区喷水 | 亚洲一区二区观看播放 | 中文字幕日韩精品一区二区三区 | 国产精品igao视频网 | 一个人免费观看的www视频 | 国产香蕉尹人视频在线 | 久久久久久久人妻无码中文字幕爆 | 特大黑人娇小亚洲女 | 欧美喷潮久久久xxxxx | 欧美激情综合亚洲一二区 | 国产97色在线 | 免 | 亚洲无人区午夜福利码高清完整版 | 欧美日韩亚洲国产精品 | 午夜福利试看120秒体验区 | 亚洲成av人综合在线观看 | 午夜精品一区二区三区在线观看 | 日韩精品无码免费一区二区三区 | 国内老熟妇对白xxxxhd | 亚洲精品国偷拍自产在线麻豆 | 欧美日韩在线亚洲综合国产人 | 午夜无码区在线观看 | 免费观看又污又黄的网站 | 色欲久久久天天天综合网精品 | 日韩在线不卡免费视频一区 | 真人与拘做受免费视频 | 日日噜噜噜噜夜夜爽亚洲精品 | 老子影院午夜伦不卡 | 性色欲情网站iwww九文堂 | 内射后入在线观看一区 | 图片区 小说区 区 亚洲五月 | 7777奇米四色成人眼影 | 亚洲狠狠婷婷综合久久 | 亚洲精品一区三区三区在线观看 | 97精品人妻一区二区三区香蕉 | 女人被爽到呻吟gif动态图视看 | 精品久久久中文字幕人妻 | 欧美亚洲日韩国产人成在线播放 | 亚洲精品中文字幕久久久久 | 亚洲国产日韩a在线播放 | 欧美精品国产综合久久 | 国产成人无码区免费内射一片色欲 | 俺去俺来也www色官网 | 又大又硬又爽免费视频 | 无码国内精品人妻少妇 | 黑人粗大猛烈进出高潮视频 | 啦啦啦www在线观看免费视频 | 国产精品99久久精品爆乳 | 精品厕所偷拍各类美女tp嘘嘘 | 又粗又大又硬毛片免费看 | 亚洲国产精品美女久久久久 | 亚洲国产精品美女久久久久 | 精品人妻av区 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 牲欲强的熟妇农村老妇女视频 | 国产精品手机免费 | 欧美zoozzooz性欧美 | 国产黑色丝袜在线播放 | 亚洲综合伊人久久大杳蕉 | 清纯唯美经典一区二区 | 中文字幕色婷婷在线视频 | 欧美日韩色另类综合 | 色爱情人网站 | 中文字幕av无码一区二区三区电影 | 无码人妻精品一区二区三区下载 | 女人被爽到呻吟gif动态图视看 | 日本一区二区三区免费播放 | 波多野结衣乳巨码无在线观看 | 精品国产乱码久久久久乱码 | 国语自产偷拍精品视频偷 | 无码吃奶揉捏奶头高潮视频 | 高潮毛片无遮挡高清免费 | 婷婷丁香六月激情综合啪 | 亚洲伊人久久精品影院 | 亚洲精品国产品国语在线观看 | 欧美日韩一区二区免费视频 | 午夜嘿嘿嘿影院 | 最近中文2019字幕第二页 | 成人精品天堂一区二区三区 | 成人动漫在线观看 | 综合网日日天干夜夜久久 | 成年美女黄网站色大免费视频 | 国产乱人偷精品人妻a片 | 亚洲国产综合无码一区 | 六月丁香婷婷色狠狠久久 | 四虎4hu永久免费 | 色综合天天综合狠狠爱 | 2020久久超碰国产精品最新 | av在线亚洲欧洲日产一区二区 | 性啪啪chinese东北女人 | 国产亚洲人成a在线v网站 | 国产又粗又硬又大爽黄老大爷视 | 狠狠色噜噜狠狠狠狠7777米奇 | 中文字幕日韩精品一区二区三区 | 亚洲 日韩 欧美 成人 在线观看 | 波多野结衣av在线观看 | 成年美女黄网站色大免费视频 | 亚洲欧美精品伊人久久 | 久久久久久av无码免费看大片 | 久久综合激激的五月天 | 国产精品国产三级国产专播 | 性欧美videos高清精品 | 女人被男人爽到呻吟的视频 | 欧美性色19p | 精品无码国产自产拍在线观看蜜 | 久久精品国产一区二区三区 | 狂野欧美激情性xxxx | 荡女精品导航 | 国产人妻精品午夜福利免费 | 久久人人爽人人爽人人片ⅴ | 亚洲精品中文字幕 | 性色av无码免费一区二区三区 | 久久午夜无码鲁丝片 | 台湾无码一区二区 | 国产免费无码一区二区视频 | 精品偷自拍另类在线观看 | 在线观看国产午夜福利片 | 中文字幕 亚洲精品 第1页 | 久久久精品成人免费观看 | 好男人社区资源 | 一本久道久久综合婷婷五月 | 大肉大捧一进一出视频出来呀 | 欧美zoozzooz性欧美 | 日日摸日日碰夜夜爽av | 国产av一区二区精品久久凹凸 | 奇米影视7777久久精品 | 亚洲爆乳精品无码一区二区三区 | 伊人久久大香线焦av综合影院 | 色婷婷香蕉在线一区二区 | 国产精品国产自线拍免费软件 | 国产成人无码av一区二区 | 国产精品多人p群无码 | 青青久在线视频免费观看 | 一个人看的www免费视频在线观看 | 国产综合色产在线精品 | 精品 日韩 国产 欧美 视频 | 成人性做爰aaa片免费看不忠 | 欧美日韩一区二区免费视频 | 国产精品办公室沙发 | 麻豆蜜桃av蜜臀av色欲av | 日本熟妇大屁股人妻 | 永久黄网站色视频免费直播 | 在线播放亚洲第一字幕 | 久久综合色之久久综合 | 国产乱人伦偷精品视频 | 中文字幕 人妻熟女 | 狠狠色丁香久久婷婷综合五月 | 国产av久久久久精东av | 无码吃奶揉捏奶头高潮视频 | 色 综合 欧美 亚洲 国产 | 中文字幕人成乱码熟女app | 久久久久久久人妻无码中文字幕爆 | 国产 浪潮av性色四虎 | 国产精品无码永久免费888 | 日本成熟视频免费视频 | 丰满少妇熟乱xxxxx视频 | 精品国产福利一区二区 | 亚洲欧美国产精品专区久久 | 国产精品无码一区二区桃花视频 | 欧美老熟妇乱xxxxx | 国产乱人偷精品人妻a片 | 亚洲色欲色欲欲www在线 | 99视频精品全部免费免费观看 | 欧美老人巨大xxxx做受 | 三上悠亚人妻中文字幕在线 | 国产成人一区二区三区在线观看 | 国产成人精品必看 | 国产亚洲日韩欧美另类第八页 | 亚洲国产精品毛片av不卡在线 | 欧美成人午夜精品久久久 | 小泽玛莉亚一区二区视频在线 | 无码毛片视频一区二区本码 | 特级做a爰片毛片免费69 | 欧美日本精品一区二区三区 | 丰腴饱满的极品熟妇 | 无码任你躁久久久久久久 | 国产亚洲视频中文字幕97精品 | 熟女体下毛毛黑森林 | 初尝人妻少妇中文字幕 | 麻豆精品国产精华精华液好用吗 | 亚洲人交乣女bbw | 国产成人久久精品流白浆 | 欧美日韩久久久精品a片 | 美女扒开屁股让男人桶 | 欧美野外疯狂做受xxxx高潮 | 美女极度色诱视频国产 | 99久久久国产精品无码免费 | 国产在线精品一区二区三区直播 | 人妻体内射精一区二区三四 | 俺去俺来也在线www色官网 | 美女黄网站人色视频免费国产 | 欧美三级a做爰在线观看 | 97久久精品无码一区二区 | 蜜臀av在线播放 久久综合激激的五月天 | 一个人看的视频www在线 | 色一情一乱一伦一区二区三欧美 | 麻豆精产国品 | 国产亚洲tv在线观看 | 男女下面进入的视频免费午夜 | 免费看少妇作爱视频 | 国色天香社区在线视频 | 日韩视频 中文字幕 视频一区 | 国产成人无码午夜视频在线观看 | 国产午夜福利100集发布 | 宝宝好涨水快流出来免费视频 | 纯爱无遮挡h肉动漫在线播放 | 麻豆蜜桃av蜜臀av色欲av | 久久精品99久久香蕉国产色戒 | 成人欧美一区二区三区黑人免费 | 国产97在线 | 亚洲 | 国产国语老龄妇女a片 | 精品久久久久久人妻无码中文字幕 | 内射巨臀欧美在线视频 | 人妻aⅴ无码一区二区三区 | 国产精品久久久午夜夜伦鲁鲁 | 欧洲欧美人成视频在线 | 亚洲无人区一区二区三区 | 永久免费精品精品永久-夜色 | 中文毛片无遮挡高清免费 | 5858s亚洲色大成网站www | 亚洲熟悉妇女xxx妇女av | 激情内射亚州一区二区三区爱妻 | 人妻无码αv中文字幕久久琪琪布 | 成人免费视频视频在线观看 免费 | 久久久久99精品成人片 | 亚洲娇小与黑人巨大交 | 人妻插b视频一区二区三区 | 久久午夜无码鲁丝片 | 成年美女黄网站色大免费视频 | 国产免费观看黄av片 | 欧美人与物videos另类 | 清纯唯美经典一区二区 | 狠狠色欧美亚洲狠狠色www | 美女张开腿让人桶 | 少妇性l交大片欧洲热妇乱xxx | 亚洲精品久久久久久一区二区 | 激情五月综合色婷婷一区二区 | 亚洲欧美色中文字幕在线 | 国产成人无码a区在线观看视频app | 日韩欧美中文字幕在线三区 | 高潮毛片无遮挡高清免费视频 | 在线а√天堂中文官网 | 国产国产精品人在线视 | 麻豆蜜桃av蜜臀av色欲av | 日韩精品a片一区二区三区妖精 | 国产又爽又猛又粗的视频a片 | 欧美变态另类xxxx | 99精品视频在线观看免费 | 亚洲欧美日韩国产精品一区二区 | 亚洲无人区一区二区三区 | 国产日产欧产精品精品app | 久青草影院在线观看国产 | 狠狠色色综合网站 | 欧美zoozzooz性欧美 | 成年美女黄网站色大免费全看 | 水蜜桃亚洲一二三四在线 | 久久久精品欧美一区二区免费 | 国产成人综合色在线观看网站 | 久久久久se色偷偷亚洲精品av | 波多野结衣av一区二区全免费观看 | 亚洲精品午夜无码电影网 | 亚洲成av人片天堂网无码】 | 国产香蕉尹人视频在线 | 成人欧美一区二区三区黑人免费 | 日韩av激情在线观看 | 欧美日韩久久久精品a片 | 2020久久香蕉国产线看观看 | 18禁止看的免费污网站 | 精品一区二区三区波多野结衣 | 免费网站看v片在线18禁无码 | 夫妻免费无码v看片 | 国产亚av手机在线观看 | 久久无码专区国产精品s | 成年美女黄网站色大免费全看 | 欧美精品无码一区二区三区 | 精品国产一区二区三区四区在线看 | 一本加勒比波多野结衣 | 欧美性生交活xxxxxdddd | 亚洲熟妇自偷自拍另类 | 国产精品人人爽人人做我的可爱 | 55夜色66夜色国产精品视频 | 天堂а√在线中文在线 | 在线看片无码永久免费视频 | 国产情侣作爱视频免费观看 | 玩弄中年熟妇正在播放 | 四虎影视成人永久免费观看视频 | 国精产品一品二品国精品69xx | 少妇人妻大乳在线视频 | 国产激情无码一区二区app | 亚洲春色在线视频 | 少妇性俱乐部纵欲狂欢电影 | 无码人妻精品一区二区三区下载 | 76少妇精品导航 | 亚洲娇小与黑人巨大交 | 免费国产成人高清在线观看网站 | 日韩精品无码免费一区二区三区 | 欧美老妇交乱视频在线观看 | 国内精品人妻无码久久久影院 | 99视频精品全部免费免费观看 | 99久久久无码国产aaa精品 | 少妇一晚三次一区二区三区 | 国产两女互慰高潮视频在线观看 | 99国产精品白浆在线观看免费 | 2019nv天堂香蕉在线观看 | 亚洲国产av美女网站 | 日本精品人妻无码免费大全 | 少妇人妻偷人精品无码视频 | 国内精品久久久久久中文字幕 | 狠狠色丁香久久婷婷综合五月 | 在线亚洲高清揄拍自拍一品区 | 久久亚洲精品中文字幕无男同 | 熟妇人妻激情偷爽文 | 99精品国产综合久久久久五月天 | 久久精品中文字幕一区 | 国内揄拍国内精品少妇国语 | 青青草原综合久久大伊人精品 | 台湾无码一区二区 | 青春草在线视频免费观看 | 亚洲成av人片在线观看无码不卡 | 国产成人精品三级麻豆 | 精品国产av色一区二区深夜久久 | 日韩精品a片一区二区三区妖精 | 亚洲国产成人av在线观看 | 亚洲区欧美区综合区自拍区 | 久久午夜无码鲁丝片午夜精品 | 色爱情人网站 | 学生妹亚洲一区二区 | 久久99精品国产麻豆 | 高清无码午夜福利视频 | 国产乱码精品一品二品 | 牲交欧美兽交欧美 | 久久久久久久女国产乱让韩 | 影音先锋中文字幕无码 | 色欲av亚洲一区无码少妇 | 无码中文字幕色专区 | 国色天香社区在线视频 | 亚洲熟悉妇女xxx妇女av | 国产97色在线 | 免 | 国产特级毛片aaaaaa高潮流水 | 天堂在线观看www | 国产性生大片免费观看性 | 精品国产乱码久久久久乱码 | 国产一精品一av一免费 | 一本色道婷婷久久欧美 | 啦啦啦www在线观看免费视频 | 国产麻豆精品精东影业av网站 | 国产精品鲁鲁鲁 | 熟妇人妻激情偷爽文 | 漂亮人妻洗澡被公强 日日躁 | 中文字幕精品av一区二区五区 | 国产人妻大战黑人第1集 | 最近的中文字幕在线看视频 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲欧美日韩成人高清在线一区 | 丁香啪啪综合成人亚洲 | 青春草在线视频免费观看 | 久久zyz资源站无码中文动漫 | 国产精华av午夜在线观看 | 日本乱人伦片中文三区 | 国产精品永久免费视频 | 色老头在线一区二区三区 | 日日碰狠狠躁久久躁蜜桃 | 久久 国产 尿 小便 嘘嘘 | 国产亚洲欧美在线专区 | 久久久久成人片免费观看蜜芽 | 精品无人区无码乱码毛片国产 | 一本久久a久久精品亚洲 | 精品一区二区三区波多野结衣 | 日韩精品久久久肉伦网站 | av无码不卡在线观看免费 | 沈阳熟女露脸对白视频 | 99久久婷婷国产综合精品青草免费 | 图片小说视频一区二区 | 亚洲日韩一区二区三区 | 亚洲色偷偷偷综合网 | 丰满少妇熟乱xxxxx视频 | 日韩av无码中文无码电影 | 丰满肥臀大屁股熟妇激情视频 | 日日噜噜噜噜夜夜爽亚洲精品 | 亚洲综合在线一区二区三区 | 日本又色又爽又黄的a片18禁 | 强奷人妻日本中文字幕 | 一区二区传媒有限公司 | 免费人成在线观看网站 | 欧美日韩色另类综合 | 国产高清不卡无码视频 | 国产又爽又猛又粗的视频a片 | 国产欧美熟妇另类久久久 | 乱人伦人妻中文字幕无码久久网 | 自拍偷自拍亚洲精品10p | 国产内射爽爽大片视频社区在线 | 福利一区二区三区视频在线观看 | 久久www免费人成人片 | 亚洲日本一区二区三区在线 | 中文无码成人免费视频在线观看 | 在线播放亚洲第一字幕 | 性开放的女人aaa片 | 全球成人中文在线 | 国产av无码专区亚洲a∨毛片 | 黑人大群体交免费视频 | 动漫av网站免费观看 | 欧美性生交活xxxxxdddd | www成人国产高清内射 | 午夜精品一区二区三区的区别 | 日本丰满护士爆乳xxxx | 99精品视频在线观看免费 | 亚洲区小说区激情区图片区 | 国产精品人人妻人人爽 | 久久精品成人欧美大片 | 日韩视频 中文字幕 视频一区 | 激情内射日本一区二区三区 | 日产精品高潮呻吟av久久 | 欧美阿v高清资源不卡在线播放 | 伊人色综合久久天天小片 | 精品国产av色一区二区深夜久久 | 久久久久久av无码免费看大片 | 亚洲色大成网站www国产 | 国产精品嫩草久久久久 | 国产区女主播在线观看 | 熟女少妇在线视频播放 | √天堂中文官网8在线 | 精品熟女少妇av免费观看 | 中文字幕色婷婷在线视频 | 99精品久久毛片a片 | 久久久久人妻一区精品色欧美 | 日日摸日日碰夜夜爽av | 波多野结衣高清一区二区三区 | 东京无码熟妇人妻av在线网址 | 亚洲s码欧洲m码国产av | 亚洲理论电影在线观看 | 中文字幕乱码人妻二区三区 | 无码精品人妻一区二区三区av | 最新版天堂资源中文官网 | 国产精品成人av在线观看 | 中文字幕乱码亚洲无线三区 | 欧美熟妇另类久久久久久多毛 | 亚洲国产精品久久久天堂 | 精品久久综合1区2区3区激情 | 国产精品va在线观看无码 | 国产成人综合在线女婷五月99播放 | 一二三四在线观看免费视频 | 久久久久人妻一区精品色欧美 | 无码人妻少妇伦在线电影 | 免费网站看v片在线18禁无码 | 国产亚洲精品久久久闺蜜 | 动漫av一区二区在线观看 | 久久99精品久久久久久动态图 | 精品久久久久久人妻无码中文字幕 | 亚洲欧美精品伊人久久 | 国产婷婷色一区二区三区在线 | 无码免费一区二区三区 | 色欲久久久天天天综合网精品 | 欧美性猛交内射兽交老熟妇 | 日日碰狠狠躁久久躁蜜桃 | 乱人伦人妻中文字幕无码 | 午夜无码区在线观看 | 亚洲成熟女人毛毛耸耸多 | 色欲久久久天天天综合网精品 | а√天堂www在线天堂小说 | 青青青手机频在线观看 | 人人澡人人透人人爽 | 内射白嫩少妇超碰 | 人人妻人人澡人人爽精品欧美 | 中文字幕乱码人妻无码久久 | 欧美国产亚洲日韩在线二区 | 国产亚洲精品精品国产亚洲综合 | 午夜精品久久久内射近拍高清 | 欧美性黑人极品hd | 人妻少妇精品久久 | 国产精品va在线播放 | 岛国片人妻三上悠亚 | a在线亚洲男人的天堂 | 亚洲第一网站男人都懂 | 99国产欧美久久久精品 | 日韩av无码中文无码电影 | 天天拍夜夜添久久精品大 | 日本一区二区三区免费高清 | 亚洲日韩精品欧美一区二区 | 亚洲精品一区二区三区四区五区 | 中文字幕久久久久人妻 | 波多野结衣av一区二区全免费观看 | 377p欧洲日本亚洲大胆 | 精品国产乱码久久久久乱码 | 欧美肥老太牲交大战 | 超碰97人人做人人爱少妇 | 色欲av亚洲一区无码少妇 | 亚洲精品综合五月久久小说 | 国产精品免费大片 | 国产精品美女久久久久av爽李琼 | 无码av岛国片在线播放 | 久久国产精品精品国产色婷婷 | 51国偷自产一区二区三区 | 久久精品成人欧美大片 | 国产无套内射久久久国产 | 88国产精品欧美一区二区三区 | 欧美zoozzooz性欧美 | 国产精品.xx视频.xxtv | 熟妇人妻中文av无码 | 国产精品-区区久久久狼 | 日日碰狠狠躁久久躁蜜桃 | 乱人伦中文视频在线观看 | 日本一卡2卡3卡四卡精品网站 | 亚洲国产欧美日韩精品一区二区三区 | 国内揄拍国内精品人妻 | 中文字幕无码乱人伦 | 无码国模国产在线观看 | 欧美日韩在线亚洲综合国产人 | 日本www一道久久久免费榴莲 | 5858s亚洲色大成网站www | 正在播放老肥熟妇露脸 | 久久亚洲中文字幕无码 | 日本肉体xxxx裸交 | 国产成人精品一区二区在线小狼 | a国产一区二区免费入口 | 免费无码一区二区三区蜜桃大 | 亚洲成a人片在线观看无码 | 黄网在线观看免费网站 | 对白脏话肉麻粗话av | 99麻豆久久久国产精品免费 | 中文无码精品a∨在线观看不卡 | 国产情侣作爱视频免费观看 | 少妇高潮一区二区三区99 | 亚洲欧洲日本综合aⅴ在线 | 小sao货水好多真紧h无码视频 | 国产一区二区三区日韩精品 | 亚洲性无码av中文字幕 | 亚洲精品一区二区三区大桥未久 | 亚洲天堂2017无码 | 亚洲成av人综合在线观看 | 一区二区传媒有限公司 | 好男人社区资源 | 久久熟妇人妻午夜寂寞影院 | 97久久精品无码一区二区 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲人亚洲人成电影网站色 | 久久国产精品萌白酱免费 | 精品国产乱码久久久久乱码 | 天堂一区人妻无码 | 精品成人av一区二区三区 | 帮老师解开蕾丝奶罩吸乳网站 | 激情内射亚州一区二区三区爱妻 | www国产亚洲精品久久网站 | 九九在线中文字幕无码 | 精品久久综合1区2区3区激情 | 久久www免费人成人片 | 国产香蕉尹人视频在线 | 欧美老人巨大xxxx做受 | 97精品国产97久久久久久免费 | 亚洲aⅴ无码成人网站国产app | 日韩人妻无码中文字幕视频 | 少妇被粗大的猛进出69影院 | 强辱丰满人妻hd中文字幕 | 人妻少妇精品无码专区动漫 | 久久亚洲精品成人无码 | 欧洲熟妇色 欧美 | 爽爽影院免费观看 | 日韩精品一区二区av在线 | 丰满人妻一区二区三区免费视频 | 国产亚洲精品久久久闺蜜 | 国产欧美熟妇另类久久久 | 久久久中文字幕日本无吗 | 国产精品永久免费视频 | 久久午夜无码鲁丝片秋霞 | 伊人久久婷婷五月综合97色 | 国产午夜无码精品免费看 | 在线播放亚洲第一字幕 | av小次郎收藏 | 真人与拘做受免费视频一 | 色综合久久中文娱乐网 | 男人和女人高潮免费网站 | 中国女人内谢69xxxxxa片 | 亚洲啪av永久无码精品放毛片 | 高清国产亚洲精品自在久久 | 噜噜噜亚洲色成人网站 | 麻豆国产人妻欲求不满谁演的 | 纯爱无遮挡h肉动漫在线播放 | 人人爽人人澡人人高潮 | 国产性生交xxxxx无码 | 精品久久久久久亚洲精品 | 蜜桃臀无码内射一区二区三区 | 精品日本一区二区三区在线观看 | 国产激情综合五月久久 | 免费乱码人妻系列无码专区 | 日韩精品无码免费一区二区三区 | 自拍偷自拍亚洲精品10p | 精品aⅴ一区二区三区 | 日韩精品一区二区av在线 | 波多野42部无码喷潮在线 | 国产va免费精品观看 | 东京热男人av天堂 | 国产午夜亚洲精品不卡下载 | 又粗又大又硬又长又爽 | 在线成人www免费观看视频 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 成人精品一区二区三区中文字幕 | 思思久久99热只有频精品66 | 国产三级久久久精品麻豆三级 | 国产极品美女高潮无套在线观看 | 国产亚洲精品久久久久久久 | 亚洲精品一区二区三区在线观看 | av无码不卡在线观看免费 | 亚洲综合另类小说色区 | 欧美大屁股xxxxhd黑色 | 国产又爽又猛又粗的视频a片 | 久久精品国产精品国产精品污 | 久久人人爽人人人人片 | 色欲av亚洲一区无码少妇 | 88国产精品欧美一区二区三区 | 欧美第一黄网免费网站 | 亚洲精品国产a久久久久久 | 欧美日韩在线亚洲综合国产人 | 99精品视频在线观看免费 | 内射爽无广熟女亚洲 | 国产精品va在线播放 | 亚洲国产精品久久久天堂 | 国产av无码专区亚洲a∨毛片 | 亚洲成a人片在线观看无码 | 麻花豆传媒剧国产免费mv在线 | 一本久久伊人热热精品中文字幕 | 亚洲码国产精品高潮在线 | 国产精品美女久久久 | 欧美日本精品一区二区三区 | 乌克兰少妇xxxx做受 | 九九热爱视频精品 | 300部国产真实乱 | 欧美日韩一区二区三区自拍 | 狠狠色丁香久久婷婷综合五月 | 美女毛片一区二区三区四区 | 在线欧美精品一区二区三区 | 亚洲精品www久久久 | 亚洲高清偷拍一区二区三区 | 无码帝国www无码专区色综合 | 粉嫩少妇内射浓精videos | 国产sm调教视频在线观看 | 狠狠色色综合网站 | av无码电影一区二区三区 | 国产亚洲精品久久久ai换 | 色婷婷欧美在线播放内射 | 国产激情精品一区二区三区 | 国产精品久久久久久无码 | 亚洲国产精品无码一区二区三区 | 久久人妻内射无码一区三区 | 撕开奶罩揉吮奶头视频 | 牲欲强的熟妇农村老妇女视频 | 久久久成人毛片无码 | 大地资源网第二页免费观看 | 国产欧美精品一区二区三区 | 又大又黄又粗又爽的免费视频 | 特级做a爰片毛片免费69 | 成人一在线视频日韩国产 | 亚洲中文字幕乱码av波多ji | 亚洲理论电影在线观看 | 人人妻人人澡人人爽人人精品浪潮 | 狠狠色色综合网站 | √8天堂资源地址中文在线 | 荫蒂添的好舒服视频囗交 | 亚洲精品一区二区三区婷婷月 | 婷婷丁香五月天综合东京热 | 国产麻豆精品一区二区三区v视界 | 人妻无码αv中文字幕久久琪琪布 | 日本一本二本三区免费 | 男人的天堂2018无码 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 天堂无码人妻精品一区二区三区 | 亚洲七七久久桃花影院 | 女高中生第一次破苞av | 亚洲综合久久一区二区 | 中文无码精品a∨在线观看不卡 | 色一情一乱一伦一区二区三欧美 | 国产成人综合色在线观看网站 | 亚洲七七久久桃花影院 | 亚洲男女内射在线播放 | 波多野结衣av在线观看 | 久久精品人人做人人综合试看 | 综合激情五月综合激情五月激情1 | 黑人巨大精品欧美一区二区 | 亚洲 激情 小说 另类 欧美 | 欧美自拍另类欧美综合图片区 | 欧美人与善在线com | 丰满少妇弄高潮了www | 99精品视频在线观看免费 | 国产网红无码精品视频 | 国内精品一区二区三区不卡 | 亚洲区小说区激情区图片区 | 狠狠色色综合网站 | 久精品国产欧美亚洲色aⅴ大片 | 久久精品无码一区二区三区 | 国产人妻精品一区二区三区 | 强开小婷嫩苞又嫩又紧视频 | 欧美老熟妇乱xxxxx | 久久精品99久久香蕉国产色戒 | 麻豆国产人妻欲求不满 | 欧美国产日韩亚洲中文 | 成熟妇人a片免费看网站 | 99久久精品日本一区二区免费 | 99久久99久久免费精品蜜桃 | 99精品国产综合久久久久五月天 | 久久99精品国产.久久久久 | 精品一区二区三区波多野结衣 | 久久综合九色综合欧美狠狠 | 内射巨臀欧美在线视频 | 国产精品亚洲综合色区韩国 | 精品欧美一区二区三区久久久 | 欧美猛少妇色xxxxx | 人妻天天爽夜夜爽一区二区 | 免费男性肉肉影院 | 中文字幕无码乱人伦 | 成人精品视频一区二区 | 国产激情无码一区二区 | 麻豆av传媒蜜桃天美传媒 | 亚洲综合色区中文字幕 | av香港经典三级级 在线 | 久久99精品久久久久久 | 天天摸天天透天天添 | 激情人妻另类人妻伦 | 天堂一区人妻无码 | 精品成人av一区二区三区 | 久久久久久久人妻无码中文字幕爆 | 特黄特色大片免费播放器图片 | 日产国产精品亚洲系列 | 欧美熟妇另类久久久久久不卡 | 无码av免费一区二区三区试看 | 人人妻人人澡人人爽人人精品浪潮 | 日本一区二区三区免费播放 | 午夜精品一区二区三区在线观看 | 波多野结衣高清一区二区三区 | 又粗又大又硬毛片免费看 | 欧美日本精品一区二区三区 | 精品国产青草久久久久福利 | 俄罗斯老熟妇色xxxx | 午夜福利试看120秒体验区 | 亚洲人成人无码网www国产 | 理论片87福利理论电影 | 欧洲熟妇精品视频 | 精品人妻中文字幕有码在线 | 蜜桃无码一区二区三区 | 人人爽人人爽人人片av亚洲 | 麻豆国产人妻欲求不满 | 丰满少妇熟乱xxxxx视频 | 在线观看免费人成视频 | 欧美黑人巨大xxxxx | 97色伦图片97综合影院 | 美女扒开屁股让男人桶 | 成年美女黄网站色大免费视频 | 久久这里只有精品视频9 | 国产亚洲精品久久久久久国模美 | 性欧美牲交xxxxx视频 | 成人无码视频免费播放 | 图片小说视频一区二区 | 免费人成在线视频无码 | 色欲av亚洲一区无码少妇 | 狠狠躁日日躁夜夜躁2020 | 内射爽无广熟女亚洲 | 久久久久久久女国产乱让韩 | 2020久久超碰国产精品最新 | 欧美三级a做爰在线观看 | 国精品人妻无码一区二区三区蜜柚 | 久久99久久99精品中文字幕 | 久久国产劲爆∧v内射 | 樱花草在线社区www | 欧美日本日韩 | 暴力强奷在线播放无码 | 久久久精品成人免费观看 | 初尝人妻少妇中文字幕 | 欧美放荡的少妇 | 强伦人妻一区二区三区视频18 | 色综合久久久无码网中文 | 久久99精品国产.久久久久 | v一区无码内射国产 | 四虎永久在线精品免费网址 | 久久精品99久久香蕉国产色戒 | 无码纯肉视频在线观看 | 国产激情无码一区二区app | 欧美精品在线观看 | 天堂а√在线中文在线 | 欧美老妇与禽交 | 国产在线精品一区二区三区直播 | 真人与拘做受免费视频 | 国产精品爱久久久久久久 | 九九在线中文字幕无码 | 国产一区二区三区四区五区加勒比 | 精品一区二区三区无码免费视频 | 成人欧美一区二区三区黑人免费 | 久精品国产欧美亚洲色aⅴ大片 | 国产综合久久久久鬼色 | 377p欧洲日本亚洲大胆 | 无码人妻av免费一区二区三区 | 午夜福利一区二区三区在线观看 | 亚洲熟妇色xxxxx亚洲 | 免费人成在线观看网站 | 人人妻人人澡人人爽人人精品 | 好爽又高潮了毛片免费下载 | 黑人巨大精品欧美黑寡妇 | 中国女人内谢69xxxx | 婷婷六月久久综合丁香 | 无码人妻丰满熟妇区五十路百度 | 国产精品欧美成人 | 国产人成高清在线视频99最全资源 | 四十如虎的丰满熟妇啪啪 | 欧美精品无码一区二区三区 | 大色综合色综合网站 | 狠狠亚洲超碰狼人久久 | 无码国产色欲xxxxx视频 | 国产美女精品一区二区三区 | 乌克兰少妇xxxx做受 | 一本久久a久久精品vr综合 | 午夜理论片yy44880影院 | 东京热无码av男人的天堂 | 久久国产精品_国产精品 | 亚洲精品国产品国语在线观看 | 宝宝好涨水快流出来免费视频 | 欧美亚洲国产一区二区三区 | 永久免费观看美女裸体的网站 | 激情亚洲一区国产精品 | 国产乱人偷精品人妻a片 | 国产精品人人爽人人做我的可爱 | 国产免费久久精品国产传媒 | 乱人伦人妻中文字幕无码 | 国产欧美熟妇另类久久久 | 亚洲а∨天堂久久精品2021 | 午夜福利一区二区三区在线观看 | 永久黄网站色视频免费直播 | 综合网日日天干夜夜久久 | 精品久久久久久亚洲精品 | 老头边吃奶边弄进去呻吟 | 人妻天天爽夜夜爽一区二区 | 日韩精品a片一区二区三区妖精 | 国产精品-区区久久久狼 | 玩弄人妻少妇500系列视频 | 正在播放东北夫妻内射 | 亚洲中文字幕在线观看 | 国产又粗又硬又大爽黄老大爷视 | 精品久久久久久亚洲精品 | 亚洲人成无码网www | 少妇一晚三次一区二区三区 | 国产熟妇高潮叫床视频播放 | 狠狠色欧美亚洲狠狠色www | 女人被男人躁得好爽免费视频 | 国产黑色丝袜在线播放 | 日本护士xxxxhd少妇 | 无码一区二区三区在线观看 | 国产乱人偷精品人妻a片 | 国产色视频一区二区三区 | 女人被男人爽到呻吟的视频 | 又色又爽又黄的美女裸体网站 | 欧美三级a做爰在线观看 | 国产一区二区不卡老阿姨 | 久久精品人人做人人综合 | 人妻尝试又大又粗久久 | 99久久精品无码一区二区毛片 | 欧美freesex黑人又粗又大 | av人摸人人人澡人人超碰下载 | 亚洲精品鲁一鲁一区二区三区 | 国内丰满熟女出轨videos | 熟女少妇在线视频播放 | 久热国产vs视频在线观看 | 蜜桃无码一区二区三区 | 国产人妻人伦精品 | 亚洲欧美精品aaaaaa片 | 日本一卡二卡不卡视频查询 | 精品无人国产偷自产在线 | 蜜桃无码一区二区三区 | 亚洲s色大片在线观看 | 无遮无挡爽爽免费视频 | 无码精品国产va在线观看dvd | 国产激情精品一区二区三区 | 麻豆成人精品国产免费 | 国产精品久久久久久久影院 | 亚洲色在线无码国产精品不卡 | 国产suv精品一区二区五 | 久久亚洲中文字幕无码 | 影音先锋中文字幕无码 | 在线欧美精品一区二区三区 | 国产熟女一区二区三区四区五区 | 清纯唯美经典一区二区 | 亚洲 a v无 码免 费 成 人 a v | 亚洲欧美日韩综合久久久 | 欧美三级a做爰在线观看 | 国产成人综合色在线观看网站 | 18禁黄网站男男禁片免费观看 | 国产成人无码午夜视频在线观看 | 国产精品欧美成人 | 久久99久久99精品中文字幕 | 人妻少妇精品无码专区动漫 | 熟女少妇人妻中文字幕 | 男女超爽视频免费播放 | 2020久久超碰国产精品最新 | 国产精品毛多多水多 | 99视频精品全部免费免费观看 | 国产精品第一国产精品 | 久久99精品国产.久久久久 | 亚洲va中文字幕无码久久不卡 | 一本大道伊人av久久综合 | 搡女人真爽免费视频大全 | 99er热精品视频 | 国产精品资源一区二区 | 亚洲中文字幕va福利 | 亚洲一区二区三区四区 | 欧美日本免费一区二区三区 | 成人精品一区二区三区中文字幕 | 日韩 欧美 动漫 国产 制服 | 欧美亚洲国产一区二区三区 | 强辱丰满人妻hd中文字幕 | 国产精品-区区久久久狼 | 欧美精品一区二区精品久久 | 午夜精品久久久久久久久 | 欧美亚洲日韩国产人成在线播放 | 乱人伦人妻中文字幕无码久久网 | 色综合天天综合狠狠爱 | 国产精品亚洲专区无码不卡 | 久久久久se色偷偷亚洲精品av | 欧美日韩一区二区免费视频 | 中文字幕精品av一区二区五区 | 日韩人妻无码一区二区三区久久99 | 丰满少妇弄高潮了www | 成人av无码一区二区三区 | 国产精品久久久一区二区三区 | 国内老熟妇对白xxxxhd | 无码人妻久久一区二区三区不卡 | 秋霞特色aa大片 | 亚洲色欲色欲天天天www | 国产无遮挡吃胸膜奶免费看 | 国产精品久久久久7777 | 99久久精品国产一区二区蜜芽 | 精品久久8x国产免费观看 | 欧美丰满少妇xxxx性 | 狠狠cao日日穞夜夜穞av | 久激情内射婷内射蜜桃人妖 | 国产成人无码午夜视频在线观看 | av无码电影一区二区三区 | 青春草在线视频免费观看 | 99久久精品无码一区二区毛片 | 国产成人av免费观看 | 国产激情无码一区二区 | 国产成人一区二区三区在线观看 | 亚洲 欧美 激情 小说 另类 | 免费观看的无遮挡av | 国产欧美熟妇另类久久久 | 欧美丰满熟妇xxxx性ppx人交 | 日韩av无码一区二区三区不卡 | 一区二区三区高清视频一 | 少女韩国电视剧在线观看完整 | 欧美zoozzooz性欧美 | 国产艳妇av在线观看果冻传媒 | 国产精品久久久久久久影院 | 免费看男女做好爽好硬视频 | 午夜时刻免费入口 | 18精品久久久无码午夜福利 | 骚片av蜜桃精品一区 | 国内精品九九久久久精品 | 国产口爆吞精在线视频 | 国产三级久久久精品麻豆三级 | 99精品国产综合久久久久五月天 | 在线天堂新版最新版在线8 | 亚洲毛片av日韩av无码 | 日韩av激情在线观看 | 国产精品久久久久久亚洲毛片 | 亚洲欧美精品aaaaaa片 | 亚洲 另类 在线 欧美 制服 | 国产亚洲精品精品国产亚洲综合 | 久久久久久亚洲精品a片成人 | 男女猛烈xx00免费视频试看 | 国内精品久久久久久中文字幕 | 亚洲成av人综合在线观看 | 色婷婷香蕉在线一区二区 | 99国产精品白浆在线观看免费 | 东京一本一道一二三区 | 国产精品毛片一区二区 | 国产欧美熟妇另类久久久 | 亚洲日本一区二区三区在线 | 欧美老妇与禽交 | 蜜桃视频插满18在线观看 | 国产精华av午夜在线观看 | 亚洲熟妇自偷自拍另类 | 国产在线aaa片一区二区99 | 亚洲 a v无 码免 费 成 人 a v | 色婷婷综合中文久久一本 | 妺妺窝人体色www在线小说 | 女人被男人爽到呻吟的视频 | 中文字幕无码免费久久9一区9 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲精品国产精品乱码不卡 | 亚洲一区二区三区香蕉 | 国产人妻人伦精品1国产丝袜 | 亚洲欧美精品aaaaaa片 | 日本成熟视频免费视频 | 九九在线中文字幕无码 | 亚洲综合伊人久久大杳蕉 | 午夜福利试看120秒体验区 | 精品一二三区久久aaa片 | 自拍偷自拍亚洲精品10p | 国产午夜无码精品免费看 | 亚洲精品一区三区三区在线观看 | 成人欧美一区二区三区黑人免费 | 久久视频在线观看精品 | 欧美刺激性大交 | 强伦人妻一区二区三区视频18 | 日韩无码专区 | 亚洲国精产品一二二线 | 日韩av激情在线观看 | 无码一区二区三区在线 | 亚洲综合无码久久精品综合 | аⅴ资源天堂资源库在线 | 在线播放免费人成毛片乱码 | 中文字幕无线码免费人妻 | 高潮喷水的毛片 | 久久99精品国产.久久久久 | 麻豆成人精品国产免费 | 又紧又大又爽精品一区二区 | 成在人线av无码免观看麻豆 | 久久久精品欧美一区二区免费 | 亚洲小说春色综合另类 | 亚洲日本在线电影 | 国产激情无码一区二区app | 免费无码午夜福利片69 | 纯爱无遮挡h肉动漫在线播放 | 欧美真人作爱免费视频 | 99riav国产精品视频 | 少妇高潮喷潮久久久影院 | 国产内射老熟女aaaa | 熟妇人妻无码xxx视频 | 99精品视频在线观看免费 | 欧美精品免费观看二区 | 久久精品人妻少妇一区二区三区 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 色情久久久av熟女人妻网站 | 国产乱人伦av在线无码 | 无遮挡国产高潮视频免费观看 | 日韩 欧美 动漫 国产 制服 | 四虎永久在线精品免费网址 | 久久久久国色av免费观看性色 | 日韩精品无码一本二本三本色 | 久久精品99久久香蕉国产色戒 | 一本久道高清无码视频 | 精品久久久无码人妻字幂 | 永久免费观看美女裸体的网站 | 在线观看免费人成视频 | 一区二区传媒有限公司 | 少妇无码一区二区二三区 | 1000部啪啪未满十八勿入下载 | 午夜精品久久久内射近拍高清 | 强奷人妻日本中文字幕 | 亚洲精品成人av在线 | 岛国片人妻三上悠亚 | 久在线观看福利视频 | 88国产精品欧美一区二区三区 | 在线天堂新版最新版在线8 | 久久久久免费看成人影片 | 中文字幕无线码免费人妻 | 青青青爽视频在线观看 | 少妇被粗大的猛进出69影院 | 人人妻人人澡人人爽欧美一区 | 99久久亚洲精品无码毛片 | 黑人巨大精品欧美一区二区 | 国产真实乱对白精彩久久 | 日本va欧美va欧美va精品 | аⅴ资源天堂资源库在线 | 爱做久久久久久 | 18无码粉嫩小泬无套在线观看 | 国产免费久久久久久无码 | 欧美日韩一区二区免费视频 | 无码人妻丰满熟妇区五十路百度 | 特大黑人娇小亚洲女 | 妺妺窝人体色www在线小说 | 丝袜人妻一区二区三区 | 久久国产精品萌白酱免费 | 久久午夜无码鲁丝片午夜精品 | 在线观看免费人成视频 | 亚洲国产精华液网站w | 久久综合色之久久综合 | 中文字幕无码人妻少妇免费 | 97精品国产97久久久久久免费 | 两性色午夜免费视频 | 精品人妻人人做人人爽夜夜爽 | 久久国内精品自在自线 | 国产在热线精品视频 | 水蜜桃av无码 | 未满小14洗澡无码视频网站 | 性做久久久久久久久 | 欧美日韩久久久精品a片 | 俄罗斯老熟妇色xxxx | 久久精品视频在线看15 | 波多野42部无码喷潮在线 | 国产区女主播在线观看 | 久久久精品国产sm最大网站 | 野狼第一精品社区 | 亚洲爆乳精品无码一区二区三区 | 性色欲网站人妻丰满中文久久不卡 | 国精产品一品二品国精品69xx | 大肉大捧一进一出视频出来呀 | 亚洲国产精品久久久天堂 | 思思久久99热只有频精品66 | 午夜精品久久久久久久久 | 国产又爽又猛又粗的视频a片 | 天天摸天天透天天添 | 国产欧美精品一区二区三区 | 兔费看少妇性l交大片免费 | 内射老妇bbwx0c0ck | 最新国产乱人伦偷精品免费网站 | 夜夜影院未满十八勿进 | 成人亚洲精品久久久久 | 性欧美videos高清精品 | 亚洲 另类 在线 欧美 制服 | 成年女人永久免费看片 | 领导边摸边吃奶边做爽在线观看 | 日本大乳高潮视频在线观看 | 3d动漫精品啪啪一区二区中 | 久久99精品久久久久久 | 久久精品成人欧美大片 | 午夜精品一区二区三区的区别 | 波多野结衣av一区二区全免费观看 | 少妇愉情理伦片bd | 午夜精品久久久久久久 | 日韩精品一区二区av在线 | 久久天天躁夜夜躁狠狠 | 一个人看的www免费视频在线观看 | 中国女人内谢69xxxx | 国产麻豆精品精东影业av网站 | 亚洲国产精品久久人人爱 | 老熟女乱子伦 | 亚洲成a人片在线观看日本 | 水蜜桃亚洲一二三四在线 | 成在人线av无码免费 | 夜精品a片一区二区三区无码白浆 | 欧美国产日韩亚洲中文 | 久久久婷婷五月亚洲97号色 | 人妻天天爽夜夜爽一区二区 | 老司机亚洲精品影院 | 精品aⅴ一区二区三区 | 亚洲精品国产品国语在线观看 | 成熟女人特级毛片www免费 | 午夜无码人妻av大片色欲 | 欧美猛少妇色xxxxx | 久久精品成人欧美大片 | 国产成人无码区免费内射一片色欲 | 亚洲aⅴ无码成人网站国产app | 呦交小u女精品视频 | 捆绑白丝粉色jk震动捧喷白浆 | 亚欧洲精品在线视频免费观看 | 国产9 9在线 | 中文 | 国产9 9在线 | 中文 | 欧美一区二区三区视频在线观看 | 蜜桃臀无码内射一区二区三区 | 亚洲精品中文字幕 | 疯狂三人交性欧美 | 精品亚洲成av人在线观看 | 97久久国产亚洲精品超碰热 | 香港三级日本三级妇三级 | 99久久精品日本一区二区免费 | 伊在人天堂亚洲香蕉精品区 | 夜夜高潮次次欢爽av女 | 国产无av码在线观看 | 亚洲va中文字幕无码久久不卡 | 婷婷五月综合缴情在线视频 | 5858s亚洲色大成网站www | 伊在人天堂亚洲香蕉精品区 | 给我免费的视频在线观看 | 亚洲无人区一区二区三区 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 无码纯肉视频在线观看 | 少妇久久久久久人妻无码 | 大地资源网第二页免费观看 | 少妇一晚三次一区二区三区 | 麻花豆传媒剧国产免费mv在线 | 国产精品高潮呻吟av久久4虎 | 国产精品国产三级国产专播 | 图片区 小说区 区 亚洲五月 | 成人性做爰aaa片免费看不忠 | 伊人久久大香线焦av综合影院 | 乱中年女人伦av三区 | 精品欧洲av无码一区二区三区 | 亚洲精品www久久久 | 国产色xx群视频射精 | 国产成人av免费观看 | 国产精品自产拍在线观看 | 国产另类ts人妖一区二区 | 少妇无套内谢久久久久 | 亚洲色大成网站www | 2019nv天堂香蕉在线观看 | 成年美女黄网站色大免费全看 | 欧美日韩视频无码一区二区三 | 少妇无套内谢久久久久 | 国产av剧情md精品麻豆 | 狂野欧美性猛交免费视频 | 狂野欧美激情性xxxx | 午夜精品久久久久久久 | 男女爱爱好爽视频免费看 | 无套内射视频囯产 | 亚洲一区二区三区播放 | 蜜桃无码一区二区三区 | 一本加勒比波多野结衣 | 国产熟女一区二区三区四区五区 | 久久精品国产一区二区三区肥胖 | 国产精品无码mv在线观看 | 人妻天天爽夜夜爽一区二区 | 国产一区二区不卡老阿姨 | 天下第一社区视频www日本 | 国产人妻人伦精品 | 又湿又紧又大又爽a视频国产 | 亚洲中文字幕久久无码 | 亚洲无人区一区二区三区 | 麻豆精产国品 | 人人爽人人澡人人人妻 | 久在线观看福利视频 | 成人无码视频免费播放 | 精品午夜福利在线观看 | 国内揄拍国内精品人妻 | www国产亚洲精品久久久日本 | 久久婷婷五月综合色国产香蕉 | 久久亚洲日韩精品一区二区三区 | 国产精品-区区久久久狼 | 中文字幕人妻无码一夲道 | 日日天日日夜日日摸 | 久久伊人色av天堂九九小黄鸭 | 成人免费视频视频在线观看 免费 | 最近免费中文字幕中文高清百度 | 全球成人中文在线 | 亚洲欧洲中文日韩av乱码 | 欧美国产日产一区二区 | 一本久道高清无码视频 | www国产亚洲精品久久网站 | 国产成人午夜福利在线播放 | 精品国偷自产在线 | 免费观看激色视频网站 | 捆绑白丝粉色jk震动捧喷白浆 | 久久精品中文闷骚内射 | 亚无码乱人伦一区二区 | 波多野结衣乳巨码无在线观看 | 国产精品久久久久影院嫩草 | 影音先锋中文字幕无码 | 精品国产一区二区三区四区在线看 | 国产精品亚洲综合色区韩国 | 午夜福利电影 | 纯爱无遮挡h肉动漫在线播放 | 老熟女乱子伦 | 亚洲乱码日产精品bd | 大肉大捧一进一出好爽视频 | 国产精品久免费的黄网站 | 97久久超碰中文字幕 | 久久精品国产一区二区三区 | 大地资源网第二页免费观看 | yw尤物av无码国产在线观看 | 国产亚洲日韩欧美另类第八页 | 国产精品久久福利网站 | 18禁黄网站男男禁片免费观看 | 日本va欧美va欧美va精品 | 亚洲毛片av日韩av无码 | 成人无码视频在线观看网站 | 好男人www社区 | 中文字幕 人妻熟女 | 强伦人妻一区二区三区视频18 | 日本丰满护士爆乳xxxx | 夜先锋av资源网站 | v一区无码内射国产 | 四虎永久在线精品免费网址 | 亚洲精品久久久久久一区二区 | 麻豆av传媒蜜桃天美传媒 | 国产美女精品一区二区三区 | 欧美人妻一区二区三区 | 青青草原综合久久大伊人精品 | 人人妻人人澡人人爽欧美一区九九 | 99麻豆久久久国产精品免费 | 狠狠亚洲超碰狼人久久 | 无码国内精品人妻少妇 | 国产亚洲精品久久久ai换 | 国产办公室秘书无码精品99 | www成人国产高清内射 | 一本久久a久久精品vr综合 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲色大成网站www | 色一情一乱一伦 | 国产激情精品一区二区三区 | 亚洲色偷偷偷综合网 | 国产成人一区二区三区别 | 亚洲综合久久一区二区 | 国产亚洲tv在线观看 | 色一情一乱一伦一区二区三欧美 | 久久精品成人欧美大片 | 中文字幕无码热在线视频 | 日本丰满护士爆乳xxxx | 日韩欧美中文字幕在线三区 | 国产猛烈高潮尖叫视频免费 | 国产午夜福利亚洲第一 | 国产人妻人伦精品1国产丝袜 | 日本大乳高潮视频在线观看 | 亚洲日韩av一区二区三区中文 | 欧美亚洲国产一区二区三区 | 国产激情艳情在线看视频 | 无码国产激情在线观看 | 亚洲成av人片在线观看无码不卡 | 国产精品自产拍在线观看 | 中文字幕乱妇无码av在线 | 国产成人无码一二三区视频 | 三上悠亚人妻中文字幕在线 | 国产精品毛多多水多 | 男女猛烈xx00免费视频试看 | 久久久中文字幕日本无吗 | 在线观看国产一区二区三区 | 人人妻人人澡人人爽欧美一区 | 亚洲成av人片在线观看无码不卡 | 中文字幕人妻无码一夲道 | 免费无码av一区二区 | 狂野欧美激情性xxxx | 麻豆国产人妻欲求不满谁演的 | 大胆欧美熟妇xx | 精品国产一区二区三区四区 | 亚洲国产精品成人久久蜜臀 | 亚洲精品成a人在线观看 | 日本精品人妻无码免费大全 | 亚洲熟悉妇女xxx妇女av | 国产成人人人97超碰超爽8 | 中文字幕乱码人妻二区三区 | 精品国产一区二区三区四区在线看 | 国产综合色产在线精品 | 永久免费精品精品永久-夜色 | 黑人巨大精品欧美黑寡妇 | 老熟妇乱子伦牲交视频 | 亚洲a无码综合a国产av中文 | 亚洲色www成人永久网址 | 一本色道久久综合狠狠躁 | 国产无av码在线观看 | 无码吃奶揉捏奶头高潮视频 | 国产成人av免费观看 | 午夜成人1000部免费视频 | 成人精品一区二区三区中文字幕 | 国产精品久久久久久亚洲影视内衣 | √8天堂资源地址中文在线 | 亚洲色大成网站www国产 | 国产精品无码一区二区桃花视频 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产午夜无码精品免费看 | 亚洲国产欧美在线成人 | 国产真人无遮挡作爱免费视频 | 久热国产vs视频在线观看 | 国产欧美亚洲精品a | 亚洲国产精品一区二区第一页 | 狠狠色欧美亚洲狠狠色www | 乱人伦中文视频在线观看 | 老熟女乱子伦 | 国产成人av免费观看 | 久久久久人妻一区精品色欧美 | 永久免费观看国产裸体美女 | 亚洲国产精华液网站w | 色欲综合久久中文字幕网 | 国产精品无码久久av | 中文字幕无线码 | 国产精品亚洲专区无码不卡 | 午夜丰满少妇性开放视频 | 欧美国产亚洲日韩在线二区 | 欧美成人家庭影院 | 一本色道婷婷久久欧美 | 国产真实夫妇视频 | 小sao货水好多真紧h无码视频 | 7777奇米四色成人眼影 | 夜夜躁日日躁狠狠久久av | 久久国产36精品色熟妇 | 午夜性刺激在线视频免费 | 久久99精品国产麻豆 | 日日碰狠狠躁久久躁蜜桃 | 久久99精品国产.久久久久 | 岛国片人妻三上悠亚 | 西西人体www44rt大胆高清 | 人妻尝试又大又粗久久 | 国产精品美女久久久 | 国产农村妇女高潮大叫 | 国产精品久久久久久久影院 | 中国大陆精品视频xxxx | 亚洲伊人久久精品影院 | 少妇性荡欲午夜性开放视频剧场 | 亚洲成色在线综合网站 | 亚洲人成影院在线无码按摩店 | 久久亚洲精品中文字幕无男同 | 久久午夜无码鲁丝片午夜精品 | 亚洲中文字幕久久无码 | 四虎永久在线精品免费网址 | 亚洲 a v无 码免 费 成 人 a v | 少妇无套内谢久久久久 | 国产特级毛片aaaaaa高潮流水 | 亚洲の无码国产の无码步美 | 国产成人精品优优av | 成在人线av无码免费 | 小泽玛莉亚一区二区视频在线 | 久青草影院在线观看国产 | 奇米影视7777久久精品 | 日本在线高清不卡免费播放 | 综合人妻久久一区二区精品 | 少妇被黑人到高潮喷出白浆 | 久久国产精品偷任你爽任你 | 性生交大片免费看女人按摩摩 | 国产午夜福利亚洲第一 | 国产人妖乱国产精品人妖 | 4hu四虎永久在线观看 | 成人无码精品1区2区3区免费看 | 沈阳熟女露脸对白视频 | 亚洲 a v无 码免 费 成 人 a v | 成 人 免费观看网站 | 亚洲成av人在线观看网址 | 永久黄网站色视频免费直播 | 久久精品丝袜高跟鞋 | 日本在线高清不卡免费播放 | 亚洲自偷自拍另类第1页 | 夜夜躁日日躁狠狠久久av | 久久综合久久自在自线精品自 | 亚洲人交乣女bbw | 免费人成网站视频在线观看 | 国产亚洲人成a在线v网站 | 婷婷综合久久中文字幕蜜桃三电影 | 青青草原综合久久大伊人精品 | 日韩av激情在线观看 | 亚洲无人区午夜福利码高清完整版 | 欧美日本免费一区二区三区 | 18无码粉嫩小泬无套在线观看 | 精品欧美一区二区三区久久久 | 色欲久久久天天天综合网精品 | 又粗又大又硬又长又爽 | 国产高清不卡无码视频 | 亚洲一区二区三区无码久久 | 小sao货水好多真紧h无码视频 | 日产精品高潮呻吟av久久 | 午夜精品久久久久久久久 | 国内丰满熟女出轨videos | 久久精品人妻少妇一区二区三区 | 日日碰狠狠丁香久燥 | 在线观看欧美一区二区三区 | 国产猛烈高潮尖叫视频免费 | 露脸叫床粗话东北少妇 | 动漫av一区二区在线观看 | 欧美黑人乱大交 | 亚洲精品久久久久久一区二区 | 300部国产真实乱 | 欧美刺激性大交 | 成熟人妻av无码专区 | 色欲久久久天天天综合网精品 | 色欲人妻aaaaaaa无码 | 夜夜影院未满十八勿进 | 国语自产偷拍精品视频偷 | 欧美刺激性大交 | 红桃av一区二区三区在线无码av | 真人与拘做受免费视频一 | 亚洲乱码中文字幕在线 | 爽爽影院免费观看 | 国产精品无码一区二区三区不卡 | 在线精品国产一区二区三区 | 少妇愉情理伦片bd | 中文亚洲成a人片在线观看 | 无套内射视频囯产 | 国产精品久久久久无码av色戒 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 乌克兰少妇xxxx做受 | 色欲人妻aaaaaaa无码 | 国产又爽又黄又刺激的视频 | 九月婷婷人人澡人人添人人爽 | 性生交大片免费看l | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 国产亚洲日韩欧美另类第八页 | 国产精品怡红院永久免费 | 大地资源网第二页免费观看 | 久久久无码中文字幕久... | 婷婷五月综合激情中文字幕 | 国产精品va在线播放 | 久久综合给久久狠狠97色 | 久久久中文久久久无码 | 日本精品少妇一区二区三区 | 国产亚洲精品久久久久久久 | 久久亚洲精品成人无码 | 色综合天天综合狠狠爱 | 黑人巨大精品欧美一区二区 | 国产成人无码一二三区视频 | 无码人妻丰满熟妇区五十路百度 | 国产特级毛片aaaaaa高潮流水 | 帮老师解开蕾丝奶罩吸乳网站 | 欧美国产日产一区二区 | 97无码免费人妻超级碰碰夜夜 | 又黄又爽又色的视频 | 亚洲中文字幕av在天堂 | 亚洲人成无码网www | 久久综合香蕉国产蜜臀av | 台湾无码一区二区 | 自拍偷自拍亚洲精品被多人伦好爽 | 夜夜影院未满十八勿进 | 国产人妻人伦精品1国产丝袜 | 国产成人无码av在线影院 | 超碰97人人射妻 | 国产深夜福利视频在线 | 中文无码成人免费视频在线观看 | 一区二区传媒有限公司 | 久久亚洲国产成人精品性色 | 无码福利日韩神码福利片 | 国内精品久久久久久中文字幕 | 中文字幕乱码中文乱码51精品 | 国内精品人妻无码久久久影院 | 国产熟女一区二区三区四区五区 | 亚洲乱码日产精品bd | 亚洲国产精品毛片av不卡在线 | 人人爽人人澡人人高潮 | 乱人伦人妻中文字幕无码 | 亚洲自偷自拍另类第1页 | 国产va免费精品观看 | 国产精品久久久久影院嫩草 | 亚洲欧美精品aaaaaa片 | 亚洲人成网站色7799 | 亚洲国产精品久久人人爱 | 久久国内精品自在自线 | 国产无av码在线观看 | 女人高潮内射99精品 | 日本成熟视频免费视频 | 波多野结衣aⅴ在线 | 久久婷婷五月综合色国产香蕉 | 一个人看的视频www在线 | 夫妻免费无码v看片 | 欧美日韩视频无码一区二区三 | 日韩人妻系列无码专区 | 夜夜高潮次次欢爽av女 | 无码人中文字幕 | 欧美一区二区三区 | 中文字幕无码av波多野吉衣 | 国产成人无码av片在线观看不卡 | 伊在人天堂亚洲香蕉精品区 | 国内精品一区二区三区不卡 | 在线观看国产午夜福利片 | 亚洲精品一区二区三区在线 | 亚洲伊人久久精品影院 | 沈阳熟女露脸对白视频 | 亚洲中文字幕在线无码一区二区 | 女人高潮内射99精品 | 国产亚洲视频中文字幕97精品 | 欧美熟妇另类久久久久久不卡 |