青草久久影院-青草久久伊人-青草久久久-青草久久精品亚洲综合专区-SM双性精跪趴灌憋尿调教H-SM脚奴调教丨踩踏贱奴

17站長(zhǎng)網(wǎng)

Tomcat 類加載器的實(shí)現(xiàn)方法及實(shí)例代碼

2022-10-6 09:28| 查看: 1380 |來源: 互聯(lián)網(wǎng)

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

Tomcat 內(nèi)部定義了多個(gè) ClassLoader,以便應(yīng)用和容器訪問不同存儲(chǔ)庫中的類和資源,同時(shí)達(dá)到應(yīng)用間類隔離的目的。

1. Java 類加載機(jī)制

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

類加載器之所以能實(shí)現(xiàn)類隔離,是因?yàn)閮蓚(gè)類相等的前提是它們由同一個(gè)類加載器加載,否則必定不相等。

JVM 在加載時(shí),采用的是一種雙親委托機(jī)制,當(dāng)類加載器要加載一個(gè)類時(shí),加載順序是:

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

這個(gè)機(jī)制的好處就是能夠保證核心類庫不被覆蓋。

而按照 Servlet 規(guī)范的建議,Webapp 加載器略有不同,它首先會(huì)在自己的資源庫中搜索,而不是向上委托,打破了標(biāo)準(zhǔn)的委托機(jī)制,來看下 Tomcat 的設(shè)計(jì)和實(shí)現(xiàn)。

2. Tomcat 類加載器設(shè)計(jì)

Tomcat 整體類加載器結(jié)構(gòu)如下:

其中 JDK 內(nèi)部提供的類加載器分別是:

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

Tomcat 自定義實(shí)現(xiàn)的類加載器分別是:

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

在實(shí)現(xiàn)時(shí),上圖不是繼承關(guān)系,而是通過組合體現(xiàn)父子關(guān)系。Tomcat 類加載器的源碼類圖:

Common、Catalina 、Shared 它們都是 StandardClassLoader 的實(shí)例,在默認(rèn)情況下,它們引用的是同一個(gè)對(duì)象。其中 StandardClassLoader 與 URLClassLoader 沒有區(qū)別;WebappClassLoader 則按規(guī)范實(shí)現(xiàn)以下順序的查找并加載:

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

接下來看下源碼實(shí)現(xiàn)。

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(); } // 指定倉(cāng)庫路徑配置文件前綴和父加載器,創(chuàng)建 ClassLoader 實(shí)例 catalinaLoader = createClassLoader("server", commonLoader); sharedLoader = createClassLoader("shared", commonLoader); } catch (Throwable t) { log.error("Class loader creation threw exception", t); System.exit(1); } }

可以看到分別創(chuàng)建了三個(gè)類加載器,createClassLoader 就是根據(jù)配置獲取資源倉(cāng)庫地址,最后返回一個(gè) StandardClassLoader 實(shí)例,核心代碼如下:

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(); ... // 獲取資源倉(cāng)庫路徑 String[] locations = (String[]) repositoryLocations.toArray(new String[0]); Integer[] types = (Integer[]) repositoryTypes.toArray(new Integer[0]); // 創(chuàng)建一個(gè) StandardClassLoader 對(duì)象 ClassLoader classLoader = ClassLoaderFactory.createClassLoader (locations, types, parent); ... return classLoader; }

類加載器初始化完畢后,會(huì)創(chuàng)建一個(gè) Catalina 對(duì)象,最終會(huì)調(diào)用它的 load 方法,解析 server.xml 初始化容器內(nèi)部組件。那么容器,比如 Engine,又是怎么關(guān)聯(lián)到這個(gè)設(shè)置的父加載器的呢?

Catalina 對(duì)象有一個(gè) parentClassLoader 成員變量,它是所有組件的父加載器,默認(rèn)是 AppClassLoader,在此對(duì)象創(chuàng)建完畢時(shí),會(huì)反射調(diào)用它的 setParentClassLoader 方法,將父加載器設(shè)為 sharedLoader。

