亚洲国产精品人久久,亚洲va国产日韩欧美精品色婷婷,久久久久88色偷偷,免费人成黄页在线观看国际

17站長網

17站長網 首頁 網站 服務器 查看內容

Tomcat 類加載器的實現方法及實例代碼

2022-10-6 09:28| 查看: 1464 |來源: 互聯網

Tomcat 內部定義了多個 ClassLoader,以便應用和容器訪問不同存儲庫中的類和資源,同時達到應用間類隔離的目的。 1. Java 類加載機制 類加載就是把編譯生成的 class 文件,加載到 JVM 內存中(永久代/元空間)。

Tomcat 內部定義了多個 ClassLoader,以便應用和容器訪問不同存儲庫中的類和資源,同時達到應用間類隔離的目的。

1. Java 類加載機制

類加載就是把編譯生成的 class 文件,加載到 JVM 內存中(永久代/元空間)。

類加載器之所以能實現類隔離,是因為兩個類相等的前提是它們由同一個類加載器加載,否則必定不相等。

JVM 在加載時,采用的是一種雙親委托機制,當類加載器要加載一個類時,加載順序是:

首先將請求委托給父加載器,如果父加載器找不到要加載的類然后再查找自己的存儲庫嘗試加載

這個機制的好處就是能夠保證核心類庫不被覆蓋。

而按照 Servlet 規范的建議,Webapp 加載器略有不同,它首先會在自己的資源庫中搜索,而不是向上委托,打破了標準的委托機制,來看下 Tomcat 的設計和實現。

2. Tomcat 類加載器設計

Tomcat 整體類加載器結構如下:

其中 JDK 內部提供的類加載器分別是:

Bootstrap - 啟動類加載器,屬于 JVM 的一部分,加載 /lib/ 目錄下特定的文件Extension - 擴展類加載器,加載 /lib/ext/ 目錄下的類庫Application - 應用程序類加載器,也叫系統類加載器,加載 CLASSPATH 指定的類庫

Tomcat 自定義實現的類加載器分別是:

Common - 父加載器是 AppClassLoader,默認加載 ${catalina.home}/lib/ 目錄下的類庫Catalina - 父加載器是 Common 類加載器,加載 catalina.properties 配置文件中 server.loader 配置的資源,一般是 Tomcat 內部使用的資源Shared - 父加載器是 Common 類加載器,加載 catalina.properties 配置文件中 shared.loader 配置的資源,一般是所有 Web 應用共享的資源WebappX - 父加載器是 Shared 加載器,加載 /WEB-INF/classes 的 class 和 /WEB-INF/lib/ 中的 jar 包JasperLoader - 父加載器是 Webapp 加載器,加載 work 目錄應用編譯 JSP 生成的 class 文件

在實現時,上圖不是繼承關系,而是通過組合體現父子關系。Tomcat 類加載器的源碼類圖:

Common、Catalina 、Shared 它們都是 StandardClassLoader 的實例,在默認情況下,它們引用的是同一個對象。其中 StandardClassLoader 與 URLClassLoader 沒有區別;WebappClassLoader 則按規范實現以下順序的查找并加載:

從 JVM 內部的 Bootstrap 倉庫加載從應用程序加載器路徑,即 CLASSPATH 下加載從 Web 程序內的 /WEB-INF/classes 目錄從 Web 程序內的 /WEB-INF/lib 中的 jar 文件從容器 Common 加載器倉庫,即所有 Web 程序共享的資源加載

接下來看下源碼實現。

3. 自定義加載器的初始化

common 類加載器是在 Bootstrap 的 initClassLoaders 初始化的,源碼如下:

