精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

實踐API鉤子攔截DLL庫調用

安全 應用安全
在日常分析使用某個軟件的過程中,如果我們想要去挖掘軟件的漏洞、或者是通過打補丁的方式給軟件增添一些新的功能,抑或是為了記錄下軟件運行過程中被調用的函數及其參數,有時候我們需要劫持對某些DLL庫的調用過程。

[[177879]]

前言

在日常分析使用某個軟件的過程中,如果我們想要去挖掘軟件的漏洞、或者是通過打補丁的方式給軟件增添一些新的功能,抑或是為了記錄下軟件運行過程中被調用的函數及其參數,有時候我們需要劫持對某些DLL庫的調用過程。在一般情況下,如果我們是軟件的開發者或者該軟件提供源碼下載,那么剛才提到的問題只要對源碼進行一定的修改就可以了,簡直是小菜一碟。但是在更多情況下,我們無從獲取軟件或是庫的源碼,因為他們根本沒有采用源碼發行的方式。那這樣我們是否就一籌莫展了呢?通過閱讀這篇文章,我會告訴你最流行的“API鉤子”方法是什么,并且會以略微不同的方式展現給大家。

API鉤子

正如上文我們已經提到的,劫持DLL最流行的方法被稱作“API鉤子”——一種將庫函數調用重定向到你的代碼的技術。最為流行的API鉤子庫非微軟的 Microsoft Detours (常用于游戲破解)莫屬,并且這個商業庫被打上的價值標簽已經高達9999.95美元(約68999元人民幣)。再舉一個例子,在Dephi語言中有一個庫叫做 madCodeHook,他的商業價值約為349歐元(約2564元人民幣)。

下面就讓我們來看一看API鉤子的具體實現原理。

對于已經加載的DLL庫及對應函數,通過在想要鉤取的函數頭部首字節打上一個補丁(也叫重寫,個人認為叫覆蓋最為貼切),補丁內容為一個JMP指令,像是 JMP NEAR 這樣的形式,轉換成16進制就是 E9 xx xx xx xx。如下圖所示:

圖1:被鉤取的函數前后內容示意

當控制權被傳遞到我們鉤取過的函數后,通常這時就可以執行我們自己想要執行的代碼了,執行完畢后又會接著運行原函數然后返回到之前從DLL庫中調用該函數的代碼位置。

API鉤子其實會導致一些問題,而問題的來源就在于編譯過的軟件結構和它本身的代碼結構。當我們想要通過鉤子本身來調用原函數的時候(通常不加處理情況下會導致一個死循環),我們必須要創建一個特殊的代碼區塊來調用原函數代碼,這個代碼區塊有個別稱叫做“蹦床”(個人覺得在國內更常被稱為跳板),這樣的話就不用管鉤子本身是否在要調用的函數體內了。

另外需要說明的是,API鉤子技術不是萬能的,在受保護的DLL庫中幾乎不可能實現。說得詳細一點就是,比如存在CRC校驗保護的時候,無論是從硬盤上還是內存中對庫DLL庫代碼的修改都是不可行的。

還有一點就是,經典的API鉤子也不適用于DLL庫導出的“偽函數”,這里的偽函數是指導出的變量、類指針等等。因為在這種類型的“函數”條件下我們根本不可能在原函數和我們的代碼之間建立一個經典的代碼鉤子(事實上根本就沒有函數可鉤取)。那是不是就無可奈何了呢?上面我們提到的方法是改寫原函數代碼,而下面要介紹的第二種常見方法就是修改PE導出表。只不過這種方法的局限性很大,遠不如前一種流行,而且只有很少的一部分鉤子庫支持它。

DLL轉發

一種更加有創意但是也更為麻煩的API鉤取方式叫做“DLL”轉發,它通過Windows的內部機制來實現,基本原理就是轉發DLL調用至其他模塊。

DLL轉發技術基于“替換表“來實現,所以也被稱為“DLL代理”,它可以導出所有的原始庫函數,也可以傳遞所有對庫函數的調用——除了我們想要鉤取的那部分函數。而函數調用是被通過一些鮮為人知的Windows機制傳遞給原函數庫的,這樣我們就可以借此來調用其他庫函數,裝作他們本來就是存儲在我們使用的API鉤子庫里一樣,但事實上這些代碼被存儲在其他的庫中。弄明白以上這些過程,我們也就不難得知為什么要叫做“DLL轉發”了。