而 Tomcat 內(nèi)部頂級(jí)容器 Engine 在初始化時(shí),Digester 有一個(gè) SetParentClassLoaderRule 規(guī)則,會(huì)將 Catalina 的 parentClassLoader 通過 Engine.setParentClassLoader 方法關(guān)聯(lián)起來。

4. 如何打破雙親委托機(jī)制

答案是使用 Thread.getContextClassLoader() - 當(dāng)前線程的上下文加載器,該加載器可通過 Thread.setContextClassLoader() 在代碼運(yùn)行時(shí)動(dòng)態(tài)設(shè)置。

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

Tomcat 就是在 StandardContext 啟動(dòng)時(shí)首先初始化一個(gè) WebappClassLoader 然后設(shè)置為當(dāng)前線程的上下文加載器,最后將其封裝為 Loader 對(duì)象,借助容器之間的父子關(guān)系,在加載 Servlet 類時(shí)使用。

5. Web 應(yīng)用的類加載

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

在防止覆蓋 J2SE

public synchronized Class loadClass(String name, boolean resolve) throws ClassNotFoundException { ... Class clazz = null; // (0) 檢查自身內(nèi)部緩存中是否已經(jīng)加載 clazz = findLoadedClass0(name); if (clazz != null) { if (log.isDebugEnabled()) log.debug(" Returning class from cache"); if (resolve) resolveClass(clazz); return (clazz); } // (0.1) 檢查 JVM 的緩存中是否已經(jīng)加載 clazz = findLoadedClass(name); if (clazz != null) { if (log.isDebugEnabled()) log.debug(" Returning class from cache"); if (resolve) resolveClass(clazz); return (clazz); } // (0.2) 嘗試使用系統(tǒng)類加載加載,防止覆蓋 J2SE 類 try { clazz = system.loadClass(name); if (clazz != null) { if (resolve) resolveClass(clazz); return (clazz); } } catch (ClassNotFoundException e) {// Ignore} // (0.5) 使用 SecurityManager 檢查是否有此類的訪問權(quán)限 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) 是否委托給父類,這里默認(rèn)為 false if (delegateLoad) { ... } // (2) 嘗試查找自己的存儲(chǔ)庫并加載 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) 如果此時(shí)還加載失敗,那么將加載請(qǐng)求委托給父加載器 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 類的時(shí)候,版本 Tomcat 6,使用的是 AppClassLoader,rt.jar 核心類庫是由 Bootstrap Classloader 加載的,但是在 Java 代碼是獲取不了這個(gè)加載器的,在高版本做了以下優(yōu)化: ClassLoader j = String.class.getClassLoader(); if (j == null) { j = getSystemClassLoader(); while (j.getParent() != null) { j = j.getParent(); } } this.javaseClassLoader = j;

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

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

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

6. 小結(jié)

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

本文最后更新于 2022-10-6 09:28,某些文章具有時(shí)效性,若有錯(cuò)誤或已失效,請(qǐng)?jiān)诰W(wǎng)站留言或聯(lián)系站長(zhǎng):17tui@17tui.com
·END·
站長(zhǎng)網(wǎng)微信號(hào):w17tui,關(guān)注站長(zhǎng)、創(chuàng)業(yè)、關(guān)注互聯(lián)網(wǎng)人 - 互聯(lián)網(wǎng)創(chuàng)業(yè)者營(yíng)銷服務(wù)中心

免責(zé)聲明:本站部分文章和圖片均來自用戶投稿和網(wǎng)絡(luò)收集,旨在傳播知識(shí),文章和圖片版權(quán)歸原作者及原出處所有,僅供學(xué)習(xí)與參考,請(qǐng)勿用于商業(yè)用途,如果損害了您的權(quán)利,請(qǐng)聯(lián)系我們及時(shí)修正或刪除。謝謝!

17站長(zhǎng)網(wǎng)微信二維碼

