青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

xiaoguozi's Blog
Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習(xí)慣原本生活的人不容易改變,就算現(xiàn)狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預(yù)料,人們需要更細(xì)心的觀察別人,要隨時(shí)注意才能保護(hù)別人,因?yàn)樗麄兾幢刂雷约阂裁础ぁぁぁぁ?/span>
#include "windows.h"
#include 
<iostream>

using namespace std;

#define NTSIGNATURE(a) ((LPVOID)((BYTE *)a + \
                       ((PIMAGE_DOS_HEADER)a)
->e_lfanew))
/*
const int SIZE_OF_NT_SIGNATURE = 4;
#define PEHEADOFFSET(a) ((LPVOID)((BYTE *)a + \
                       ((PIMAGE_DOS_HEADER)a)->e_lfanew)+SIZE_OF_NT_SIGNATURE)
*/
class PEUtil{
public:
    
static bool IsPeFile(LPVOID lp){
        
//DWORD ImageType=ImageFileType(lp);
        
//if(ImageType!=
        /*if(lp==NULL)return false;
        PIMAGE_DOS_HEADER pImage_Dos_Header=(PIMAGE_DOS_HEADER)lp;
        if(pImage_Dos_Header->e_magic!=IMAGE_DOS_SIGNATURE)return false;

        PIMAGE_NT_HEADERS32 pImage_Nt_Header=GetNtHeader(lp);
        if(pImage_Nt_Header->Signature!=IMAGE_NT_SIGNATURE)return false;

        return true;
*/

        
return ImageFileType(lp)==IMAGE_NT_SIGNATURE;
    }

    
static PIMAGE_NT_HEADERS GetNtHeader(PBYTE lp){
        
if(IsPeFile(lp)==false)return NULL;

        
return (PIMAGE_NT_HEADERS32)NTSIGNATURE(lp);
    }
    
static PIMAGE_FILE_HEADER GetFileHeader(PBYTE lp){
        PIMAGE_NT_HEADERS pNtHeader
=GetNtHeader(lp);
        
if(pNtHeader==NULL)return NULL;

        
return PIMAGE_FILE_HEADER(&pNtHeader->FileHeader);
    }
    
static PIMAGE_OPTIONAL_HEADER GetOptionalHeader(PBYTE lp){
        PIMAGE_NT_HEADERS pNtHeader
=GetNtHeader(lp);
        
if(pNtHeader==NULL)return NULL;

        
return PIMAGE_OPTIONAL_HEADER(&pNtHeader->OptionalHeader);
    }
    
static PIMAGE_SECTION_HEADER GetSectionHeader(PBYTE lp){
        PIMAGE_NT_HEADERS pnh
=GetNtHeader(lp);
        PIMAGE_SECTION_HEADER pch
=(PIMAGE_SECTION_HEADER)((PBYTE)pnh+sizeof(IMAGE_NT_HEADERS));
        
return pch;
    }
    
static LPVOID IMAGE_DIRECTORY_OFFSET(PBYTE lp,DWORD index){
        PIMAGE_FILE_HEADER pfh
=GetFileHeader(lp);
        PIMAGE_OPTIONAL_HEADER poh
=GetOptionalHeader(lp);
        PIMAGE_SECTION_HEADER psh
=GetSectionHeader(lp);

        
int nSections=pfh->NumberOfSections;
        
if(index>=poh->NumberOfRvaAndSizes){
            
return NULL;
        }

        LPVOID virtualDirAddr
=(LPVOID)poh->DataDirectory[index].VirtualAddress;

        
int i=0;
        
while(i<nSections){
            
if(psh->VirtualAddress<=DWORD(virtualDirAddr)&&
                psh
->VirtualAddress+psh->SizeOfRawData>DWORD(virtualDirAddr)){
                    
break;
            }
            
++psh;
            
++i;
        }
        
if(i>=nSections)return NULL;

        
return (LPVOID)(((int)lp+(int)virtualDirAddr-psh->VirtualAddress) +
    (
int)psh->PointerToRawData);
        
//return NULL;
    }
private:
    
static DWORD WINAPI ImageFileType (LPVOID lpFile)
    {
      
/* 首先出現(xiàn)的是DOS文件標(biāo)志 */
      
if (*(USHORT *)lpFile == IMAGE_DOS_SIGNATURE)
      {
        
/* 由DOS頭部決定PE文件頭部的位置 */
        
if (LOWORD (*(DWORD *)NTSIGNATURE (lpFile)) ==
            IMAGE_OS2_SIGNATURE 
||
            LOWORD (
*(DWORD *)NTSIGNATURE (lpFile)) ==
            IMAGE_OS2_SIGNATURE_LE)
          
return (DWORD)LOWORD(*(DWORD *)NTSIGNATURE (lpFile));
        
else if (*(DWORD *)NTSIGNATURE (lpFile) ==
          IMAGE_NT_SIGNATURE)
        
return IMAGE_NT_SIGNATURE;
        
else
          
return IMAGE_DOS_SIGNATURE;
      }
      
else
        
/* 不明文件種類 */
        
return 0;
    }
};
int _tmain(int argc, _TCHAR* argv[])
{
    LPCWSTR filepath
=TEXT("D://STLPort/MemoryMap.exe");
    HANDLE hFile 
= CreateFile(filepath,GENERIC_READ|GENERIC_WRITE,
        FILE_SHARE_READ,NULL,OPEN_ALWAYS,FILE_ATTRIBUTE_NORMAL,NULL);

    
    
if(hFile==INVALID_HANDLE_VALUE){
        cout
<<"CreateFile Error"<<endl;
        
return -1;
    }

    
//IMAGE_NT_HEADERS32
    HANDLE hFileMapping = CreateFileMapping(hFile,NULL,PAGE_READWRITE,0,0,L"testFileMapping");
    PBYTE pByte
=(PBYTE)MapViewOfFile(hFileMapping,FILE_MAP_ALL_ACCESS,0,0,0);

    
//cout<<hex<<PEUtil::GetOptionalHeader(pByte)->ImageBase<<endl;
    int nSections=PEUtil::GetFileHeader(pByte)->NumberOfSections;
    cout
<<nSections<<endl;
    PIMAGE_SECTION_HEADER psh
=PEUtil::GetSectionHeader(pByte);

    
for(int i=0;i<nSections;i++){
        cout
<<psh->Name<<" "<<psh->VirtualAddress<<" "<<psh->PointerToRawData<<endl;
        psh
++;
    }
    
/*cout<<IsPeFile(pByte);
    PIMAGE_NT_HEADERS32 pImage=GetNtHeader(pByte);
    cout<<hex<<pImage->Signature<<endl;
    cout<<pImage->FileHeader.Machine<<endl;
    //cout<<hex<<ImageFileType(pByte)<<endl;
    //cout<<PEHEADOFFSET(pByte)
    //cout<<pByte<<endl;
*/
    
return 0;
}
有時(shí)間總結(jié),待續(xù)...