函數調用慣例

函數調用慣例是一個低等級的用于傳遞函數參數和處理函數調用返回前的堆棧的方式。很大一部分情況下它取決于編譯時的設置,并且在大多數高級編程語言中可以任意選擇函數調用的方式,所以兩者任取其一均可。為了讓我們的API鉤子庫正常運行,它的鉤取函數也必須使用和已經被鉤取的函數相同的調用慣例。他們只有在二進制情況下相互兼容才不會引發像堆棧破壞之類的異常。

表1. 函數調用慣例

調用慣例高度依賴于編譯器的默認設置,比如Delphi默認采用register調用慣例,C語言默認采用cdecl調用慣例。

WinAPI函數(Windows系統函數)默認使用stdcall調用慣例,所以在調用之前,函數的參數都使用push指令存儲在棧中,然后call指令被執行,執行完畢后并沒有必要去修正棧指針ESP,因為在stdcall調用慣例中,棧在函數返回前是自動修正的。這里值得一提的是,一個很有趣的現象是WinAPI中的有些函數并不使用stdcall而是C語言的cdecl,cdecl并不將參數存儲于棧,但棧的修正會在調用完成后根據函數參數的數量被編譯器修正。舉一個例子,user32.dll中的一個函數wsprintfA()(它在C函數庫中的對應是sprintf())就采用cdecl慣例,這種調用方式是備受推崇的,因為這樣除了編譯器之外沒有人知道究竟傳遞了多少個參數。

API鉤子實例

作為一個例子,我想讓它盡量簡單易懂一點,只會用到一個測試庫BlackBox.dll,它只導出兩個函數Sum()和Divide(),想必你已經猜到了,第一個函數的作用是兩個數的求和,第二個函數是兩個數的除法。讓我們假設我們擁有一個完整的庫文檔,并且清楚地知道這兩個函數使用的調用慣例(假設我們有這個庫的頭文件),而且我們還知道它們各自都使用哪些參數。在其他情況下我們需要使用逆向工程來獲得這些底層信息。

代碼清單1:

  1. 6// 該函數將兩個數相加并將結果儲存于Result變量中 
  2. // 成功返回TRUE,失敗返回ERROR  
  3. BOOL __stdcall Sum(int Number1, int Number2, int * Result);  
  4. // 該函數將兩個數相除并將結果儲存于Result變量中  
  5. // 成功返回TRUE,失敗返回ERROR  
  6. BOOL __stdcall Divide(int Number1, int Number2, int * Result); 

在我們的樣例庫中,Divide()函數是有bug的,因為如果除0就會導致程序崩潰(假設我們的程序并沒有做異常處理),現在我們的目標就是來修補這個漏洞。

代理DLL

為了修補BlackBox.dll中的漏洞,我們接下來需要創建一個中間庫,能夠使Divide()函數得以有效應用而不出現除0異常。該應用采用FASM編譯器(波蘭的mr Tomasza Grysztar 創建)的32位匯編器。在下面你會看到帶有精確注釋的樣例庫模板。

代碼清單2:樣例庫的開頭

  1. -------------------------------------------------  
  2. ; DLL 輸出文件格式  
  3. ;-------------------------------------------------  
  4. format PE GUI 4.0 DLL  
  5. ; DLL 入口點函數名  
  6. entry DllEntryPoint  
  7. ; 導入的Windows函數和常數  
  8. include '%fasm%\include\win32a.inc' 

注意源代碼的開頭,你可以在找到輸出文件的類型聲明,并且在頭文件、DLL庫的函數入口點也可以放置這些代碼。

代碼清單3:未初始化的數據段

  1. ;------------------------------------------------- 
  2. ; 未初始化的數據段 
  3. ;------------------------------------------------- 
  4. section '.bss' readable writeable 
  5. ; uchwyt HMODULE oryginalnej biblioteki 
  6. hLibOrgdd ? 

可執行文件和DLL庫被分割為一個個獨立的部分,他們其中之一是未初始化的數據段,這部分并不占用硬盤的空間,僅僅擁作于記錄程序所使用的未初始化變量的整體大小信息。可執行文件的段名稱并不重要(它被限制為最多只有8個字符),通常它會被賦以公司合同的名稱。在這個段的聲明中還會定義訪問權限(如讀、寫、執行),但是在FASM編譯器下.bss段的聲明還會為變量創建一個未初始化的段。