始終以前瞻性的眼光聚焦站長(zhǎng)、創(chuàng)業(yè)、互聯(lián)網(wǎng)等領(lǐng)域,為您提供最新最全的互聯(lián)網(wǎng)資訊,幫助站長(zhǎng)轉(zhuǎn)型升級(jí),為互聯(lián)網(wǎng)創(chuàng)業(yè)者提供更加優(yōu)質(zhì)的創(chuàng)業(yè)信息和品牌營(yíng)銷服務(wù),與站長(zhǎng)一起進(jìn)步!讓互聯(lián)網(wǎng)創(chuàng)業(yè)者不再孤獨(dú)!

掃一掃,關(guān)注站長(zhǎng)網(wǎng)微信

大家都在看

  • 當(dāng)我們?cè)诠蚕砭W(wǎng)絡(luò)訪問的時(shí)候,可能會(huì)遇到提示指定的網(wǎng)絡(luò)名不再可用的問題,這可能是由于我們的共享網(wǎng)絡(luò)出現(xiàn)了錯(cuò)誤,也可能是被共享的對(duì)象所拒絕了。指定的網(wǎng)絡(luò)名 ......

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

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

    站長(zhǎng) 2020-12-09
  • 一、軟件沖突1、首先確認(rèn)是否是應(yīng)用程序沖突導(dǎo)致的。2、查看是否只有特定幾個(gè)游戲或應(yīng)用會(huì)導(dǎo)致該問題。3、如果是應(yīng)用沖突,那么只要卸載這些app就可以解決了。二 ......

    軟件教程 2022-12-27
  • 圖片來源于簡(jiǎn)書  文/郭開森 楊帆  陸玖財(cái)經(jīng)準(zhǔn)備開新欄目了,每周一創(chuàng)始人郭開森和楊帆合體郭德帆,對(duì)行業(yè)進(jìn)行一些觀察和評(píng)論,第一篇我們?nèi)允谴蛩銓懮鐓^(qū)團(tuán)購(gòu),這是當(dāng)下最火的話題! 磉^陸玖財(cái)經(jīng)做客的朋友們...

    熱議 2020-12-07
  • 電腦端:1、大家可以點(diǎn)擊右邊鏈接進(jìn)入網(wǎng)頁版的百度網(wǎng)盤,進(jìn)入之后點(diǎn)擊“去登錄”。https://pan.baidu.com/2、之后正確的輸入賬號(hào)密碼進(jìn)行登錄就好啦。手機(jī)端:1 ......

    軟件教程 2022-12-27
  • 一、N100對(duì)比intel i3 1、N100的跑分達(dá)到了147210分,這個(gè)數(shù)據(jù)可以達(dá)到i3的七代級(jí)別。 2、在跑分上也是超越了大部分的I3七代CPU,不過比I3八代要弱勢(shì)一些。 3 ......

    硬件知識(shí) 2023-04-26
  • 8月15日消息 上周,有媒體報(bào)道前身為百度圖片的“榴蓮”APP含有大量不雅視頻內(nèi)容被用戶舉報(bào)。對(duì)此,百度圖片官方進(jìn)行了回應(yīng),百度圖片表示已經(jīng)對(duì)報(bào)道中所涉及的“生吃旋風(fēng)哥”等爭(zhēng)議內(nèi)容進(jìn)行了下線處理。 此外,百度...

    站長(zhǎng) 2016-08-15
  • 在填寫一些項(xiàng)目申請(qǐng)書中,總是免不了要選擇一些數(shù)字,但是在方框中如何插入數(shù)字,該怎么辦呢?那么下面就由學(xué)習(xí)啦小編給大家分享下word在方框里輸入數(shù)字的技巧, ......

    Word教程 2023-04-27
  • WPS Office手機(jī)版怎么加橫線?很多用戶還不知道WPS Office手機(jī)版怎么加橫線,WPS Office手機(jī)版怎么加橫線,WPS Office手機(jī)版怎么打橫線,WPS Office手機(jī)版怎么弄 ......

    WPS教程 2023-03-31
  • 迅雷前綴是什么 答:迅雷前綴是(magnet:?xt=urn:btih:)括號(hào)里的就是了。 我們只要在這段文字之后輸入后續(xù)的內(nèi)容,就可以創(chuàng)建下載鏈接了。 1、磁力鏈接不基于文 ......

    軟件教程 2023-06-03
  • 一、內(nèi)容特權(quán)。 1、半價(jià)點(diǎn)播。 許多站內(nèi)視頻都需要付費(fèi)觀看,而大會(huì)員用戶可以直接半價(jià)享受; 購(gòu)買成功后的48h內(nèi)無限次觀看。有部分的內(nèi)容是只限在中國(guó)大陸內(nèi)觀 ......

    軟件教程 2023-05-05
  • 1、首先打開小米運(yùn)動(dòng)的“實(shí)驗(yàn)室功能”。 2、接著點(diǎn)擊“門卡模擬”。 3、然后點(diǎn)擊“我知道了”。 4、最后貼近就可以刷卡成功了。...

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

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

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

    windows11 2022-12-13
  • 可見單元格就是不包括隱藏或者篩選篩選后隱藏起來的單元格區(qū)域。方法:篩選或隱藏?cái)?shù)據(jù),復(fù)制需要粘貼的值,在目標(biāo)單元格區(qū)域左上角的第一個(gè)單元格處右擊,選擇【 ......

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

    硬件知識(shí) 2023-04-06
  •   文/黎明  一場(chǎng)針對(duì)中國(guó)互聯(lián)網(wǎng)巨頭的反壟斷風(fēng)暴正在醞釀,而且這次動(dòng)真格了! 11月10日,國(guó)家市場(chǎng)監(jiān)管總局發(fā)布《關(guān)于平臺(tái)經(jīng)濟(jì)領(lǐng)域的反壟斷指南(征求意見稿)》,要加大對(duì)互聯(lián)網(wǎng)巨頭涉嫌壟斷的調(diào)查和監(jiān)管。 ...

    熱議 2020-11-14
  • 文件被win10系統(tǒng)誤報(bào)病毒自動(dòng)刪除了如何進(jìn)行恢復(fù)?有用戶下載了某些破解軟件卻被Win10系統(tǒng)誤認(rèn)為是病毒文件而自動(dòng)刪除,當(dāng)然系統(tǒng)自帶殺毒軟件其實(shí)挺不錯(cuò)的,就是有時(shí)候會(huì)誤報(bào),大家遇到這種情況的時(shí)候就希望把誤刪的...

    windows10 2022-11-20
  • win11系統(tǒng)如何釋放掉系統(tǒng)默認(rèn)保留的存儲(chǔ)空間?一般情況下,Windows會(huì)保留一些存儲(chǔ)空間,以便設(shè)備獲得良好性能和成功更新。但是當(dāng)出現(xiàn)系統(tǒng)盤儲(chǔ)存空間不足時(shí),我們會(huì)將幾個(gè)G的保留空間釋放出來,以解燃眉之急。本期教...

    windows11 2022-11-17
  • 1、先打開機(jī)頂盒進(jìn)入主界面,并且使用遙控器打開設(shè)置。 2、然后選擇“賬號(hào)與安全”,并且進(jìn)入。 3、最后往下面翻就可以看到“ADB調(diào)試”的選項(xiàng),直接開啟就行了 ......

    軟件教程 2023-06-01
  • 答:在3DMark壓力測(cè)試當(dāng)中,顯卡需要超高97%才能夠算合格,證明顯卡的穩(wěn)定性是過關(guān)的。 1、一般的默認(rèn)情況下在2500~3000分就算很正常的了。 2、分?jǐn)?shù)越高說明顯卡 ......

    軟件教程 2023-06-01
  • 羅技g304dpi燈顏色代表什么:1、藍(lán)色:這種情況是正常工作的顯示,如果說是常亮或者閃爍,那都沒有問題這是在正常工作呢。2、紅色:如果說是紅燈閃爍的話那就是 ......

    硬件知識(shí) 2023-03-16
  • 我們經(jīng)常用WPS的時(shí)候,如果需要輸入波浪號(hào)~,會(huì)發(fā)現(xiàn)鍵盤上的波浪號(hào)輸入之后在最上面,但是為了美觀,我們希望波浪號(hào)顯示在中間。這里總結(jié)了三個(gè)方法分享給大家 ......

    WPS教程 2023-02-18
  • win11系統(tǒng)快速跳過聯(lián)網(wǎng)創(chuàng)建本地管理賬戶3種方法?現(xiàn)在市面上銷售的品牌筆記本和臺(tái)式機(jī)基本上都預(yù)裝Windows11家庭中文版正版操作系統(tǒng),聯(lián)網(wǎng)后系統(tǒng)會(huì)自動(dòng)激活。當(dāng)用戶拿到新機(jī)器后還需要按照cortana(小娜)的提示一步...

    windows11 2022-11-13
  • 答:中高端水平 i513500hx在處理器當(dāng)中是處于一個(gè)中高端的水平。 i513500hx是第十一代酷睿處理器系列的一員,基礎(chǔ)頻率為2.4GHz,表現(xiàn)十分的不錯(cuò)。 i513500hx介 ......

    硬件知識(shí) 2023-04-27
  • 打開軟件,直接填寫就可以。 1、下載安裝easyconnect軟件, 2、打開easyconnect應(yīng)用,在如圖所示的“服務(wù)器地址”一欄輸入如圖所示網(wǎng)址,點(diǎn)擊“連接”, 3、等 ......

    軟件教程 2023-04-03
  • 相信有非常多使用過筆記本的用戶都聽說過獨(dú)顯直連這個(gè)詞,但很多用戶并不了解獨(dú)顯直連是什么,又有什么用處,那么下面就和小編一起來看看什么是獨(dú)顯直連和開啟這 ......

    其它 2022-12-15
  • win11系統(tǒng)開機(jī)總是自動(dòng)登錄OneDrive如何關(guān)閉?win11系統(tǒng)開機(jī)的時(shí)候,會(huì)自動(dòng)啟動(dòng)OneDrive,不想要啟動(dòng),該怎么操作呢?下面我們就來看看詳細(xì)的教程。 在OneDrive界面點(diǎn)小齒輪按鈕,下拉菜單中點(diǎn)【設(shè)置】。 單擊【...

    windows11 2022-11-15