#include "windows.h"
#include 
<iostream>
//#include "dlltest.h"
#include <vector>
#include 
<string>

using namespace std;
//#pragma comment(lib,"dlltest.lib")
typedef int (*pf)(void);
#define NTSIGNATURE(a) ((LPVOID)((BYTE *)a + \
                       ((PIMAGE_DOS_HEADER)a)
->e_lfanew))
/*
const int SIZE_OF_NT_SIGNATURE = 4;
#define PEHEADOFFSET(a) ((LPVOID)((BYTE *)a + \
                       ((PIMAGE_DOS_HEADER)a)->e_lfanew)+SIZE_OF_NT_SIGNATURE)
*/

typedef 
struct tagImportDirectory
{
  DWORD dwRVAFunctionNameList;
  DWORD dwUseless1;
  DWORD dwUseless2;
  DWORD dwRVAModuleName;
  DWORD dwRVAFunctionAddressList;
} IMAGE_IMPORT_MODULE_DIRECTORY, 
*PIMAGE_IMPORT_MODULE_DIRECTORY;


class PEUtil{
public:
    
static bool IsPeFile(LPVOID lp){
        
//DWORD ImageType=ImageFileType(lp);
        
//if(ImageType!=
        /*if(lp==NULL)return false;
        PIMAGE_DOS_HEADER pImage_Dos_Header=(PIMAGE_DOS_HEADER)lp;
        if(pImage_Dos_Header->e_magic!=IMAGE_DOS_SIGNATURE)return false;

        PIMAGE_NT_HEADERS32 pImage_Nt_Header=GetNtHeader(lp);
        if(pImage_Nt_Header->Signature!=IMAGE_NT_SIGNATURE)return false;

        return true;
*/

        
return ImageFileType(lp)==IMAGE_NT_SIGNATURE;
    }

    
static PIMAGE_NT_HEADERS GetNtHeader(PBYTE lp){
        
if(IsPeFile(lp)==false)return NULL;

        
return (PIMAGE_NT_HEADERS32)NTSIGNATURE(lp);
    }
    
static PIMAGE_FILE_HEADER GetFileHeader(PBYTE lp){
        PIMAGE_NT_HEADERS pNtHeader
=GetNtHeader(lp);
        
if(pNtHeader==NULL)return NULL;

        
return PIMAGE_FILE_HEADER(&pNtHeader->FileHeader);
    }
    
static PIMAGE_OPTIONAL_HEADER GetOptionalHeader(PBYTE lp){
        PIMAGE_NT_HEADERS pNtHeader
=GetNtHeader(lp);
        
if(pNtHeader==NULL)return NULL;

        
return PIMAGE_OPTIONAL_HEADER(&pNtHeader->OptionalHeader);
    }
    
static PIMAGE_SECTION_HEADER GetSectionHeader(PBYTE lp){
        PIMAGE_NT_HEADERS pnh
=GetNtHeader(lp);
        PIMAGE_SECTION_HEADER pch
=(PIMAGE_SECTION_HEADER)((PBYTE)pnh+sizeof(IMAGE_NT_HEADERS));
        
return pch;
    }
    
static PIMAGE_SECTION_HEADER GetSectionHeaderByName(PBYTE lp,LPCSTR name){
        
int nSections=GetFileHeader(lp)->NumberOfSections;
        PIMAGE_SECTION_HEADER psh
=GetSectionHeader(lp);

        
for(int i=0;i<nSections;i++){
            
//cout<<psh->Name<<" "<<psh->VirtualAddress<<" "<<psh->PointerToRawData<<endl;
            if(strcmp((char*)psh->Name,name)==0)
                
return psh;
            psh
++;
        }
        
return NULL;
    }
    
static LPVOID IMAGE_DIRECTORY_OFFSET(PBYTE lp,DWORD index){
        PIMAGE_FILE_HEADER pfh
=GetFileHeader(lp);
        PIMAGE_OPTIONAL_HEADER poh
=GetOptionalHeader(lp);
        PIMAGE_SECTION_HEADER psh
=GetSectionHeader(lp);

        
int nSections=pfh->NumberOfSections;
        
if(index>=poh->NumberOfRvaAndSizes){
            
return NULL;
        }

        LPVOID virtualDirAddr
=(LPVOID)poh->DataDirectory[index].VirtualAddress;

        
int i=0;
        
while(i<nSections){
            
if(psh->VirtualAddress<=DWORD(virtualDirAddr)&&
                psh
->VirtualAddress+psh->SizeOfRawData>DWORD(virtualDirAddr)){
                    
break;
            }
            
++psh;
            
++i;
        }
        
if(i>=nSections)return NULL;

        
return (LPVOID)(((int)lp+(int)psh->PointerToRawData
            
+(int)virtualDirAddr-psh->VirtualAddress));
        
//return NULL;
    }
    
static LPVOID IAT_OFFSET(PBYTE lp){
        
/*PIMAGE_OPTIONAL_HEADER poh=GetOptionalHeader(lp);
        DWORD virtualDirAddr=poh->DataDirectory[12].VirtualAddress;
        PIMAGE_IMPORT_MODULE_DIRECTORY pimd;

        pimd=(PIMAGE_IMPORT_MODULE_DIRECTORY)IMAGE_DIRECTORY_OFFSET(lp,IMAGE_DIRECTORY_ENTRY_IMPORT);

        PIMAGE_SECTION_HEADER idsh;
        idsh=GetSectionHeaderByName(lp,".idata");
        return (LPVOID)((PBYTE)pimd+(virtualDirAddr-idsh->VirtualAddress));
*/
        
return (LPVOID)((PBYTE)IMAGE_DIRECTORY_OFFSET(lp,12)/*-lp*/);
    }
    
static void GetImportModuleNames(PBYTE lp,vector<PBYTE>& vec){
        PIMAGE_IMPORT_MODULE_DIRECTORY pimd;
        PIMAGE_SECTION_HEADER idsh;

        
//pimd 物理地址
        pimd=(PIMAGE_IMPORT_MODULE_DIRECTORY)IMAGE_DIRECTORY_OFFSET(lp,IMAGE_DIRECTORY_ENTRY_IMPORT);
        idsh
=GetSectionHeaderByName(lp,".idata");
        
//cout<<idsh->Name<<endl;
        PBYTE pData=(PBYTE)pimd;

        
//pid->
        
//pid->Name
        
//ImageRvaToVa(

        
while(pimd->dwRVAModuleName){
            
//vec.push_back((PBYTE)(pimd+(pimd->dwRVAModuleName-idsh->VirtualAddress)));
            vec.push_back((pData+(pimd->dwRVAModuleName-idsh->VirtualAddress)));
            
++pimd;
        }
    }
    
static PIMAGE_IMPORT_MODULE_DIRECTORY GetImportModuleByName(PBYTE lp,LPCSTR name){
        PIMAGE_IMPORT_MODULE_DIRECTORY pimd;
        PIMAGE_SECTION_HEADER idsh;
        pimd
=(PIMAGE_IMPORT_MODULE_DIRECTORY)IMAGE_DIRECTORY_OFFSET(lp,IMAGE_DIRECTORY_ENTRY_IMPORT);
        idsh
=GetSectionHeaderByName(lp,".idata");
        
//cout<<idsh->Name<<endl;

        
if(idsh==NULL)return NULL;

        PBYTE pData
=(PBYTE)pimd;
        
while(pimd->dwRVAModuleName){
            
//vec.push_back((PBYTE)(pimd+(pimd->dwRVAModuleName-idsh->VirtualAddress)));
            
//vec.push_back((pData+(pimd->dwRVAModuleName-idsh->VirtualAddress)));
            if(strcmp((char*)(pData+(pimd->dwRVAModuleName-idsh->VirtualAddress)),name)==0){
                
return pimd;
            }
            
++pimd;
        }

        
return NULL;
    }
    
static void GetImportFunctionNamesByModule(PBYTE lp,vector<PBYTE>& ret){
        PIMAGE_IMPORT_MODULE_DIRECTORY pimd;
        PIMAGE_SECTION_HEADER idsh;
        pimd
=(PIMAGE_IMPORT_MODULE_DIRECTORY)IMAGE_DIRECTORY_OFFSET(lp,IMAGE_DIRECTORY_ENTRY_IMPORT);
        idsh
=GetSectionHeaderByName(lp,".idata");

        DWORD dwBase
=(DWORD)((PBYTE)pimd - idsh->VirtualAddress);
    
//    DWORD dwBaseAddr=(DWORD)(lp - idsh->VirtualAddress);

        LPVOID iat
=IAT_OFFSET(lp);

        PIMAGE_IMPORT_DESCRIPTOR pid;
        pid
=(PIMAGE_IMPORT_DESCRIPTOR)IMAGE_DIRECTORY_OFFSET(lp,IMAGE_DIRECTORY_ENTRY_IMPORT);
        
        
while(pimd->dwRVAModuleName){

            cout
<<"------------"<<(char*)(dwBase+pimd->dwRVAModuleName)<<"-----------"<<endl;

            DWORD dwFunction
=pimd->dwRVAFunctionNameList;
            DWORD dwFunctionAddr
=pimd->dwRVAFunctionAddressList;

            
while(dwFunction && *(DWORD*)(dwFunction+dwBase) && *(char*)(*(DWORD*)(dwFunction+dwBase)+dwBase+2)){
                cout
<<(char*)(*(DWORD*)(dwFunction+dwBase)+dwBase+2)<<" ---rva:   ";
                cout
<<hex<<(dwFunctionAddr)<<endl;
                dwFunction
+=4;
                dwFunctionAddr
+=4;
            }

            
++pimd;
        }
        
//vector<PBYTE> moduleSet;
        
//GetImportModuleNames(lp,moduleSet);

    }
private:
    
static DWORD WINAPI ImageFileType (LPVOID lpFile)
    {
      
/* 首先出現(xiàn)的是DOS文件標(biāo)志 */
      
if (*(USHORT *)lpFile == IMAGE_DOS_SIGNATURE)
      {
        
/* 由DOS頭部決定PE文件頭部的位置 */
        
if (LOWORD (*(DWORD *)NTSIGNATURE (lpFile)) ==
            IMAGE_OS2_SIGNATURE 
||
            LOWORD (
*(DWORD *)NTSIGNATURE (lpFile)) ==
            IMAGE_OS2_SIGNATURE_LE)
          
return (DWORD)LOWORD(*(DWORD *)NTSIGNATURE (lpFile));
        
else if (*(DWORD *)NTSIGNATURE (lpFile) ==
          IMAGE_NT_SIGNATURE)
        
return IMAGE_NT_SIGNATURE;
        
else
          
return IMAGE_DOS_SIGNATURE;
      }
      
else
        
/* 不明文件種類 */
        
return 0;
    }
};
int _tmain(int argc, _TCHAR* argv[])
{
    LPCWSTR filepath
=TEXT("D://STLPort/MemoryMap.exe");
    HANDLE hFile 
= CreateFile(filepath,GENERIC_READ|GENERIC_WRITE,
        FILE_SHARE_READ,NULL,OPEN_ALWAYS,FILE_ATTRIBUTE_NORMAL,NULL);

    
if(hFile==INVALID_HANDLE_VALUE){
        cout
<<"CreateFile Error"<<endl;
        
return -1;
    }

    
//IMAGE_NT_HEADERS32
    HANDLE hFileMapping = CreateFileMapping(hFile,NULL,PAGE_READWRITE,0,0,L"testFileMapping");
    PBYTE pByte
=(PBYTE)MapViewOfFile(hFileMapping,FILE_MAP_ALL_ACCESS,0,0,0);


    cout
<<PEUtil::IsPeFile(pByte)<<endl;

    
//LPVOID p=PEUtil::IAT_OFFSET(pByte);
    
//cout<<fndlltest()<<endl;
    HINSTANCE hInst=LoadLibrary(L"dlltest.dll");
    pf lp;
    lp
=(pf)GetProcAddress(hInst,"fndlltest");
    cout
<<lp()<<endl;



    
//cout<<hex<<PEUtil::GetOptionalHeader(pByte)->ImageBase<<endl;
    /*int nSections=PEUtil::GetFileHeader(pByte)->NumberOfSections;
    cout<<nSections<<endl;
    PIMAGE_SECTION_HEADER psh=PEUtil::GetSectionHeader(pByte);

    for(int i=0;i<nSections;i++){
        cout<<psh->Name<<" "<<psh->VirtualAddress<<" "<<psh->PointerToRawData<<endl;
        psh++;
    }
*/
    PIMAGE_SECTION_HEADER psh
=PEUtil::GetSectionHeaderByName(pByte,".idata");
    cout
<<psh->Name<<" "<<psh->VirtualAddress<<" "<<psh->PointerToRawData<<endl;

    vector
<PBYTE> vec;
    
/*PEUtil::GetImportModuleNames(pByte,vec);
    for(int i=0;i<vec.size();i++){
        cout<<vec[i]<<endl;
    }
*/
    PEUtil::GetImportFunctionNamesByModule(pByte,vec);
    
/*cout<<IsPeFile(pByte);
    PIMAGE_NT_HEADERS32 pImage=GetNtHeader(pByte);
    cout<<hex<<pImage->Signature<<endl;
    cout<<pImage->FileHeader.Machine<<endl;
    //cout<<hex<<ImageFileType(pByte)<<endl;
    //cout<<PEHEADOFFSET(pByte)
    //cout<<pByte<<endl;
*/
    
return 0;
}