代碼清單4:數據段

  1. ;------------------------------------------------- 
  2. ; 初始化的數據段 
  3. ;------------------------------------------------- 
  4. section '.data' data readable writeable 
  5. ; 原始庫的名稱 
  6. szDllOrgdb 'BlackBox_org.dll',0 

因為原始庫已經有了名稱了,所以這里我們重命名一個BlackBox_org.dll(它以ASCII形式存儲于源代碼中,以null結束),這個庫會在后面用到。

代碼清單5:帶有DLL入口點的代碼段

  1. ;------------------------------------------------- 
  2. ; 庫的代碼段 
  3. ;------------------------------------------------- 
  4. section '.text' code readable executable 
  5. ;------------------------------------------------- 
  6. ; DLL庫入口點 (DllMain) 
  7. ;------------------------------------------------- 
  8. proc DllEntryPoint hinstDLL, fdwReason, lpvReserved 
  9. moveax,[fdwReason] 
  10. ; DLL library 加載完畢后立即傳遞事件 
  11. cmpeax,DLL_PROCESS_ATTACH 
  12. je_dll_attach 
  13. jmp_dll_exit 
  14. ; 庫已經加載 
  15. _dll_attach: 
  16. ; 獲得原始 DLL 庫的句柄 
  17. ; 如果想要調用原始函數就會使用 
  18. pushszDllOrg 
  19. call[GetModuleHandleA] 
  20. mov[hLibOrg],eax 
  21. ; 返回 1 說明庫初始化成功 
  22. moveax,1 
  23. _dll_exit: 
  24. ret 

代碼段包含所有庫函數和DLL入口點函數。這是一個特殊的函數,它在庫加載以后被Windows系統函數調用。代碼段需要被標記上可執行的標記,以此來告訴操作系統這段內存區域包含可以執行的代碼段。如果沒有這樣標記,那么任何想從這塊內存區域執行代碼的行為都會以觸發CPU處理器的DEP(Data Execution Prevention)內存保護機制而告終。在初始化函數內部(DllMain),接收到 DLL_PROCESS_ATTACH 事件后我們將使用原始DLL庫名稱來獲得他的句柄,也就是 HMODULE (這樣之后就可以被調用了)。

代碼清單6:過度優化保護

  1. ; 調用任何原始庫 
  2. ; BlackBox_org.dll 中的函數, 沒有它FASM編譯器就會 
  3. ; 移除對庫的引用并且不會被自動加載 
  4. calldummy 

我們自定義的庫會調用到原始庫,但是如果我們一點引用也不放在源代碼中,FASM編譯器會移除所有對它的引用(優化)而且原始庫并不會被自動加載,這就是為什么在ret指令后直接放了一個偽調用的緣故(這樣在任何時候都不會執行)。

代碼清單7:有效的Divide()函數代碼

  1. ;------------------------------------------------- 
  2. ; 我們修改后能夠處理除0錯誤的Divide() 函數 
  3. ;------------------------------------------------- 
  4. proc Divide Number1, Number2, Result 
  5. ; 檢查除數是否為0 
  6. ; 如果是的話返回ERROR代碼 
  7. movecx,[Number2] 
  8. testecx,ecx 
  9. jeDivisionError 
  10. ; 將第一個數字載入 EAX 處理器 
  11. moveax,[Number1] 
  12. ;擴展 EDX 寄存器來處理有符號數 
  13. cdq 
  14. ; 現在 EDX:EAX 寄存器對可以處理64位數據了 
  15. ; EDX:EAX / ECX 除法的實現, 除法在EDX:EAX寄存器對 
  16. ; 上實現,就像對待64位數據一樣, 除法的結果保存在EAX 
  17. ; 寄存器中, 余數保存在EDX 寄存器中 
  18. idiv ecx 
  19. ; 檢查有效的指向結果的指針 
  20. ; 如果沒有檢測到則返回error 代碼 
  21. movedx,[Result] 
  22. testedx,edx 
  23. jeDivisionError 
  24. ; 在受保護的地址存儲除法的結果 
  25. mov[edx],eax 
  26. ; 以 exit code TRUE (1) 返回 
  27. moveax,1 
  28. jmpDivisionExit 
  29. ; 除法錯誤,返回FALSE (0) 
  30. DivisionError: 
  31. sub eax,eax 
  32. DivisionExit: 
  33. ; 從除法函數中返回 
  34. ; 布爾型的exit 代碼被設置在 EAX 寄存器中 
  35. ret 
  36. endp 