熱門排行

    最近更新

      返回頂部
      主站蜘蛛池模板: 永久免费毛片 | 别停好爽好深好大好舒服视频 | 色偷偷超碰97人人澡人人 | 富婆找黑人老外泻火在线播放 | 日日天干夜夜狠狠爱 | 国产毛片A级久久久不卡精品 | 好爽好深太大了再快一点 | 成人国产在线看不卡 | 俄罗斯XX性幻女18 | 伊人国产在线观看 | 精品视频中文字幕 | 国产精品久久久久a影院 | 欧美兽交YOYO | 久久亚洲这里只有精品18 | 久久AV国产麻豆HD真实 | 日本不卡三卡四卡 | 无码AV精品久久一区二区免费 | 久久人妻熟女中文字幕AV蜜芽 | 亚洲 欧美 国产 综合五月天 | 美女裸露100%奶头视频 | 激情内射亚州一区二区三区爱妻 | 美女被日出水 | 色AV色婷婷97人妻久久久 | 国产成人女人在线视频观看 | 一区二区三区四区国产 | 福利免费观看体检区 | 国产精品成人免费视频99 | 国产精品免费大片一区二区 | 国产一级做a爰片久久毛片男 | 国产真实女人一级毛片 | 99精品视频 | 国产精品网红女主播久久久 | 久久精品国产在热亚洲完整版 | 少妇伦子伦精品无码 | 亚洲精品色婷婷在线蜜芽 | 午夜性爽视频男人的天堂在线 | 男女床上黄色 | 四虎永久在线精品国产 | chinese野外男女free | 亚洲久热无码中文字幕 | 国产成人精品综合在线观看 |