posted on 2010-10-12 17:22 小果子 閱讀(725) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Windows 、C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产一在线精品一区在线观看| 亚洲国产一区二区三区a毛片| 亚洲精品久久在线| 亚洲天堂成人| 亚洲乱码国产乱码精品精可以看| 一区视频在线播放| 国产日韩欧美综合在线| 国产女主播一区二区| 国产精品中文在线| 国产区二精品视| 亚洲电影免费观看高清完整版| 国产日本精品| 亚洲精品一级| 亚洲三级电影在线观看| 亚洲在线观看免费| 久久精品国产亚洲高清剧情介绍| 久久久xxx| 亚洲美女黄色片| 久久精品国产久精国产一老狼| 久久精品欧美日韩| 日韩天堂在线观看| 亚洲美女毛片| 国产精品99久久99久久久二8 | 亚洲美女黄网| 亚洲综合激情| 欧美日韩一区二区高清| 精品白丝av| 午夜伦欧美伦电影理论片| 久久久人人人| 欧美在线视频一区二区| 欧美日韩在线播放三区| 亚洲黄色在线观看| 欧美国产高清| 久久婷婷久久| 亚洲国产日韩一区| 欧美激情精品久久久六区热门| 欧美一级日韩一级| 国产日韩欧美综合在线| 久久成人免费电影| 亚洲免费在线视频一区 二区| 久久久噜噜噜久久久| 欧美精品xxxxbbbb| 久久夜色精品亚洲噜噜国产mv| 国产精品一区二区黑丝| 亚洲欧美国内爽妇网| 亚洲免费成人av电影| 国产精品高潮视频| 小黄鸭精品密入口导航| 久久综合九色综合网站| 一区二区三区av| 亚洲欧美亚洲| 狂野欧美一区| 一区二区三区黄色| 欧美日韩视频在线| 香蕉成人伊视频在线观看 | 欧美高清一区| 久久久亚洲精品一区二区三区 | 欧美自拍偷拍| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲日本在线观看| 久久国产精品久久w女人spa| 日韩视频一区二区三区在线播放免费观看 | 亚洲免费一级电影| 在线成人免费视频| 国产一区二区三区在线观看网站| 亚洲久久一区| 夜夜嗨av一区二区三区四季av| 久久精品欧洲| 亚洲国产精品成人| 国产精品久久久久久久久婷婷 | 欧美刺激午夜性久久久久久久| 欧美另类变人与禽xxxxx| 免费观看不卡av| 欧美日韩在线视频一区二区| 久久久美女艺术照精彩视频福利播放| 欧美日韩一区二区精品| 亚洲黄色天堂| 一区二区三区高清在线| 99riav1国产精品视频| 一区二区三区色| 欧美色图天堂网| 亚洲一区久久久| 欧美中文字幕视频| 亚洲国产日韩综合一区| 欧美日本在线一区| 欧美一区二区福利在线| 麻豆精品在线观看| 亚洲精品免费看| 国产精品色网| 老司机午夜精品| 99亚洲一区二区| 欧美成人激情视频| 亚洲图色在线| 国产在线拍偷自揄拍精品| 欧美激情综合| 另类成人小视频在线| 亚洲视频在线一区观看| 亚洲国产精品欧美一二99| 欧美一区二区三区久久精品 | 久久视频一区二区| 亚洲精品自在在线观看| 久久综合色88| 久久国产日韩欧美| 亚洲欧美视频在线观看视频| 在线观看一区视频| 久久视频国产精品免费视频在线| 性色av一区二区三区红粉影视| 国产亚洲aⅴaaaaaa毛片| 欧美成人按摩| 久久久久久久久综合| 午夜亚洲视频| 亚洲欧美国产毛片在线| 一区二区三区高清不卡| 日韩午夜激情| 最新高清无码专区| 亚洲福利视频一区二区| 91久久精品一区二区三区| 久久综合久久美利坚合众国| 久久不射2019中文字幕| 欧美一区综合| 美乳少妇欧美精品| 最新日韩在线视频| 亚洲小少妇裸体bbw| 久久精品亚洲精品国产欧美kt∨| 香蕉久久夜色精品国产| 久久视频精品在线| 免费视频一区| 国产欧美日韩在线视频| 影音先锋久久精品| 亚洲夜晚福利在线观看| 久久久精品午夜少妇| 欧美顶级大胆免费视频| 亚洲——在线| 欧美日韩大陆在线| 精品动漫av| 国产人妖伪娘一区91| 午夜在线不卡| 国产精品国产精品国产专区不蜜| 国产日韩精品一区二区三区| 一区二区欧美日韩| 欧美国产日本高清在线| 午夜精品短视频| 欧美久久99| av成人免费在线观看| 亚洲国产视频a| 免费不卡欧美自拍视频| 国产一区二区日韩精品欧美精品| 亚洲一区二区三区在线视频| 亚洲美女在线看| 欧美成人精品在线播放| 亚洲欧美久久久| 国产日韩欧美一区二区三区四区| 亚洲精品视频啊美女在线直播| 欧美国产亚洲另类动漫| 久久频这里精品99香蕉| 亚洲国产一区在线观看| 久久一区二区三区国产精品| 久久精品盗摄| 亚洲日韩欧美一区二区在线| 欧美激情视频给我| 欧美精品精品一区| 亚洲欧美日韩精品在线| 久久精品一二三| 亚洲精品日韩在线| 亚洲欧美美女| 在线电影国产精品| 欧美成人一区二区| 欧美先锋影音| 午夜精品久久久99热福利| 午夜伦欧美伦电影理论片| 亚洲国产成人在线播放| 99精品99| 亚洲电影免费观看高清完整版在线 | 亚洲美女av在线播放| 亚洲欧美日韩天堂| 亚洲另类自拍| 蜜桃久久av| 蜜臀久久99精品久久久画质超高清| 欧美日韩久久久久久| 久久综合电影| 国产在线视频欧美| 亚洲性av在线| 欧美一区二区播放| 国产精品日韩欧美一区| 亚洲午夜在线| 亚洲免费综合| 国产精品进线69影院| 一本一本a久久| 亚洲香蕉在线观看| 久久久999精品视频| 国产精品丝袜久久久久久app | 一区二区日韩免费看| 免费欧美网站| 91久久线看在观草草青青| 韩国欧美一区| 国产一区视频观看| 亚洲欧美影音先锋| 国产精品丝袜白浆摸在线| 亚洲影院免费观看| 欧美在线啊v|