修改后的Divide()函數的實現增添了對除0錯誤的校驗,函數遇到錯誤會返回錯誤代碼FALSE,另外還額外做了對指向結果變量result的指針非空檢查,如果指針指向null也會報錯。另外請注意,修改后的函數的調用慣例與原函數是完全一致的,并且在我們的這個例子中使用的是stdcall慣例,所以函數參數被傳遞到棧中,函數返回值儲存于EAX寄存器,棧指針也被FASM編譯器自動修復,方法是根據源代碼中的ret聲明生成ret (number_of_parameters * 4)指令。

代碼清單8:庫的導入表

  1. ;------------------------------------------------- 
  2. ; 我們的庫使用的函數段 
  3. ;------------------------------------------------- 
  4. section '.idata' import data readable writeable 
  5. ; 在代碼中用到的庫的列表 
  6. library kernel,'KERNEL32.DLL',\ 
  7. blackbox, 'BlackBox_org.dll' 
  8. ; KERNEL32.dll庫的函數列表 
  9. importkernel,\ 
  10. GetModuleHandleA, 'GetModuleHandleA' 
  11. ; 聲明了原始庫的用途 
  12. ; DLL 庫會被自動加載 
  13. importblackbox,\ 
  14. dummy, 'Divide' 

FASM編譯器允許我們手動地定義我們自己的庫調用到的庫和函數,除了標準系統庫,我們需要在這里添加一個對 BlackBox.dll 的引用。多虧于此,當Windows加載我們的鉤子庫的同時也會根據地址空間加載原始庫,從而無需再手動調用 LoadLibraryA() 函數來加載它。 在某些情況下想要使用導入表來加載庫甚至是強制性要求使用 LoadLibraryA() 的,它需要使用多線程應用程序中TLS(Thread Local Storage)機制的動態鏈接庫來支持。

代碼清單9:函數導出表

  1. ;------------------------------------------------- 
  2. ; 導出表段包含我們的庫中導出的函數 
  3. ; 這里我們也許要聲明原始庫中聲明的函數 
  4. ;------------------------------------------------- 
  5. section '.edata' export data readable 
  6. ; 導出函數列表及其指針 
  7. export'BlackBox.dll',\ 
  8. Sum'Sum',\ 
  9. Divide, 'Divide' 
  10. ; 轉發表名稱, 首先目的庫被存儲 (無需.DLL擴展) 
  11. ; 然后最終的函數名稱被存儲 
  12. Sum db 'BlackBox_org.Sum',0 

在這個段中我們必須聲明原始庫中的所有函數,而且我們想要鉤取的函數必須在代碼中得以應用,想要傳遞給原始庫的函數存儲在一個特殊的文本格式中:

DestinationDllLibrary.FunctionName

DestinationDllLibrary.#1

以此來順序導入函數而非按照名稱的順序。該機制的所有內部工作均交由Windows系統自身處理。以上為DLL轉發。

代碼清單10:重定位部分

  1. ;------------------------------------------------- 
  2. ; 重定位部分 
  3. ;------------------------------------------------- 
  4. section '.reloc' fixups data discardable 

我們的庫中最后一個段是重定位段,它保證了我們的庫能夠正常運行。這是因為動態鏈接庫被加載的基地址是非常多變的,而引起這個多變性的原因在于指針使用的絕對地址和匯編器的指令使用的絕對地址必須根據當前內存中的基地址做出更新,而這個基地址的信息正是由編譯器在重定位段中生成的。

總結

這篇API鉤子介紹的方法可以被成功應用于各種使用動態鏈接庫的場合,較傳統的經典API鉤子方法而言各有利弊,但是在我看來本文的方法為實踐打開了更大的拓展空間,并提供了一種更加簡單的改變軟件完整功能性的方法。該方法同樣可以在高級語言中以適當的導出函數定義文件(DEF)的方式實現。

責任編輯:武曉燕 來源: overXsky
相關推薦

2009-08-05 16:49:42

C#中調用dll

2024-03-01 20:59:11

C#DLL開發

2009-12-14 16:44:56

Ruby調用DLL

2024-09-25 08:04:58

2009-07-31 17:28:35

C#語言調用DLL

2009-08-03 12:57:27

C#調用DLL

2009-08-07 17:22:36

C#調用dll導出函數

2011-06-28 13:12:07

Qt 調用 DLL DLL

2009-08-05 09:40:02