private void initClassLoaders() { try { commonLoader = createClassLoader("common", null); if( commonLoader == null ) { // no config file, default to this loader - we might be in a 'single' env. commonLoader=this.getClass().getClassLoader(); } // 指定倉庫路徑配置文件前綴和父加載器,創建 ClassLoader 實例 catalinaLoader = createClassLoader("server", commonLoader); sharedLoader = createClassLoader("shared", commonLoader); } catch (Throwable t) { log.error("Class loader creation threw exception", t); System.exit(1); } }

可以看到分別創建了三個類加載器,createClassLoader 就是根據配置獲取資源倉庫地址,最后返回一個 StandardClassLoader 實例,核心代碼如下:

private ClassLoader createClassLoader(String name, ClassLoader parent) throws Exception { String value = CatalinaProperties.getProperty(name + ".loader"); if ((value == null) || (value.equals(""))) return parent; // 如果沒有配置,則返回傳入的父加載器 ArrayList repositoryLocations = new ArrayList(); ArrayList repositoryTypes = new ArrayList(); ... // 獲取資源倉庫路徑 String[] locations = (String[]) repositoryLocations.toArray(new String[0]); Integer[] types = (Integer[]) repositoryTypes.toArray(new Integer[0]); // 創建一個 StandardClassLoader 對象 ClassLoader classLoader = ClassLoaderFactory.createClassLoader (locations, types, parent); ... return classLoader; }

類加載器初始化完畢后,會創建一個 Catalina 對象,最終會調用它的 load 方法,解析 server.xml 初始化容器內部組件。那么容器,比如 Engine,又是怎么關聯到這個設置的父加載器的呢?

Catalina 對象有一個 parentClassLoader 成員變量,它是所有組件的父加載器,默認是 AppClassLoader,在此對象創建完畢時,會反射調用它的 setParentClassLoader 方法,將父加載器設為 sharedLoader。

而 Tomcat 內部頂級容器 Engine 在初始化時,Digester 有一個 SetParentClassLoaderRule 規則,會將 Catalina 的 parentClassLoader 通過 Engine.setParentClassLoader 方法關聯起來。

4. 如何打破雙親委托機制

答案是使用 Thread.getContextClassLoader() - 當前線程的上下文加載器,該加載器可通過 Thread.setContextClassLoader() 在代碼運行時動態設置。

默認情況下,Thread 上下文加載器繼承自父線程,也就是說所有線程默認上下文加載器都與第一個啟動的線程相同,也就是 main 線程,它的上下文加載器是 AppClassLoader。

Tomcat 就是在 StandardContext 啟動時首先初始化一個 WebappClassLoader 然后設置為當前線程的上下文加載器,最后將其封裝為 Loader 對象,借助容器之間的父子關系,在加載 Servlet 類時使用。

5. Web 應用的類加載

Web 應用的類加載是由 WebappClassLoader 的方法 loadClass(String, boolean) 完成,核心代碼如下:

在防止覆蓋 J2SE

public synchronized Class loadClass(String name, boolean resolve) throws ClassNotFoundException { ... Class clazz = null; // (0) 檢查自身內部緩存中是否已經加載 clazz = findLoadedClass0(name); if (clazz != null) { if (log.isDebugEnabled()) log.debug(" Returning class from cache"); if (resolve) resolveClass(clazz); return (clazz); } // (0.1) 檢查 JVM 的緩存中是否已經加載 clazz = findLoadedClass(name); if (clazz != null) { if (log.isDebugEnabled()) log.debug(" Returning class from cache"); if (resolve) resolveClass(clazz); return (clazz); } // (0.2) 嘗試使用系統類加載加載,防止覆蓋 J2SE 類 try { clazz = system.loadClass(name); if (clazz != null) { if (resolve) resolveClass(clazz); return (clazz); } } catch (ClassNotFoundException e) {// Ignore} // (0.5) 使用 SecurityManager 檢查是否有此類的訪問權限 if (securityManager != null) { int i = name.lastIndexOf('.'); if (i >= 0) { try { securityManager.checkPackageAccess(name.substring(0,i)); } catch (SecurityException se) { String error = "Security Violation, attempt to use " + "Restricted Class: " + name; log.info(error, se); throw new ClassNotFoundException(error, se); } } } boolean delegateLoad = delegate || filter(name); // (1) 是否委托給父類,這里默認為 false if (delegateLoad) { ... } // (2) 嘗試查找自己的存儲庫并加載 try { clazz = findClass(name); if (clazz != null) { if (log.isDebugEnabled()) log.debug(" Loading class from local repository"); if (resolve) resolveClass(clazz); return (clazz); } } catch (ClassNotFoundException e) {} // (3) 如果此時還加載失敗,那么將加載請求委托給父加載器 if (!delegateLoad) { if (log.isDebugEnabled()) log.debug(" Delegating to parent classloader at end: " + parent); ClassLoader loader = parent; if (loader == null) loader = system; try { clazz = loader.loadClass(name); if (clazz != null) { if (log.isDebugEnabled()) log.debug(" Loading class from parent"); if (resolve) resolveClass(clazz); return (clazz); } } catch (ClassNotFoundException e) {} } // 最后加載失敗,拋出異常 throw new ClassNotFoundException(name); } 在防止覆蓋 J2SE 類的時候,版本 Tomcat 6,使用的是 AppClassLoader,rt.jar 核心類庫是由 Bootstrap Classloader 加載的,但是在 Java 代碼是獲取不了這個加載器的,在高版本做了以下優化: ClassLoader j = String.class.getClassLoader(); if (j == null) { j = getSystemClassLoader(); while (j.getParent() != null) { j = j.getParent(); } } this.javaseClassLoader = j;

類的時候,版本 Tomcat 6,使用的是 AppClassLoader,rt.jar 核心類庫是由 Bootstrap Classloader 加載的,但是在 Java 代碼是獲取不了這個加載器的,在高版本做了以下優化:

ClassLoader j = String.class.getClassLoader(); if (j == null) { j = getSystemClassLoader(); while (j.getParent() != null) { j = j.getParent(); } } this.javaseClassLoader = j;

也就是使用盡可能接近 Bootstrap 加載器的類加載器。

6. 小結

相信大部分人都遇到過 ClassNotFoundException 這個異常,這背后就涉及到了類加載器,對加載的原理有一定的了解,有助于排查問題。

本文最后更新于 2022-10-6 09:28,某些文章具有時效性,若有錯誤或已失效,請在網站留言或聯系站長:17tui@17tui.com
·END·
站長網微信號:w17tui,關注站長、創業、關注互聯網人 - 互聯網創業者營銷服務中心

免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系我們及時修正或刪除。謝謝!

17站長網微信二維碼

始終以前瞻性的眼光聚焦站長、創業、互聯網等領域,為您提供最新最全的互聯網資訊,幫助站長轉型升級,為互聯網創業者提供更加優質的創業信息和品牌營銷服務,與站長一起進步!讓互聯網創業者不再孤獨!

掃一掃,關注站長網微信

大家都在看

  • 當我們在共享網絡訪問的時候,可能會遇到提示指定的網絡名不再可用的問題,這可能是由于我們的共享網絡出現了錯誤,也可能是被共享的對象所拒絕了。指定的網絡名 ......

    故障排除 2023-03-10
  • 1、首先進入到“百度”軟件中, 2、然后在其中輸入“百度識圖”, 3、之后點擊圖中的“開始使用”按鈕, 4、緊接著點擊右下角的“相冊”功能, 5、在相冊下 ......

    軟件教程 2023-02-17
  • 一、軟件沖突1、首先確認是否是應用程序沖突導致的。2、查看是否只有特定幾個游戲或應用會導致該問題。3、如果是應用沖突,那么只要卸載這些app就可以解決了。二 ......

    軟件教程 2022-12-27
  •   文/曹楊  原標題:誰還看電視?  爸爸戴一副老花鏡,媽媽戴一副近視鏡,一人坐在沙發,一人躺在床上,各自刷著自己關注的博主更新的短視頻。電視也許開著,但只是背景。  這樣的畫面,幾乎成了洛奇家的常 ...

    站長 2020-12-09
  • 圖片來源于簡書  文/郭開森 楊帆  陸玖財經準備開新欄目了,每周一創始人郭開森和楊帆合體郭德帆,對行業進行一些觀察和評論,第一篇我們仍是打算寫社區團購,這是當下最火的話題。  來過陸玖財經做客的朋友們...

    熱議 2020-12-07
  • 一、N100對比intel i3 1、N100的跑分達到了147210分,這個數據可以達到i3的七代級別。 2、在跑分上也是超越了大部分的I3七代CPU,不過比I3八代要弱勢一些。 3 ......

    硬件知識 2023-04-26
  • 電腦端:1、大家可以點擊右邊鏈接進入網頁版的百度網盤,進入之后點擊“去登錄”。https://pan.baidu.com/2、之后正確的輸入賬號密碼進行登錄就好啦。手機端:1 ......

    軟件教程 2022-12-27
  • 在填寫一些項目申請書中,總是免不了要選擇一些數字,但是在方框中如何插入數字,該怎么辦呢?那么下面就由學習啦小編給大家分享下word在方框里輸入數字的技巧, ......

    Word教程 2023-04-27
  • 8月15日消息 上周,有媒體報道前身為百度圖片的“榴蓮”APP含有大量不雅視頻內容被用戶舉報。對此,百度圖片官方進行了回應,百度圖片表示已經對報道中所涉及的“生吃旋風哥”等爭議內容進行了下線處理。 此外,百度...

    站長 2016-08-15
  • 迅雷前綴是什么 答:迅雷前綴是(magnet:?xt=urn:btih:)括號里的就是了。 我們只要在這段文字之后輸入后續的內容,就可以創建下載鏈接了。 1、磁力鏈接不基于文 ......

    軟件教程 2023-06-03
  • WPS Office手機版怎么加橫線?很多用戶還不知道WPS Office手機版怎么加橫線,WPS Office手機版怎么加橫線,WPS Office手機版怎么打橫線,WPS Office手機版怎么弄 ......

    WPS教程 2023-03-31
  • 一、內容特權。 1、半價點播。 許多站內視頻都需要付費觀看,而大會員用戶可以直接半價享受; 購買成功后的48h內無限次觀看。有部分的內容是只限在中國大陸內觀 ......

    軟件教程 2023-05-05
  • 藍奏云怎么打開別人分享的鏈接1、當我們獲得了鏈接以后,首先需要把鏈接粘貼進瀏覽器里回車進入。2、進入以后就會轉到這樣一個頁面,如果有密碼的話我們就輸入給 ......

    軟件教程 2023-03-16
  • 1、首先打開小米運動的“實驗室功能”。 2、接著點擊“門卡模擬”。 3、然后點擊“我知道了”。 4、最后貼近就可以刷卡成功了。...

    硬件知識 2023-05-17
  • 1、打開手機輕顏相機app,點擊“我的”,點擊“設置”,2、點擊“幫助與反饋”,3、點擊右下角“在線咨詢”即可聯系客服,詢問自己的問題啦!...

    軟件教程 2023-03-16
  • 答:華為P系列: 華為p40,華為p40plus,華為p50,華為p50e,華為p60 華為mate系列: 華為mate40,華為mate50,華為mate50e,華為mate60 華為nova系列: 華為n ......

    鴻蒙系統 2023-04-24
  • 近期有用戶反映,電腦在更新Windows 11 Insider Preview 25252.1000后,出現了應用和已壓縮的文件點擊毫無反應,拖拽都不行,只能從開始菜單打開的情況,這是怎 ......

    windows11 2022-12-13
  • 可見單元格就是不包括隱藏或者篩選篩選后隱藏起來的單元格區域。方法:篩選或隱藏數據,復制需要粘貼的值,在目標單元格區域左上角的第一個單元格處右擊,選擇【 ......

    WPS教程 2022-12-10
  • 答:驍龍8+更好。 驍龍7+gen2實際上就是驍龍8+的低配版本。 在一些其他的核心架構方面都是保持一致的,比如說CPU的架構、GPU的架構等等。 驍龍7+和驍龍8+具體 ......

    硬件知識 2023-04-06
  • 1、先打開機頂盒進入主界面,并且使用遙控器打開設置。 2、然后選擇“賬號與安全”,并且進入。 3、最后往下面翻就可以看到“ADB調試”的選項,直接開啟就行了 ......

    軟件教程 2023-06-01
  • 答:在3DMark壓力測試當中,顯卡需要超高97%才能夠算合格,證明顯卡的穩定性是過關的。 1、一般的默認情況下在2500~3000分就算很正常的了。 2、分數越高說明顯卡 ......

    軟件教程 2023-06-01
  • 文件被win10系統誤報病毒自動刪除了如何進行恢復?有用戶下載了某些破解軟件卻被Win10系統誤認為是病毒文件而自動刪除,當然系統自帶殺毒軟件其實挺不錯的,就是有時候會誤報,大家遇到這種情況的時候就希望把誤刪的...

    windows10 2022-11-20
  • win11系統如何釋放掉系統默認保留的存儲空間?一般情況下,Windows會保留一些存儲空間,以便設備獲得良好性能和成功更新。但是當出現系統盤儲存空間不足時,我們會將幾個G的保留空間釋放出來,以解燃眉之急。本期教...

    windows11 2022-11-17
  •   文/黎明  一場針對中國互聯網巨頭的反壟斷風暴正在醞釀,而且這次動真格了。  11月10日,國家市場監管總局發布《關于平臺經濟領域的反壟斷指南(征求意見稿)》,要加大對互聯網巨頭涉嫌壟斷的調查和監管。 ...

    熱議 2020-11-14
  • 我們經常用WPS的時候,如果需要輸入波浪號~,會發現鍵盤上的波浪號輸入之后在最上面,但是為了美觀,我們希望波浪號顯示在中間。這里總結了三個方法分享給大家 ......

    WPS教程 2023-02-18
  • 答:不一樣。 字類不同、數量不同、使用也不同。 1、字類不同 仿宋gb2312只包含符合GB2312標準的簡體字,仿宋包含所有的簡體字,包括特殊的繁體字。 2、版本不 ......

    軟件教程 2023-02-17
  • 1、下載番茄作家助手,登錄你自己的賬號進入。2、在首頁這里可以看到你創建的書籍,或者新建一個小說,點擊這個黃色的編輯圖標。3、進入以后,再點擊“創建章節 ......

    軟件教程 2023-03-16
  • 答:中高端水平 i513500hx在處理器當中是處于一個中高端的水平。 i513500hx是第十一代酷睿處理器系列的一員,基礎頻率為2.4GHz,表現十分的不錯。 i513500hx介 ......

    硬件知識 2023-04-27
  • 羅技g304dpi燈顏色代表什么:1、藍色:這種情況是正常工作的顯示,如果說是常亮或者閃爍,那都沒有問題這是在正常工作呢。2、紅色:如果說是紅燈閃爍的話那就是 ......

    硬件知識 2023-03-16
  • 打開軟件,直接填寫就可以。 1、下載安裝easyconnect軟件, 2、打開easyconnect應用,在如圖所示的“服務器地址”一欄輸入如圖所示網址,點擊“連接”, 3、等 ......

    軟件教程 2023-04-03

熱門排行

    最近更新

      返回頂部
      亚洲国产精品人久久,亚洲va国产日韩欧美精品色婷婷,久久久久88色偷偷,免费人成黄页在线观看国际
      成人爽a毛片一区二区免费| 久久国产夜色精品鲁鲁99| 欧美精三区欧美精三区| 成人av电影免费在线播放| 欧美日韩高清在线播放| 337p日本欧洲亚洲大胆色噜噜| 最新不卡av在线| 亚洲午夜电影网| 色婷婷综合久色| 欧美一区二区三区四区在线观看| 人人超碰91尤物精品国产| 在线一区二区三区四区| 国产精品天天看| 国产成人综合精品三级| 国产日韩欧美高清| 国产精品羞羞答答xxdd| 精品国产乱码久久久久久浪潮| 婷婷成人激情在线网| 欧美男生操女生| 午夜精品福利一区二区三区蜜桃| 99热这里都是精品| 亚洲一区二区三区四区在线观看| 91欧美激情一区二区三区成人| 国产精品日产欧美久久久久| 91一区在线观看| 久久成人免费日本黄色| 日韩欧美在线影院| 成人国产精品免费网站| 亚洲欧美激情插 | 欧美剧在线免费观看网站| 奇米色777欧美一区二区| 日本一区二区三区在线不卡| 欧美成va人片在线观看| 日韩丝袜美女视频| 91麻豆精品久久久久蜜臀| 一本大道av伊人久久综合| 久久精品二区亚洲w码| 免费一区二区视频| 国产一区二区久久| 丰满亚洲少妇av| 成人免费高清在线| 99久久久久久99| 国产精品久久久久久福利一牛影视| 中文字幕亚洲电影| 欧美大片顶级少妇| 91免费观看在线| 国内精品视频666| 狠狠网亚洲精品| 一区二区三区四区高清精品免费观看 | 中文字幕欧美激情| 中文子幕无线码一区tr| www成人在线观看| 欧美国产欧美综合| 亚洲精品国产无天堂网2021| ...xxx性欧美| 麻豆极品一区二区三区| 国产福利视频一区二区三区| 91网站在线播放| 一本在线高清不卡dvd| 成人涩涩免费视频| 99久久精品费精品国产一区二区| 精品在线播放免费| 91小视频免费看| 欧美精品精品一区| 亚洲国产毛片aaaaa无费看| 国产永久精品大片wwwapp| 成人黄色777网| 精品久久久久久久久久久久久久久 | 在线免费观看视频一区| 26uuu久久天堂性欧美| 亚洲免费av高清| 色哟哟国产精品免费观看| 日韩一区二区高清| 午夜久久久影院| 在线中文字幕不卡| 三级欧美在线一区| 久久影院视频免费| 欧美性xxxxx极品少妇| 日本不卡在线视频| 色av成人天堂桃色av| 亚洲精品成人少妇| 欧美精品视频www在线观看| 日韩精品电影在线| 久久久亚洲国产美女国产盗摄| 国产美女视频一区| 一区二区三区四区精品在线视频| 色欧美片视频在线观看| 国产精品入口麻豆九色| 日韩一级视频免费观看在线| 国产激情一区二区三区四区| 亚洲黄色录像片| 精品久久久久久亚洲综合网| 欧美日韩精品免费观看视频| 国产成人av自拍| 亚洲人成亚洲人成在线观看图片| 欧美日韩成人一区| 99国产精品久久久久| 久久精品国产精品青草| 亚洲国产日韩综合久久精品| 久久久777精品电影网影网| 欧美成人精品高清在线播放| 在线精品视频一区二区三四| 成人app在线观看| eeuss鲁片一区二区三区| 精品一区二区三区影院在线午夜| 激情六月婷婷综合| 国产一区福利在线| 狠狠色丁香久久婷婷综合_中| 免费看黄色91| 男男gaygay亚洲| 麻豆精品一区二区三区| 一区二区三区在线不卡| 亚洲欧美日韩人成在线播放| 亚洲免费大片在线观看| 亚洲免费观看高清完整版在线| 国产传媒日韩欧美成人| 91一区在线观看| 93久久精品日日躁夜夜躁欧美| 午夜精品成人在线| 青青草91视频| 久久99精品国产.久久久久久| 欧美成人vps| caoporen国产精品视频| 国产精品一区二区久久不卡| 久久成人综合网| 国产乱子轮精品视频| 成人爽a毛片一区二区免费| 欧美体内she精视频| 中文字幕国产一区二区| 蜜桃精品在线观看| 日韩一级片网站| 免费观看日韩电影| 日本欧美大码aⅴ在线播放| 亚洲在线中文字幕| 奇米精品一区二区三区四区| 欧美三区在线视频| 中文字幕一区不卡| 国产精品羞羞答答xxdd| 国产精品麻豆欧美日韩ww| 国产91清纯白嫩初高中在线观看| 一本色道久久综合亚洲91| 精品国产一区二区三区四区四| 亚洲久本草在线中文字幕| 成人综合激情网| 国产精品狼人久久影院观看方式| 高清不卡在线观看av| 国产免费观看久久| 日本黄色一区二区| 欧美96一区二区免费视频| 亚洲天堂免费看| 欧美伊人久久久久久久久影院 | 欧美日韩在线播| 亚洲男人电影天堂| 国产欧美日本一区视频| 91亚洲大成网污www| 天天做天天摸天天爽国产一区| 高清久久久久久| 欧美经典一区二区| 色噜噜狠狠色综合中国| 国产精品亚洲第一区在线暖暖韩国 | 亚洲欧美日韩综合aⅴ视频| 精品国产三级电影在线观看| 91福利资源站| 在线观看日韩国产| 亚洲成人动漫一区| 一区二区三区欧美激情| 国产精品美女视频| 国产日韩欧美亚洲| 久久久另类综合| 亚洲国产精品国自产拍av| 欧美韩国日本综合| 久久久一区二区| 亚洲午夜成aⅴ人片| 99久久精品免费看| 欧美日韩一区二区欧美激情| 91福利视频网站| 欧美成人一区二区三区在线观看| 欧美老女人第四色| 日韩欧美国产成人一区二区| 国产欧美日韩卡一| 日韩专区欧美专区| 国产精品中文字幕日韩精品| 99久久精品99国产精品| 在线区一区二视频| 欧美国产一区视频在线观看| 香蕉久久一区二区不卡无毒影院| 日本美女视频一区二区| 高清成人免费视频| 日韩精品一区二区三区视频在线观看 | 日本vs亚洲vs韩国一区三区二区 | 亚洲精品久久嫩草网站秘色| 麻豆精品一区二区三区| av在线播放不卡| 国产人伦精品一区二区| 久久精品久久99精品久久| 国产盗摄一区二区三区| 色噜噜狠狠成人中文综合| 成人免费一区二区三区视频 | 国产精品毛片无遮挡高清| 成人免费高清在线观看|