C#調用DLL函數

2009-08-05 16:41:36

C#調用VC dll

2009-09-02 17:16:01

冒泡排序

2009-08-05 09:30:39

C#調用DLL函數

2019-01-21 14:20:26

Java開發代碼

2013-06-13 09:21:31

RESTful APIRESTfulAPI

2011-12-02 09:20:58

JavaScript

2010-01-26 14:04:14

C++Builder

2009-06-17 13:19:50

Java調用DLL

2022-03-29 10:04:44

APIHarmony文件管理

2016-12-27 08:49:55

API設計策略

2009-07-08 17:02:11

JDK實現調用攔截器
點贊
收藏

51CTO技術棧公眾號

91中文字幕在线观看| 亚洲美女av电影| 欧美成人精品免费| 婷婷五月综合久久中文字幕| 久久久水蜜桃av免费网站| 最新69国产成人精品视频免费 | 亚洲一区二区三区免费在线观看| 亚洲美女性视频| 天堂av手机在线| 色是在线视频| 亚洲女厕所小便bbb| 免费日韩电影在线观看| 国产精品综合在线| 亚洲国产综合在线看不卡| 亚洲最大中文字幕| 亚洲自拍偷拍精品| 日韩专区视频| 日本高清无吗v一区| h无码动漫在线观看| 欧美精品hd| www一区二区| 国产精品久久久久久久免费大片 | 久久国产精品久久w女人spa| 俺去啦;欧美日韩| 中国美女乱淫免费看视频| 亚洲一区网址| 欧美精品tushy高清| 超碰影院在线观看| 182在线视频观看| 亚洲视频香蕉人妖| 亚洲色图自拍| 黄色小视频在线观看| 暴力调教一区二区三区| 亚洲自拍偷拍在线| 亚洲天堂男人网| 久久综合影音| 欧美性受xxx| 日韩特黄一级片| 国产精品激情电影| 麻豆乱码国产一区二区三区| 刘亦菲国产毛片bd| 精品美女视频| 亚洲人成电影网站色…| 少妇大叫太粗太大爽一区二区| aiai久久| 精品国产一区二区三区四区四| 国产欧美精品一二三| 国产福利一区二区三区在线播放| 欧美日韩国产影院| 国产极品在线视频| 牛牛精品一区二区| 五月综合激情日本mⅴ| 精品国产av无码一区二区三区| 国产在线高清视频| 亚洲人成人一区二区在线观看| 在线观看欧美激情| 国产免费视频在线| 91丨九色丨蝌蚪丨老版| 鲁丝一区鲁丝二区鲁丝三区| 日本私人网站在线观看| 91丨九色丨国产丨porny| 久久久久久久久一区二区| 欧美拍拍视频| 日本一区二区三级电影在线观看| 亚洲一区二区三区精品视频| 日本在线视频站| 亚洲欧美国产高清| www.亚洲视频.com| 麻豆理论在线观看| 色悠悠亚洲一区二区| 欧美一级裸体视频| 亚洲国产伊人| 精品成人在线观看| 一区二区三区免费在线观看视频| 中国av一区| 中文字幕日韩有码| 午夜国产福利一区二区| 在线观看的日韩av| 国产99久久精品一区二区永久免费| 免费一级a毛片| 久久成人久久爱| 国产aⅴ精品一区二区三区黄| 婷婷伊人综合中文字幕| 欧美激情一区二区三区不卡| 熟女视频一区二区三区| 91jq激情在线观看| 欧美亚洲动漫精品| 91视频免费入口| 妖精视频一区二区三区免费观看| 一道本无吗dⅴd在线播放一区| 天天做夜夜爱爱爱| 99国产精品久久久久久久| 国产精品久久97| 亚洲AV无码一区二区三区少妇| 久久影院电视剧免费观看| 综合视频免费看| 手机在线理论片| 91精品婷婷国产综合久久性色| 香港三日本8a三级少妇三级99 | 大地资源网在线观看免费官网| aa视频在线观看| 欧美亚洲自拍偷拍| 性猛交╳xxx乱大交| 欧美日韩一二三四| 久久久久久一区二区三区| 日韩av免费播放| 成人一区二区在线观看| 亚洲免费精品视频| 亚洲国产成人二区| 欧美成人猛片aaaaaaa| 国产精品久久久久久成人| 国一区二区在线观看| 国产在线精品一区免费香蕉| 三级视频在线| 亚洲精品日产精品乱码不卡| 噼里啪啦国语在线观看免费版高清版| 日韩精品一区二区三区免费视频| 一本色道久久88综合日韩精品 | 国产1区2区在线观看| 亚洲美女91| 2014国产精品| 伊人免费在线| 91传媒视频在线播放| 国产 xxxx| 黄色av日韩| 亚洲一区亚洲二区| 亚洲搞黄视频| 欧美在线视频你懂得| 97伦伦午夜电影理伦片| 亚洲免费播放| 国内精品久久国产| jizz一区二区三区| 欧美本精品男人aⅴ天堂| 成年人二级毛片| 久久福利视频一区二区| 亚洲欧美精品| 久久亚洲国产精品尤物| 视频直播国产精品| 涩涩视频在线观看| 国产精品欧美久久久久无广告| 国产精品涩涩涩视频网站| 西瓜成人精品人成网站| 欧美亚洲另类激情另类| 三级理论午夜在线观看| 色婷婷国产精品综合在线观看| 野外性满足hd| 日精品一区二区三区| 青青影院一区二区三区四区| 欧美粗大gay| 国产亚洲人成a一在线v站| 91视频在线视频| 国产午夜亚洲精品理论片色戒 | 天然素人一区二区视频| 永久免费精品影视网站| 中文字幕黄色av| 国产精品久久三| 一区二区三区四区毛片| 综合激情一区| 国产欧美日韩一区二区三区| 麻豆蜜桃在线观看| 国产一区二区动漫| 国产精品久久久久久久成人午夜| 亚洲精品综合在线| 中文字幕在线永久| 亚洲男人影院| 亚洲图片小说在线| 韩国一区二区三区视频| 久久乐国产精品| 欧美日本网站| 欧美人动与zoxxxx乱| 激情综合五月网| 91色综合久久久久婷婷| 国产成人黄色网址| 最新国产精品| 精品国产aⅴ麻豆| 日韩欧美精品一区二区综合视频| xxx一区二区| 亚洲黄色片视频| 欧美午夜视频一区二区| 日本不卡一区视频| 成a人片亚洲日本久久| 欧美亚洲日本在线观看| 91精品秘密在线观看| 狠狠综合久久av| 九九热这里有精品| 欧美精品久久久久a| 黄色在线观看网| 日韩欧美一级二级三级| 伊人中文字幕在线观看| 综合久久一区二区三区| 内射中出日韩无国产剧情| 卡一卡二国产精品| 男人天堂1024| 中文精品久久| 欧美日韩一区在线播放| 婷婷综合国产| 国产精品久久久久福利| 2001个疯子在线观看| 综合av色偷偷网| 国模人体一区二区| 欧美精品在线观看一区二区| 影音先锋亚洲天堂| 一区二区在线观看av| 无码少妇精品一区二区免费动态| 国产传媒欧美日韩成人| 99视频在线免费| 一区免费视频| 久久久成人精品一区二区三区| 亚洲品质自拍| 国产视频精品网| 国产一区二区三区国产精品| 国产精品草莓在线免费观看| av中文字幕在线观看第一页 | 日韩精品免费在线视频| 国产强被迫伦姧在线观看无码| 色国产精品一区在线观看| 国产第100页| 亚洲精品你懂的| 蜜臀av一区二区三区有限公司| 成人午夜电影久久影院| 手机在线观看日韩av| 日日夜夜免费精品| 久草精品在线播放| 性欧美长视频| 亚洲中文字幕无码专区| 黄色成人91| 日本aa在线观看| 一区二区三区在线电影| 一区二区不卡视频| 日韩国产一区| 香蕉久久夜色| 国产一区二区在线| 欧美日韩精品免费观看视一区二区 | 国产欧美日韩免费看aⅴ视频| 新版的欧美在线视频| 97久久精品国产| 97蜜桃久久| 午夜免费在线观看精品视频| hd国产人妖ts另类视频| 久久乐国产精品| 国产传媒av在线| 57pao国产成人免费| 中文在线8资源库| 日本国产精品视频| 亚洲成人短视频| 国产高清视频一区三区| 国产精成人品2018| 国产精品爽黄69| 电影中文字幕一区二区| 1卡2卡3卡精品视频| 东京久久高清| 六月婷婷久久| 日韩电影免费网址| 青春草在线视频免费观看| 综合激情网站| 日本午夜激情视频| 午夜在线视频观看日韩17c| 亚洲 高清 成人 动漫| 久久中文欧美| 中文字幕永久有效| 国产成人免费视频网站高清观看视频| wwwww在线观看| 北条麻妃一区二区三区| av在线网站观看| 国产精品你懂的在线| 国产精品丝袜一区二区| 亚洲一区视频在线| 五月天激情国产综合婷婷婷| 欧美天堂亚洲电影院在线播放| 国产精品无码AV| 亚洲第一国产精品| 国产视频二区在线观看| 久久香蕉国产线看观看av| 超碰97免费在线| 欧美一级成年大片在线观看 | 欧美区在线观看| 99久久精品无免国产免费| 亚洲高清av在线| av在线收看| 欧美激情视频一区二区| 欧美xo影院| 97久久夜色精品国产九色| 神马香蕉久久| 熟女熟妇伦久久影院毛片一区二区| 黄色另类av| 久久久久久三级| 国产成人免费在线视频| a级片在线观看| 亚洲激情图片qvod| 日本中文字幕在线观看视频| 欧美一级黄色片| 东凛在线观看| 97国产精品免费视频| 91成人福利社区| 欧美伦理一区二区| 欧美久久一级| 男女污污的视频| 成人一区二区三区视频| 美国美女黄色片| 午夜精品久久久久影视| 国产精品久久久久久久免费看| 日韩精品在线电影| 一区二区三区伦理| 国产欧美精品一区二区三区介绍| 日本欧美三级| 人妻av无码专区| 麻豆一区二区99久久久久| 黄色正能量网站| 亚洲国产一区二区视频| 一级片免费网站| 国产一区二区黄| 韩日成人影院| 国产精品视频免费一区二区三区| 99热国内精品永久免费观看| 97在线免费公开视频| 成人午夜私人影院| 国产一区二区三区在线视频观看| 在线观看国产日韩| 麻豆app在线观看| 欧美一级高清免费播放| 99亚洲乱人伦aⅴ精品| 成年丰满熟妇午夜免费视频 | 影音国产精品| 久久久久亚洲av片无码v| 国产精品久久久久久久第一福利| 免费黄色片视频| 亚洲视频专区在线| 中文在线资源| 欧美日韩一区在线播放| 亚洲男人影院| xxxx日本免费| 一本久久综合亚洲鲁鲁五月天 | 人妻丰满熟妇av无码区hd| 久久的精品视频| 国产视频一区二| 欧美少妇一级片| 国产在线一区二区| 一区二区国产精品精华液| 欧美日韩免费观看一区二区三区| 国产高清在线观看| 国产精品网址在线| 欧美电影三区| 久久久九九九热| 亚洲精品写真福利| 亚洲第一页在线观看| 欧美国产日韩免费| 都市激情亚洲欧美| 黄色一级视频在线播放| jlzzjlzz亚洲日本少妇| 麻豆久久久久久久久久| 国产视频亚洲精品| 欧美三区四区| 在线视频亚洲自拍| 国产高清一区日本| 日韩黄色a级片| 亚洲久久久久久久久久| 超碰这里只有精品| 一道本在线观看视频| 粉嫩绯色av一区二区在线观看 | 欧美另类视频在线| 日韩高清欧美激情| 蜜桃av.com| 欧美videos大乳护士334| 岛国av在线网站| 日本高清一区| 狠狠色2019综合网| 久久久久亚洲av成人片| 国产视频久久久久| 欧美一级做a| 免费看欧美一级片| 久久久www成人免费毛片麻豆| 日批视频免费观看| 欧美插天视频在线播放| 欧美自拍视频| 一区二区免费av| 性欧美疯狂xxxxbbbb| 国产毛片在线看| 成人18视频| 日韩在线a电影| 69xx绿帽三人行| 亚洲精品中文字幕女同| 亚洲欧美在线人成swag| 精品少妇在线视频| 欧美国产视频在线| 懂色av成人一区二区三区| 日韩免费av一区二区| 自拍视频亚洲| 五级黄高潮片90分钟视频| 4438x亚洲最大成人网| av毛片午夜不卡高**水| 午夜一区二区三区| 成年人网站91| 国产精品久久久久久久久久久久久久久久| 韩剧1988免费观看全集| 欧美第十八页| 中文字幕丰满乱子伦无码专区| 欧美一区二区免费视频| 精品3atv在线视频| 大西瓜av在线| 亚洲人成网站影音先锋播放|