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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

SpringMVC深度探险(三) —— DispatcherServlet与初始化主线

發(fā)布時(shí)間:2025/5/22 javascript 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SpringMVC深度探险(三) —— DispatcherServlet与初始化主线 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

本文是專欄文章(SpringMVC深度探險(xiǎn))系列的文章之一,博客地址為:http://downpour.iteye.com/blog/1341459

在上一篇文章中,我們給出了構(gòu)成SpringMVC應(yīng)用程序的三要素以及三要素的設(shè)計(jì)過程。讓我們來歸納一下整個(gè)設(shè)計(jì)過程中的一些要點(diǎn):

  • SpringMVC將Http處理流程抽象為一個(gè)又一個(gè)處理單元
  • SpringMVC定義了一系列組件(接口)與所有的處理單元對應(yīng)起來
  • SpringMVC由DispatcherServlet貫穿始終,并將所有的組件串聯(lián)起來

在整個(gè)過程中,組件和DispatcherServlet總是維持著一個(gè)相互支撐的關(guān)系:

  • DispatcherServlet —— 串聯(lián)起整個(gè)邏輯主線,是整個(gè)框架的心臟
  • 組件 —— 邏輯處理單元的程序化表示,起到承上啟下的作用,是SpringMVC行為模式的實(shí)際承載者

在本系列接下來的兩篇文章中,我們將分別討論DispatcherServlet和組件的相關(guān)內(nèi)容。本文討論DispatcherServlet,而下一篇?jiǎng)t重點(diǎn)分析組件。

有關(guān)DispatcherServlet,我們想從構(gòu)成DispatcherServlet的體系結(jié)構(gòu)入手,再根據(jù)不同的邏輯主線分別加以分析,希望能夠幫助讀者整理出學(xué)習(xí)SpringMVC核心類的思路。

DispatcherServlet的體系結(jié)構(gòu)

通過不同的角度來觀察DispatcherServlet會(huì)得到不同的結(jié)論。我們在這里選取了三個(gè)不同的角度:運(yùn)行特性、繼承結(jié)構(gòu)和數(shù)據(jù)結(jié)構(gòu)。

【運(yùn)行主線】

從DispatcherServlet所實(shí)現(xiàn)的接口來看,DispatcherServlet的核心本質(zhì):是一個(gè)Servlet。這個(gè)結(jié)論似乎很幼稚,不過這個(gè)幼稚的結(jié)論卻蘊(yùn)含了一個(gè)對整個(gè)框架都至關(guān)重要的內(nèi)在原則:Servlet可以根據(jù)其特性進(jìn)行運(yùn)行主線的劃分

根據(jù)Servlet規(guī)范的定義,Servlet中的兩大核心方法init方法和service方法,它們的運(yùn)行時(shí)間和觸發(fā)條件都截然不同:

1. init方法

在整個(gè)系統(tǒng)啟動(dòng)時(shí)運(yùn)行,且只運(yùn)行一次。因此,在init方法中我們往往會(huì)對整個(gè)應(yīng)用程序進(jìn)行初始化操作。這些初始化操作可能包括對容器(WebApplicationContext)的初始化、組件和外部資源的初始化等等。

2. service方法

在整個(gè)系統(tǒng)運(yùn)行的過程中處于偵聽模式,偵聽并處理所有的Web請求。因此,在service及其相關(guān)方法中,我們看到的則是對Http請求的處理流程。

因而在這里,Servlet的這一特性就被SpringMVC用于對不同的邏輯職責(zé)加以劃分,從而形成兩條互不相關(guān)的邏輯運(yùn)行主線:

  • 初始化主線 —— 負(fù)責(zé)對SpringMVC的運(yùn)行要素進(jìn)行初始化
  • Http請求處理主線 —— 負(fù)責(zé)對SpringMVC中的組件進(jìn)行邏輯調(diào)度完成對Http請求的處理

對于一個(gè)MVC框架而言,運(yùn)行主線的劃分非常重要。因?yàn)橹挥信宄煌倪\(yùn)行主線,我們才能針對不同的運(yùn)行主線采取不同的研究策略。而我們在這個(gè)系列中的絕大多數(shù)分析的切入點(diǎn),也是圍繞著不同的運(yùn)行主線進(jìn)行的。

:SpringMVC運(yùn)行主線的劃分依據(jù)是Servlet對象中不同方法的生命周期。事實(shí)上,幾乎所有的MVC都是以此為依據(jù)來進(jìn)行運(yùn)行主線的劃分。這進(jìn)一步可以證明所有的MVC框架的核心基礎(chǔ)還是Servlet規(guī)范,而設(shè)計(jì)理念的差異也導(dǎo)致了不同的框架走向了完全不同的發(fā)展道路。

【繼承結(jié)構(gòu)】

除了運(yùn)行主線的劃分以外,我們再關(guān)注一下DispatcherServlet的繼承結(jié)構(gòu):



在這個(gè)繼承結(jié)構(gòu)中,我們可以看到DispatcherServlet在其繼承樹中包含了2個(gè)Spring的支持類:HttpServletBean和FrameworkServlet。我們分別來討論一下這兩個(gè)Spring的支持類在這里所起到的作用。

HttpServletBean是Spring對于Servlet最低層次的抽象。在這一層抽象中,Spring會(huì)將這個(gè)Servlet視作是一個(gè)Spring的bean,并將init-param中的值作為bean的屬性注入進(jìn)來:

Java代碼 ?

  • public?final?void?init()?throws?ServletException?{??
  • ????if?(logger.isDebugEnabled())?{??
  • ????????logger.debug("Initializing?servlet?'"?+?getServletName()?+?"'");??
  • ????}??
  • ??
  • ????//?Set?bean?properties?from?init?parameters.??
  • ????try?{??
  • ????????PropertyValues?pvs?=?new?ServletConfigPropertyValues(getServletConfig(),?this.requiredProperties);??
  • ????????BeanWrapper?bw?=?PropertyAccessorFactory.forBeanPropertyAccess(this);??
  • ????????ResourceLoader?resourceLoader?=?new?ServletContextResourceLoader(getServletContext());??
  • ????????bw.registerCustomEditor(Resource.class,?new?ResourceEditor(resourceLoader,?this.environment));??
  • ????????initBeanWrapper(bw);??
  • ????????bw.setPropertyValues(pvs,?true);??
  • ????}??
  • ????catch?(BeansException?ex)?{??
  • ????????logger.error("Failed?to?set?bean?properties?on?servlet?'"?+?getServletName()?+?"'",?ex);??
  • ????????throw?ex;??
  • ????}??
  • ??
  • ????//?Let?subclasses?do?whatever?initialization?they?like.??
  • ????initServletBean();??
  • ??
  • ????if?(logger.isDebugEnabled())?{??
  • ????????logger.debug("Servlet?'"?+?getServletName()?+?"'?configured?successfully");??
  • ????}??
  • }??
  • public final void init() throws ServletException {

    ????if (logger.isDebugEnabled()) {

    ????????logger.debug("Initializing servlet '" + getServletName() + "'");

    ????}

    ?

    ????// Set bean properties from init parameters.

    ????try {

    ????????PropertyValues pvs = new ServletConfigPropertyValues(getServletConfig(), this.requiredProperties);

    ????????BeanWrapper bw = PropertyAccessorFactory.forBeanPropertyAccess(this);

    ????????ResourceLoader resourceLoader = new ServletContextResourceLoader(getServletContext());

    ????????bw.registerCustomEditor(Resource.class, new ResourceEditor(resourceLoader, this.environment));

    ????????initBeanWrapper(bw);

    ????????bw.setPropertyValues(pvs, true);

    ????}

    ????catch (BeansException ex) {

    ????????logger.error("Failed to set bean properties on servlet '" + getServletName() + "'", ex);

    ????????throw ex;

    ????}

    ?

    ????// Let subclasses do whatever initialization they like.

    ????initServletBean();

    ?

    ????if (logger.isDebugEnabled()) {

    ????????logger.debug("Servlet '" + getServletName() + "' configured successfully");

    ????}

    }



    從源碼中,我們可以看到HttpServletBean利用了Servlet的init方法的執(zhí)行特性,將一個(gè)普通的Servlet與Spring的容器聯(lián)系在了一起。在這其中起到核心作用的代碼是:BeanWrapper bw = PropertyAccessorFactory.forBeanPropertyAccess(this);將當(dāng)前的這個(gè)Servlet類轉(zhuǎn)化為一個(gè)BeanWrapper,從而能夠以Spring的方式來對init-param的值進(jìn)行注入。BeanWrapper的相關(guān)知識屬于Spring Framework的內(nèi)容,我們在這里不做詳細(xì)展開,讀者可以具體參考HttpServletBean的注釋獲得更多的信息。

    FrameworkServlet則是在HttpServletBean的基礎(chǔ)之上的進(jìn)一步抽象。通過FrameworkServlet真正初始化了一個(gè)Spring的容器(WebApplicationContext),并引入到Servlet對象之中:

    Java代碼 ?

  • protected?final?void?initServletBean()?throws?ServletException?{??
  • ????getServletContext().log("Initializing?Spring?FrameworkServlet?'"?+?getServletName()?+?"'");??
  • ????if?(this.logger.isInfoEnabled())?{??
  • ????????this.logger.info("FrameworkServlet?'"?+?getServletName()?+?"':?initialization?started");??
  • ????}??
  • ????long?startTime?=?System.currentTimeMillis();??
  • ??
  • ????try?{??
  • ????????this.webApplicationContext?=?initWebApplicationContext();??
  • ????????initFrameworkServlet();??
  • ????}?catch?(ServletException?ex)?{??
  • ????????this.logger.error("Context?initialization?failed",?ex);??
  • ????????throw?ex;??
  • ????}?catch?(RuntimeException?ex)?{??
  • ????????this.logger.error("Context?initialization?failed",?ex);??
  • ????????throw?ex;??
  • ????}??
  • ??
  • ????if?(this.logger.isInfoEnabled())?{??
  • ????????long?elapsedTime?=?System.currentTimeMillis()?-?startTime;??
  • ????????this.logger.info("FrameworkServlet?'"?+?getServletName()?+?"':?initialization?completed?in?"?+??
  • ????????????????elapsedTime?+?"?ms");??
  • ????}??
  • }??
  • protected final void initServletBean() throws ServletException {

    ????getServletContext().log("Initializing Spring FrameworkServlet '" + getServletName() + "'");

    ????if (this.logger.isInfoEnabled()) {

    ????????this.logger.info("FrameworkServlet '" + getServletName() + "': initialization started");

    ????}

    ????long startTime = System.currentTimeMillis();

    ?

    ????try {

    ????????this.webApplicationContext = initWebApplicationContext();

    ????????initFrameworkServlet();

    ????} catch (ServletException ex) {

    ????????this.logger.error("Context initialization failed", ex);

    ????????throw ex;

    ????} catch (RuntimeException ex) {

    ????????this.logger.error("Context initialization failed", ex);

    ????????throw ex;

    ????}

    ?

    ????if (this.logger.isInfoEnabled()) {

    ????????long elapsedTime = System.currentTimeMillis() - startTime;

    ????????this.logger.info("FrameworkServlet '" + getServletName() + "': initialization completed in " +

    ????????????????elapsedTime + " ms");

    ????}

    }



    上面的這段代碼就是FrameworkServlet初始化的核心代碼。從中我們可以看到這個(gè)FrameworkServlet將調(diào)用其內(nèi)部的方法initWebApplicationContext()對Spring的容器(WebApplicationContext)進(jìn)行初始化。同時(shí),FrameworkServlet還暴露了與之通訊的結(jié)構(gòu)可供子類調(diào)用:

    Java代碼 ?

  • public?abstract?class?FrameworkServlet?extends?HttpServletBean?{??
  • ??
  • ????/**?WebApplicationContext?for?this?servlet?*/??
  • ????private?WebApplicationContext?webApplicationContext;??
  • ??
  • ????????//?這里省略了其他所有的代碼??
  • ??
  • ????/**?
  • ?????*?Return?this?servlet's?WebApplicationContext.?
  • ?????*/??
  • ????public?final?WebApplicationContext?getWebApplicationContext()?{??
  • ????????return?this.webApplicationContext;??
  • ????}??
  • }??
  • public abstract class FrameworkServlet extends HttpServletBean {

    ?

    ????/** WebApplicationContext for this servlet */

    ????private WebApplicationContext webApplicationContext;

    ?

    // 這里省略了其他所有的代碼

    ?

    ????/**

    ???? * Return this servlet's WebApplicationContext.

    ???? */

    ????public final WebApplicationContext getWebApplicationContext() {

    ????????return this.webApplicationContext;

    ????}

    }



    我們在這里暫且不對Spring容器(WebApplicationContext)的初始化過程詳加探查,稍后我們會(huì)討論一些WebApplicationContext初始化過程中的配置選項(xiàng)。不過讀者可以在這里體會(huì)到:FrameworkServlet在其內(nèi)部初始化了一個(gè)Spring的容器(WebApplicationContext)并暴露了相關(guān)的操作接口,因而繼承自FrameworkServlet的DispatcherServlet,也就直接擁有了與WebApplicationContext進(jìn)行通信的能力。

    通過對DispatcherServlet繼承結(jié)構(gòu)的研究,我們可以明確:

    downpour 寫道

    結(jié)論 DispatcherServlet的繼承體系架起了DispatcherServlet與Spring容器進(jìn)行溝通的橋梁。



    【數(shù)據(jù)結(jié)構(gòu)】

    在上一篇文章中,我們曾經(jīng)提到過DispatcherServlet的數(shù)據(jù)結(jié)構(gòu):



    我們可以把在上面這張圖中所構(gòu)成DispatcherServlet的數(shù)據(jù)結(jié)構(gòu)主要分為兩類(我們在這里用一根分割線將其分割開來):

    • 配置參數(shù) —— 控制SpringMVC組件的初始化行為方式
    • 核心組件 —— SpringMVC的核心邏輯處理組件

    可以看到,這兩類數(shù)據(jù)結(jié)構(gòu)都與SpringMVC中的核心要素組件有關(guān)。因此,我們可以得出這樣一個(gè)結(jié)論:

    downpour 寫道

    結(jié)論 組件是整個(gè)DispatcherServlet的靈魂所在:它不僅是初始化主線中的初始化對象,同樣也是Http請求處理主線中的邏輯調(diào)度載體。



    :我們可以看到被我們劃為配置參數(shù)的那些變量都是boolean類型的,它們將在DispatcherServlet的初始化主線中起到一定的作用,我們在之后會(huì)使用源碼進(jìn)行說明。而這些boolean值可以通過web.xml中的init-param值進(jìn)行設(shè)定覆蓋(這是由HttpServletBean的特性帶來的)。

    SpringMVC的運(yùn)行體系

    DispatcherServlet繼承結(jié)構(gòu)和數(shù)據(jù)結(jié)構(gòu),實(shí)際上表述的是DispatcherServlet與另外兩大要素之間的關(guān)系:

    • 繼承結(jié)構(gòu) —— DispatcherServlet與Spring容器(WebApplicationContext)之間的關(guān)系
    • 數(shù)據(jù)結(jié)構(gòu) —— DispatcherServlet與組件之間的關(guān)系

    所以,其實(shí)我們可以這么說:SpringMVC的整個(gè)運(yùn)行體系,是由DispatcherServlet、組件和容器這三者共同構(gòu)成的。

    在這個(gè)運(yùn)行體系中,DispatcherServlet是邏輯處理的調(diào)度中心,組件則是被調(diào)度的操作對象。而容器在這里所起到的作用,是協(xié)助DispatcherServlet更好地對組件進(jìn)行管理。這就相當(dāng)于一個(gè)工廠招了一大批的工人,并把工人劃分到一個(gè)統(tǒng)一的工作車間而便于管理。在工廠要進(jìn)行生產(chǎn)活動(dòng)時(shí),只需要從工作車間把工人分派到相應(yīng)的生產(chǎn)流水線上即可。

    筆者在這里引用Spring官方reference中的一幅圖,對三者之間的關(guān)系進(jìn)行簡單的描述:



    :在這幅圖中,我們除了看到在圖的左半邊DispatcherServlet、組件和容器這三者之間的調(diào)用關(guān)系以外,還可以看到SpringMVC的運(yùn)行體系與其它運(yùn)行體系之間存在著關(guān)系。有關(guān)這一點(diǎn),我們在之后的討論中會(huì)詳細(xì)展開。

    既然是三個(gè)元素之間的關(guān)系表述,我們必須以兩兩關(guān)系的形式進(jìn)行歸納:

    • DispatcherServlet - 容器 —— DispatcherServlet對容器進(jìn)行初始化
    • 容器 - 組件 —— 容器對組件進(jìn)行全局管理
    • DispatcherServlet - 組件 —— DispatcherServlet對組件進(jìn)行邏輯調(diào)用

    值得注意的是,在上面這幅圖中,三大元素之間的兩兩關(guān)系其實(shí)表現(xiàn)得并不明顯,尤其是"容器 - 組件"和"DispatcherServlet - 組件"之間的關(guān)系。這主要是由于Spring官方reference所給出的這幅圖是一個(gè)靜態(tài)的關(guān)系表述,如果從動(dòng)態(tài)的觀點(diǎn)來對整個(gè)過程加以審視,我們就不得不將SpringMVC的運(yùn)行體系與之前所提到的運(yùn)行主線聯(lián)系在一起,看看這些元素在不同的邏輯主線中所起到的作用。

    接下來,我們就分別看看DispatcherServlet的兩條運(yùn)行主線。

    DispatcherServlet的初始化主線

    對于DispatcherServlet的初始化主線,我們首先應(yīng)該明確幾個(gè)基本觀點(diǎn):

    • 初始化主線的驅(qū)動(dòng)要素 —— servlet中的init方法
    • 初始化主線的執(zhí)行次序 —— HttpServletBean -> FrameworkServlet -> DispatcherServlet
    • 初始化主線的操作對象 —— Spring容器(WebApplicationContext)和組件

    這三個(gè)基本觀點(diǎn),可以說是我們對之前所有討論的一個(gè)小結(jié)。明確了這些內(nèi)容,我們就可以更加深入地看看DispatcherServlet初始化主線的過程:



    在這幅圖中,我們站在一個(gè)動(dòng)態(tài)的角度將DispatcherServlet、容器(WebApplicationContext)和組件這三者之間的關(guān)系表述出來,同時(shí)給出了這三者之間的運(yùn)行順序和邏輯過程。讀者或許對其中的絕大多數(shù)細(xì)節(jié)還很陌生,甚至有一種無從下手的感覺。這沒有關(guān)系,大家可以首先抓住圖中的執(zhí)行線,回憶一下之前有關(guān)DispatcherServlet的繼承結(jié)構(gòu)和數(shù)據(jù)結(jié)構(gòu)的內(nèi)容。接下來,我們就圖中的內(nèi)容逐一進(jìn)行解釋。

    【W(wǎng)ebApplicationContext的初始化】

    之前我們討論了DispatcherServlet對于WebApplicationContext的初始化是在FrameworkServlet中完成的,不過我們并沒有細(xì)究其中的細(xì)節(jié)。在默認(rèn)情況下,這個(gè)初始化過程是由web.xml中的入口程序配置所驅(qū)動(dòng)的:

    Xml代碼 ?

  • <!--?Processes?application?requests?-->??
  • <servlet>??
  • ????<servlet-name>dispatcher</servlet-name>??
  • ????<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>??
  • ????<load-on-startup>1</load-on-startup>??
  • </servlet>??
  • ??????????
  • <servlet-mapping>??
  • ????<servlet-name>dispatcher</servlet-name>??
  • ????<url-pattern>/**</url-pattern>??
  • </servlet-mapping>??
  • <!-- Processes application requests -->

    <servlet>

    ????<servlet-name>dispatcher</servlet-name>

    ????<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    ????<load-on-startup>1</load-on-startup>

    </servlet>

    ????????

    <servlet-mapping>

    ????<servlet-name>dispatcher</servlet-name>

    ????<url-pattern>/**</url-pattern>

    </servlet-mapping>



    我們已經(jīng)不止一次提到過這段配置,不過在這之前都沒有對這段配置做過什么很詳細(xì)的分析。事實(shí)上,這段入口程序的配置中隱藏了SpringMVC的兩大要素(核心分發(fā)器Dispatcher和核心配置文件[servlet-name]-servlet.xml)之間的關(guān)系表述:

    downpour 寫道

    在默認(rèn)情況下,web.xml配置節(jié)點(diǎn)中<servlet-name>的值就是建立起核心分發(fā)器DispatcherServlet與核心配置文件之間聯(lián)系的橋梁。DispatcherServlet在初始化時(shí)會(huì)加載位置在/WEB-INF/[servlet-name]-servlet.xml的配置文件作為SpringMVC的核心配置。



    SpringMVC在這里采用了一個(gè)"命名約定"的方法進(jìn)行關(guān)系映射,這種方法很廉價(jià)也很管用。以上面的配置為例,我們就必須在/WEB-INF/目錄下,放一個(gè)名為dispatcher-servlet.xml的Spring配置文件作為SpringMVC的核心配置用以指定SpringMVC的基本組件聲明定義。

    這看上去似乎有一點(diǎn)別扭,因?yàn)樵趯?shí)際項(xiàng)目中,我們通常喜歡把配置文件放在classpath下,并使用不同的package進(jìn)行區(qū)分。例如,在基于Maven的項(xiàng)目結(jié)構(gòu)中,所有的配置文件應(yīng)置于src/main/resources目錄下,這樣才比較符合配置文件統(tǒng)一化管理的最佳實(shí)踐。

    于是,Spring提供了一個(gè)初始化的配置選項(xiàng),通過指定contextConfigLocation選項(xiàng)來自定義SpringMVC核心配置文件的位置:

    Xml代碼 ?

  • <!--?Processes?application?requests?-->??
  • <servlet>??
  • ????<servlet-name>dispatcher</servlet-name>??
  • ????<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>??
  • ????<init-param>??
  • ????????<param-name>contextConfigLocation</param-name>??
  • ????????<param-value>classpath:web/applicationContext-dispatcherServlet.xml</param-value>??
  • ????</init-param>??
  • ????<load-on-startup>1</load-on-startup>??
  • </servlet>??
  • ??????????
  • <servlet-mapping>??
  • ????<servlet-name>dispatcher</servlet-name>??
  • ????<url-pattern>/</url-pattern>??
  • </servlet-mapping>??
  • <!-- Processes application requests -->

    <servlet>

    ????<servlet-name>dispatcher</servlet-name>

    ????<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    ????<init-param>

    ????????<param-name>contextConfigLocation</param-name>

    ????????<param-value>classpath:web/applicationContext-dispatcherServlet.xml</param-value>

    ????</init-param>

    ????<load-on-startup>1</load-on-startup>

    </servlet>

    ????????

    <servlet-mapping>

    ????<servlet-name>dispatcher</servlet-name>

    ????<url-pattern>/</url-pattern>

    </servlet-mapping>



    這樣一來,DispatcherServlet在初始化時(shí),就會(huì)自動(dòng)加載在classpath下,web這個(gè)package下名為applicationContext-dispatcherServlet.xml的文件作為其核心配置并用以初始化容器(WebApplicationContext)。

    當(dāng)然,這只是DispatcherServlet在進(jìn)行WebApplicationContext初始化過程中的配置選項(xiàng)之一。我們可以在Spring的官方reference中找到相應(yīng)的配置選項(xiàng),有興趣的讀者可以參照reference的說明進(jìn)行嘗試:



    所有的這些配置選項(xiàng),實(shí)際上都是為了讓DispatcherServlet對WebApplicationContext的初始化過程顯得更加自然。不過這只是完成了容器(WebApplicationContext)的構(gòu)建工作,那么容器所管理的那些組件,又是如何進(jìn)行初始化的呢?

    downpour 寫道

    結(jié)論 SpringMVC核心配置文件中所有的bean定義,就是SpringMVC的組件定義,也是DispatcherServlet在初始化容器(WebApplicationContext)時(shí),所要進(jìn)行初始化的組件。



    在上一篇文章我們談到組件的時(shí)候就曾經(jīng)提到,SpringMVC自身對于組件并未實(shí)現(xiàn)一套完整的管理機(jī)制,而是借用了Spring Framework核心框架中容器的概念,將所有的組件納入到容器中進(jìn)行管理。所以,SpringMVC的核心配置文件使用與傳統(tǒng)Spring Framework相同的配置形式,而整個(gè)管理的體系也是一脈相承的。

    :Spring3.0之后,單獨(dú)為SpringMVC建立了專用的schema,從而使得我們可以使用Schema Based XML來對SpringMVC的組件進(jìn)行定義。不過我們可以將其視作是傳統(tǒng)Spring配置的一個(gè)補(bǔ)充,而不要過于糾結(jié)不同的配置格式。

    我們知道,SpringMVC的組件是一個(gè)個(gè)的接口定義,當(dāng)我們在SpringMVC的核心配置文件中定義一個(gè)組件時(shí),使用的卻是組件的實(shí)現(xiàn)類:

    Xml代碼 ?

  • <bean?class="org.springframework.web.servlet.view.InternalResourceViewResolver">??
  • ????<property?name="prefix"?value="/"?/>??
  • ????<property?name="suffix"?value=".jsp"?/>??
  • </bean>??
  • <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">

    ????<property name="prefix" value="/" />

    ????<property name="suffix" value=".jsp" />

    </bean>



    這也就是Spring管理組件的模式:用具體的實(shí)現(xiàn)類來指定接口的行為方式。不同的實(shí)現(xiàn)類,代表著不同的組件行為模式,它們在Spring容器中是可以共存的:

    Xml代碼 ?

  • <bean?class="org.springframework.web.servlet.view.InternalResourceViewResolver">??
  • ????<property?name="prefix"?value="/"?/>??
  • ????<property?name="suffix"?value=".jsp"?/>??
  • </bean>??
  • ??
  • <bean?class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">??
  • ????<property?name="prefix"?value="/"?/>??
  • ????<property?name="suffix"?value=".ftl"?/>??
  • </bean>??
  • <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">

    ????<property name="prefix" value="/" />

    ????<property name="suffix" value=".jsp" />

    </bean>

    ?

    <bean class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">

    ????<property name="prefix" value="/" />

    ????<property name="suffix" value=".ftl" />

    </bean>



    所以,Spring的容器就像是一個(gè)聚寶盆,它只負(fù)責(zé)承載對象,管理好對象的生命周期,而并不關(guān)心一個(gè)組件接口到底有多少種實(shí)現(xiàn)類或者行為模式。這也就是我們在上面那幅圖中,畫了多個(gè)HandlerMappings、HandlerAdapters和ViewResolvers的原因:一個(gè)組件的多種行為模式可以在容器中共存,容器將負(fù)責(zé)對這些實(shí)現(xiàn)類進(jìn)行管理。而具體如何使用這些對象,則由應(yīng)用程序自身來決定。

    如此一來,我們可以大致概括一下WebApplicationContext初始化的兩個(gè)邏輯層次:

    • DispatcherServlet負(fù)責(zé)對容器(WebApplicationContext)進(jìn)行初始化。
    • 容器(WebApplicationContext)將讀取SpringMVC的核心配置文件進(jìn)行組件的實(shí)例化。

    整個(gè)過程,我們把應(yīng)用程序的日志級別調(diào)低,可以進(jìn)行非常詳細(xì)的觀察:

    引用

    14:15:27,037 DEBUG StandardServletEnvironment:100 - Initializing new StandardServletEnvironment
    14:15:27,128 DEBUG DispatcherServlet:115 - Initializing servlet 'dispatcher'
    14:15:27,438? INFO DispatcherServlet:444 - FrameworkServlet 'dispatcher': initialization started

    14:15:27,449 DEBUG DispatcherServlet:572 - Servlet with name 'dispatcher' will try to create custom WebApplicationContext context of class 'org.springframework.web.context.support.XmlWebApplicationContext', using parent context [null]
    1571 [main] INFO /sample - Initializing Spring FrameworkServlet 'dispatcher'
    14:15:27,505 DEBUG StandardServletEnvironment:100 - Initializing new StandardServletEnvironment
    14:15:27,546? INFO XmlWebApplicationContext:495 - Refreshing WebApplicationContext for namespace 'dispatcher-servlet': startup date [Mon Feb 06 14:15:27 CST 2012]; root of context hierarchy
    14:15:27,689? INFO XmlBeanDefinitionReader:315 - Loading XML bean definitions from class path resource [web/applicationContext-dispatcherServlet.xml]
    14:15:27,872 DEBUG PluggableSchemaResolver:140 - Loading schema mappings from [META-INF/spring.schemas]
    14:15:28,442 DEBUG PathMatchingResourcePatternResolver:550 - Looking for matching resources in directory tree [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller]
    14:15:28,442 DEBUG PathMatchingResourcePatternResolver:612 - Searching directory [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller] for files matching pattern [D:/Work/Demo2do/Sample/target/classes/com/demo2do/sample/web/controller/**/*.class]
    14:15:28,450 DEBUG PathMatchingResourcePatternResolver:351 - Resolved location pattern [classpath*:com/demo2do/sample/web/controller/**/*.class] to resources [file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller\BlogController.class], file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller\UserController.class]]
    14:15:28,569 DEBUG ClassPathBeanDefinitionScanner:243 - Identified candidate component class: file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller\BlogController.class]
    14:15:28,571 DEBUG ClassPathBeanDefinitionScanner:243 - Identified candidate component class: file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller\UserController.class]
    14:15:28,634 DEBUG BeanDefinitionParserDelegate:497 - Neither XML 'id' nor 'name' specified - using generated bean name [org.springframework.web.servlet.view.InternalResourceViewResolver#0]
    14:15:28,635 DEBUG XmlBeanDefinitionReader:216 - Loaded 19 bean definitions from location pattern [classpath:web/applicationContext-dispatcherServlet.xml]
    14:15:28,635 DEBUG XmlWebApplicationContext:525 - Bean factory for WebApplicationContext for namespace 'dispatcher-servlet': org.springframework.beans.factory.support.DefaultListableBeanFactory@2321b59a: defining beans [org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping#0,org.springframework.format.support.FormattingConversionServiceFactoryBean#0,org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter#0,org.springframework.web.servlet.handler.MappedInterceptor#0,org.springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExceptionResolver#0,org.springframework.web.servlet.mvc.annotation.ResponseStatusExceptionResolver#0,org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver#0,org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping,org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter,org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter,blogController,userController,org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor,org.springframework.web.servlet.resource.ResourceHttpRequestHandler#0,org.springframework.web.servlet.handler.SimpleUrlHandlerMapping#0,org.springframework.web.servlet.view.InternalResourceViewResolver#0]; root of factory hierarchy
    14:15:29,015 DEBUG RequestMappingHandlerMapping:98 - Looking for request mappings in application context: WebApplicationContext for namespace 'dispatcher-servlet': startup date [Mon Feb 06 14:15:27 CST 2012]; root of context hierarchy
    14:15:29,037? INFO RequestMappingHandlerMapping:188 - Mapped "{[/blog],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.springframework.web.servlet.ModelAndView com.demo2do.station.web.controller.BlogController.index()
    14:15:29,039? INFO RequestMappingHandlerMapping:188 - Mapped "{[/login],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.springframework.web.servlet.ModelAndView com.demo2do.station.web.controller.UserController.login(java.lang.String,java.lang.String)
    14:15:29,040 DEBUG DefaultListableBeanFactory:458 - Finished creating instance of bean 'org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping#0'
    14:15:29,460 DEBUG BeanNameUrlHandlerMapping:71 - Looking for URL mappings in application context: WebApplicationContext for namespace 'dispatcher-servlet': startup date [Mon Feb 06 14:15:27 CST 2012]; root of context hierarchy
    14:15:29,539 DEBUG DefaultListableBeanFactory:458 - Finished creating instance of bean 'org.springframework.web.servlet.resource.ResourceHttpRequestHandler#0'
    14:15:29,540 DEBUG DefaultListableBeanFactory:217 - Creating shared instance of singleton bean 'org.springframework.web.servlet.handler.SimpleUrlHandlerMapping#0'
    14:15:29,555? INFO SimpleUrlHandlerMapping:314 - Mapped URL path [/static/**] onto handler 'org.springframework.web.servlet.resource.ResourceHttpRequestHandler#0'
    14:15:29,556 DEBUG DefaultListableBeanFactory:458 - Finished creating instance of bean 'org.springframework.web.servlet.handler.SimpleUrlHandlerMapping#0'
    14:15:29,827 DEBUG DispatcherServlet:523 - Published WebApplicationContext of servlet 'dispatcher' as ServletContext attribute with name [org.springframework.web.servlet.FrameworkServlet.CONTEXT.dispatcher]
    14:15:29,827? INFO DispatcherServlet:463 - FrameworkServlet 'dispatcher': initialization completed in 2389 ms
    14:15:29,827 DEBUG DispatcherServlet:136 - Servlet 'dispatcher' configured successfully

    4047 [main] INFO org.mortbay.log - Started SelectChannelConnector@0.0.0.0:8080
    Jetty Server started, use 4267 ms



    在這段啟動(dòng)日志(筆者進(jìn)行了一定刪減)中,筆者刻意將WebApplicationContext的初始化的標(biāo)志日志使用紅色的標(biāo)進(jìn)行區(qū)分,而將核心配置文件的讀取位置和組件定義初始化的標(biāo)志日志使用藍(lán)色標(biāo)記加以區(qū)分。相信有了這段日志的幫助,讀者應(yīng)該可以對WebApplicationContext的初始化過程有了更加直觀的認(rèn)識。

    :啟動(dòng)日志是我們研究SpringMVC的主要途徑之一,之后我們還將反復(fù)使用這種方法對SpringMVC的運(yùn)行過程進(jìn)行研究。讀者應(yīng)該仔細(xì)品味每一條日志的作用,從而能夠與之后的分析講解呼應(yīng)起來。

    或許讀者對WebApplicationContext對組件進(jìn)行初始化的過程還有點(diǎn)困惑,大家不妨先將這個(gè)過程省略,把握住整個(gè)DispatcherServlet的大方向。我們在之后的文章中,還將對SpringMVC的組件、這些組件的定義以及組件的初始化方式做進(jìn)一步的分析和探討。

    到此為止,圖中順著FrameworkServlet的那些箭頭,我們已經(jīng)交代清楚,讀者可以回味一下整個(gè)過程。

    【獨(dú)立的WebApplicationContext體系】

    獨(dú)立的WebApplicationContext體系,是SpringMVC初始化主線中的一個(gè)非常重要的概念。回顧一下剛才曾經(jīng)提到過的DispatcherServlet、容器和組件三者之間的關(guān)系,我們在引用的那副官方reference的示意圖中,實(shí)際上已經(jīng)包含了這一層意思:

    downpour 寫道

    結(jié)論 在DispatcherServlet初始化的過程中所構(gòu)建的WebApplicationContext獨(dú)立于Spring自身的所構(gòu)建的其他WebApplicationContext體系而存在。



    稍有一些Spring編程經(jīng)驗(yàn)的程序員,對于下面的配置應(yīng)該非常熟悉:

    Xml代碼 ?

  • <context-param>??
  • ????<param-name>contextConfigLocation</param-name>??
  • ????<param-value>classpath:context/applicationContext-*.xml</param-value>??
  • </context-param>??
  • ??????
  • <listener>??
  • ????<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>??
  • </listener>??
  • <context-param>

    ????<param-name>contextConfigLocation</param-name>

    ????<param-value>classpath:context/applicationContext-*.xml</param-value>

    </context-param>

    ????

    <listener>

    ????<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>

    </listener>



    在上面的代碼中,我們定義了一個(gè)Listener,它會(huì)在整個(gè)Web應(yīng)用程序啟動(dòng)的時(shí)候運(yùn)行一次,并初始化傳統(tǒng)意義上的Spring的容器。這也是一般情況下,當(dāng)并不使用SpringMVC作為我們的表示層解決方案,卻希望在我們的Web應(yīng)用程序中使用Spring相關(guān)功能時(shí)所采取的一種配置方式。

    如果我們要在這里引入SpringMVC,整個(gè)配置看上去就像這樣:

    Xml代碼 ?

  • <context-param>??
  • ????<param-name>contextConfigLocation</param-name>??
  • ????<param-value>classpath:context/applicationContext-*.xml</param-value>??
  • </context-param>??
  • ??????
  • <listener>??
  • ????<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>??
  • </listener>??
  • ??????
  • <!--?Processes?application?requests?-->??
  • <servlet>??
  • ????<servlet-name>dispatcher</servlet-name>??
  • ????<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>??
  • ????<init-param>??
  • ????????<param-name>contextConfigLocation</param-name>??
  • ????????<param-value>classpath:web/applicationContext-dispatcherServlet.xml</param-value>??
  • ????</init-param>??
  • ????<load-on-startup>1</load-on-startup>??
  • </servlet>??
  • ??????????
  • <servlet-mapping>??
  • ????<servlet-name>dispatcher</servlet-name>??
  • ????<url-pattern>/</url-pattern>??
  • </servlet-mapping>??
  • <context-param>

    ????<param-name>contextConfigLocation</param-name>

    ????<param-value>classpath:context/applicationContext-*.xml</param-value>

    </context-param>

    ????

    <listener>

    ????<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>

    </listener>

    ?

    <!-- Processes application requests -->

    <servlet>

    ????<servlet-name>dispatcher</servlet-name>

    ????<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    ????<init-param>

    ????????<param-name>contextConfigLocation</param-name>

    ????????<param-value>classpath:web/applicationContext-dispatcherServlet.xml</param-value>

    ????</init-param>

    ????<load-on-startup>1</load-on-startup>

    </servlet>

    ????????

    <servlet-mapping>

    ????<servlet-name>dispatcher</servlet-name>

    ????<url-pattern>/</url-pattern>

    </servlet-mapping>



    在這種情況下,DispatcherServlet和ContextLoaderListener會(huì)分別構(gòu)建不同作用范圍的容器(WebApplicationContext)。我們可以引入兩個(gè)不同的概念來對其進(jìn)行表述:ContextLoaderListener所初始化的容器,我們稱之為Root WebApplicationContext;而DispatcherServlet所初始化的容器,是SpringMVC WebApplicationContext

    同樣采取日志分析的方法,加入了ContextLoaderListener之后,整個(gè)啟動(dòng)日志變成了這樣:

    引用

    [main] INFO /sample - Initializing Spring root WebApplicationContext
    14:56:42,261? INFO ContextLoader:272 - Root WebApplicationContext: initialization started
    14:56:42,343 DEBUG StandardServletEnvironment:100 - Initializing new StandardServletEnvironment
    14:56:42,365? INFO XmlWebApplicationContext:495 - Refreshing Root WebApplicationContext: startup date [Mon Feb 06 14:56:42 CST 2012]; root of context hierarchy
    14:56:42,441 DEBUG PathMatchingResourcePatternResolver:550 - Looking for matching resources in directory tree [D:\Work\Demo2do\Sample\target\classes\context]
    14:56:42,442 DEBUG PathMatchingResourcePatternResolver:612 - Searching directory [D:\Work\Demo2do\Sample\target\classes\context] for files matching pattern [D:/Work/Demo2do/Sample/target/classes/context/applicationContext-*.xml]
    14:56:42,446 DEBUG PathMatchingResourcePatternResolver:351 - Resolved location pattern [classpath:context/applicationContext-*.xml] to resources [file [D:\Work\Demo2do\Sample\target\classes\context\applicationContext-configuration.xml]]
    14:56:42,447? INFO XmlBeanDefinitionReader:315 - Loading XML bean definitions from file [D:\Work\Demo2do\Sample\target\classes\context\applicationContext-configuration.xml]
    14:56:42,486 DEBUG PluggableSchemaResolver:140 - Loading schema mappings from [META-INF/spring.schemas]
    14:56:42,597 DEBUG DefaultBeanDefinitionDocumentReader:108 - Loading bean definitions
    14:56:42,658 DEBUG PathMatchingResourcePatternResolver:550 - Looking for matching resources in directory tree [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample]
    14:56:42,699 DEBUG ClassPathBeanDefinitionScanner:243 - Identified candidate component class: file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\service\impl\BlogServiceImpl.class]
    14:56:42,750 DEBUG XmlBeanDefinitionReader:216 - Loaded 5 bean definitions from location pattern [classpath:context/applicationContext-*.xml]
    14:56:42,750 DEBUG XmlWebApplicationContext:525 - Bean factory for Root WebApplicationContext: org.springframework.beans.factory.support.DefaultListableBeanFactory@478e4327: defining beans [blogService,org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor]; root of factory hierarchy
    14:56:42,860 DEBUG ContextLoader:296 - Published root WebApplicationContext as ServletContext attribute with name [org.springframework.web.context.WebApplicationContext.ROOT]
    14:56:42,860? INFO ContextLoader:301 - Root WebApplicationContext: initialization completed in 596 ms


    14:56:42,935 DEBUG DispatcherServlet:115 - Initializing servlet 'dispatcher'
    14:56:42,974? INFO DispatcherServlet:444 - FrameworkServlet 'dispatcher': initialization started

    14:56:42,974 DEBUG DispatcherServlet:572 - Servlet with name 'dispatcher' will try to create custom WebApplicationContext context of class 'org.springframework.web.context.support.XmlWebApplicationContext', using parent context [Root WebApplicationContext: startup date [Mon Feb 06 14:56:42 CST 2012]; root of context hierarchy]
    14:56:42,979? INFO XmlWebApplicationContext:495 - Refreshing WebApplicationContext for namespace 'dispatcher-servlet': startup date [Mon Feb 06 14:56:42 CST 2012]; parent: Root WebApplicationContext
    14:56:42,983? INFO XmlBeanDefinitionReader:315 - Loading XML bean definitions from class path resource [web/applicationContext-dispatcherServlet.xml]
    14:56:42,987 DEBUG PluggableSchemaResolver:140 - Loading schema mappings from [META-INF/spring.schemas]
    14:56:43,035 DEBUG DefaultBeanDefinitionDocumentReader:108 - Loading bean definitions
    14:56:43,075 DEBUG PathMatchingResourcePatternResolver:550 - Looking for matching resources in directory tree [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller]
    14:56:43,075 DEBUG PathMatchingResourcePatternResolver:612 - Searching directory [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller] for files matching pattern [D:/Work/Demo2do/Sample/target/classes/com/demo2do/sample/web/controller/**/*.class]
    14:56:43,077 DEBUG PathMatchingResourcePatternResolver:351 - Resolved location pattern [classpath*:com/demo2do/sample/web/controller/**/*.class] to resources [file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller\BlogController.class], file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller\UserController.class]]
    14:56:43,079 DEBUG ClassPathBeanDefinitionScanner:243 - Identified candidate component class: file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller\BlogController.class]
    14:56:43,080 DEBUG ClassPathBeanDefinitionScanner:243 - Identified candidate component class: file [D:\Work\Demo2do\Sample\target\classes\com\demo2do\sample\web\controller\UserController.class]
    14:56:43,089 DEBUG XmlBeanDefinitionReader:216 - Loaded 19 bean definitions from location pattern [classpath:web/applicationContext-dispatcherServlet.xml]
    14:56:43,089 DEBUG XmlWebApplicationContext:525 - Bean factory for WebApplicationContext for namespace 'dispatcher-servlet': org.springframework.beans.factory.support.DefaultListableBeanFactory@5e6458a6: defining beans [org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping#0,org.springframework.format.support.FormattingConversionServiceFactoryBean#0,org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter#0,org.springframework.web.servlet.handler.MappedInterceptor#0,org.springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExceptionResolver#0,org.springframework.web.servlet.mvc.annotation.ResponseStatusExceptionResolver#0,org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver#0,org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping,org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter,org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter,blogController,userController,org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor,org.springframework.web.servlet.resource.ResourceHttpRequestHandler#0,org.springframework.web.servlet.handler.SimpleUrlHandlerMapping#0,org.springframework.web.servlet.view.InternalResourceViewResolver#0]; parent: org.springframework.beans.factory.support.DefaultListableBeanFactory@478e4327
    14:56:43,323 DEBUG RequestMappingHandlerMapping:98 - Looking for request mappings in application context: WebApplicationContext for namespace 'dispatcher-servlet': startup date [Mon Feb 06 14:56:42 CST 2012]; parent: Root WebApplicationContext
    14:56:43,345? INFO RequestMappingHandlerMapping:188 - Mapped "{[/blog],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.springframework.web.servlet.ModelAndView com.demo2do.sample.web.controller.BlogController.index()
    14:56:43,346? INFO RequestMappingHandlerMapping:188 - Mapped "{[/login],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.springframework.web.servlet.ModelAndView com.demo2do.sample.web.controller.UserController.login(java.lang.String,java.lang.String)
    14:56:43,707 DEBUG BeanNameUrlHandlerMapping:71 - Looking for URL mappings in application context: WebApplicationContext for namespace 'dispatcher-servlet': startup date [Mon Feb 06 14:56:42 CST 2012]; parent: Root WebApplicationContext
    14:56:43,828? INFO SimpleUrlHandlerMapping:314 - Mapped URL path [/static/**] onto handler 'org.springframework.web.servlet.resource.ResourceHttpRequestHandler#0'
    14:56:43,883 DEBUG DispatcherServlet:523 - Published WebApplicationContext of servlet 'dispatcher' as ServletContext attribute with name [org.springframework.web.servlet.FrameworkServlet.CONTEXT.dispatcher]
    14:56:43,883? INFO DispatcherServlet:463 - FrameworkServlet 'dispatcher': initialization completed in 909 ms
    14:56:43,883 DEBUG DispatcherServlet:136 - Servlet 'dispatcher' configured successfully

    2687 [main] INFO org.mortbay.log - Started SelectChannelConnector@0.0.0.0:8080
    Jetty Server started, use 2901 ms



    整個(gè)啟動(dòng)日志被我們分為了2段。第一段的過程初始化的是Root WebApplicationContext;而第二段的過程初始化的是SpringMVC的WebApplicationContext。我們還是使用了紅色的標(biāo)記和藍(lán)色標(biāo)記指出了在整個(gè)初始化過程中的一些重要事件。其中,有這樣一段內(nèi)容值得我們注意:

    引用

    14:56:42,979? INFO XmlWebApplicationContext:495 - Refreshing WebApplicationContext for namespace 'dispatcher-servlet': startup date [Mon Feb 06 14:56:42 CST 2012]; parent: Root WebApplicationContext



    在這段日志中,非常明確地指出了SpringMVC WebApplicationContext與Root WebApplicationContext之間的關(guān)系:從屬關(guān)系。因?yàn)楦鶕?jù)這段日志的表述,SpringMVC WebApplicationContext能夠感知到Root WebApplicationContext的存在,并且將其作為parent容器。

    Spring正是使用這種Parent-Child的容器關(guān)系來對不同的編程層次進(jìn)行劃分。這種我們俗稱的父子關(guān)系實(shí)際上不僅僅是一種從屬關(guān)系,更是一種引用關(guān)系。從剛才的日志分析中,我們可以看出:SpringMVC中所定義的一切組件能夠無縫地與Root WebApplicationContext中的組件整合。

    到此為止,我們針對圖中以web.xml為核心的箭頭分支進(jìn)行了講解,讀者可以將圖中的內(nèi)容與上面的文字說明對照再次加以理解。

    【組件默認(rèn)行為的指定】

    DispatcherServlet的初始化主線的執(zhí)行體系是順著其繼承結(jié)構(gòu)依次進(jìn)行的,我們在之前曾經(jīng)討論過它的執(zhí)行次序。所以,只有在FrameworkServlet完成了對于WebApplicationContext和組件的初始化之后,執(zhí)行權(quán)才被正式轉(zhuǎn)移到DispatcherServlet中。我們可以來看看DispatcherServlet此時(shí)究竟干了哪些事:

    Java代碼 ?

  • /**?
  • ?*?This?implementation?calls?{@link?#initStrategies}.?
  • ?*/??
  • @Override??
  • protected?void?onRefresh(ApplicationContext?context)?{??
  • ????initStrategies(context);??
  • }??
  • ??
  • /**?
  • ?*?Initialize?the?strategy?objects?that?this?servlet?uses.?
  • ?*?<p>May?be?overridden?in?subclasses?in?order?to?initialize?further?strategy?objects.?
  • ?*/??
  • protected?void?initStrategies(ApplicationContext?context)?{??
  • ????initMultipartResolver(context);??
  • ????initLocaleResolver(context);??
  • ????initThemeResolver(context);??
  • ????initHandlerMappings(context);??
  • ????initHandlerAdapters(context);??
  • ????initHandlerExceptionResolvers(context);??
  • ????initRequestToViewNameTranslator(context);??
  • ????initViewResolvers(context);??
  • ????initFlashMapManager(context);??
  • }??
  • /**

    * This implementation calls {@link #initStrategies}.

    */

    @Override

    protected void onRefresh(ApplicationContext context) {

    ????initStrategies(context);

    }

    ?

    /**

    * Initialize the strategy objects that this servlet uses.

    * <p>May be overridden in subclasses in order to initialize further strategy objects.

    */

    protected void initStrategies(ApplicationContext context) {

    ????initMultipartResolver(context);

    ????initLocaleResolver(context);

    ????initThemeResolver(context);

    ????initHandlerMappings(context);

    ????initHandlerAdapters(context);

    ????initHandlerExceptionResolvers(context);

    ????initRequestToViewNameTranslator(context);

    ????initViewResolvers(context);

    ????initFlashMapManager(context);

    }



    onRefresh是FrameworkServlet中預(yù)留的擴(kuò)展方法,在DispatcherServlet中做了一個(gè)基本實(shí)現(xiàn):initStrategies。我們粗略一看,很容易就能明白DispatcherServlet到底在這里干些什么了:初始化組件

    讀者或許會(huì)問,組件不是已經(jīng)在WebApplicationContext初始化的時(shí)候已經(jīng)被初始化過了嘛?這里所謂的組件初始化,指的又是什么呢?讓我們來看看其中的一個(gè)方法的源碼:

    Java代碼 ?

  • /**?
  • ?*?Initialize?the?MultipartResolver?used?by?this?class.?
  • ?*?<p>If?no?bean?is?defined?with?the?given?name?in?the?BeanFactory?for?this?namespace,?
  • ?*?no?multipart?handling?is?provided.?
  • ?*/??
  • private?void?initMultipartResolver(ApplicationContext?context)?{??
  • ????try?{??
  • ????????this.multipartResolver?=?context.getBean(MULTIPART_RESOLVER_BEAN_NAME,?MultipartResolver.class);??
  • ????????if?(logger.isDebugEnabled())?{??
  • ????????????logger.debug("Using?MultipartResolver?["?+?this.multipartResolver?+?"]");??
  • ????????}??
  • ????}?catch?(NoSuchBeanDefinitionException?ex)?{??
  • ????????//?Default?is?no?multipart?resolver.??
  • ????????this.multipartResolver?=?null;??
  • ????????if?(logger.isDebugEnabled())?{??
  • ????????????logger.debug("Unable?to?locate?MultipartResolver?with?name?'"?+?MULTIPART_RESOLVER_BEAN_NAME?+??
  • ????????????????????"':?no?multipart?request?handling?provided");??
  • ????????}??
  • ????}??
  • }??
  • /**

    * Initialize the MultipartResolver used by this class.

    * <p>If no bean is defined with the given name in the BeanFactory for this namespace,

    * no multipart handling is provided.

    */

    private void initMultipartResolver(ApplicationContext context) {

    ????try {

    ????????this.multipartResolver = context.getBean(MULTIPART_RESOLVER_BEAN_NAME, MultipartResolver.class);

    ????????if (logger.isDebugEnabled()) {

    ????????????logger.debug("Using MultipartResolver [" + this.multipartResolver + "]");

    ????????}

    ????} catch (NoSuchBeanDefinitionException ex) {

    ????????// Default is no multipart resolver.

    ????????this.multipartResolver = null;

    ????????if (logger.isDebugEnabled()) {

    ????????????logger.debug("Unable to locate MultipartResolver with name '" + MULTIPART_RESOLVER_BEAN_NAME +

    ????????????????????"': no multipart request handling provided");

    ????????}

    ????}

    }



    原來,這里的初始化,指的是DispatcherServlet從容器(WebApplicationContext)中讀取組件的實(shí)現(xiàn)類,并緩存于DispatcherServlet內(nèi)部的過程。還記得我們之前給出的DispatcherServlet的數(shù)據(jù)結(jié)構(gòu)嗎?這些位于DispatcherServlet內(nèi)部的組件實(shí)際上只是一些來源于容器緩存實(shí)例,不過它們同樣也是DispatcherServlet進(jìn)行后續(xù)操作的基礎(chǔ)。

    :我們在第一篇文章中就曾經(jīng)提到過Servlet實(shí)例內(nèi)部的屬性的訪問有線程安全問題。而在這里,我們可以看到所有的組件都以Servlet內(nèi)部屬性的形式被調(diào)用,充分證實(shí)了這些組件本身也都是無狀態(tài)的單例對象,所以我們在這里不必考慮線程安全的問題。

    如果對上面的代碼加以詳細(xì)分析,我們會(huì)發(fā)現(xiàn)initMultipartResolver的過程是查找特定MultipartResolver實(shí)現(xiàn)類的過程。因?yàn)樵谌萜髦胁檎医M件的時(shí)候,采取的是根據(jù)特定名稱(MULTIPART_RESOLVER_BEAN_NAME)進(jìn)行查找的策略。由此,我們可以看到DispatcherServlet進(jìn)行組件初始化的特點(diǎn):

    downpour 寫道

    結(jié)論 DispatcherServlet中對于組件的初始化過程實(shí)際上是應(yīng)用程序在WebApplicationContext中選擇和查找組件實(shí)現(xiàn)類的過程,也是指定組件在SpringMVC中的默認(rèn)行為方式的過程。



    除了根據(jù)特定名稱進(jìn)行查找的策略以外,我們還對DispatcherServlet中指定SpringMVC默認(rèn)行為方式的其他的策略進(jìn)行的總結(jié):

    • 名稱查找 —— 根據(jù)bean的名字在容器中查找相應(yīng)的實(shí)現(xiàn)類
    • 自動(dòng)搜索 —— 自動(dòng)搜索容器中所有某個(gè)特定組件(接口)的所有實(shí)現(xiàn)類
    • 默認(rèn)配置 —— 根據(jù)一個(gè)默認(rèn)的配置文件指定進(jìn)行實(shí)現(xiàn)類加載

    這三條策略恰巧在initHandlerMappings的過程中都有體現(xiàn),讀者可以從其源碼中找到相應(yīng)的線索:

    Java代碼 ?

  • private?void?initHandlerAdapters(ApplicationContext?context)?{??
  • ????this.handlerAdapters?=?null;??
  • ??
  • ????if?(this.detectAllHandlerAdapters)?{??
  • ????????//?Find?all?HandlerAdapters?in?the?ApplicationContext,?including?ancestor?contexts.??
  • ????????Map<String,?HandlerAdapter>?matchingBeans?=?BeanFactoryUtils.beansOfTypeIncludingAncestors(context,?HandlerAdapter.class,?true,?false);??
  • ????????if?(!matchingBeans.isEmpty())?{??
  • ????????????this.handlerAdapters?=?new?ArrayList<HandlerAdapter>(matchingBeans.values());??
  • ????????????//?We?keep?HandlerAdapters?in?sorted?order.??
  • ????????????OrderComparator.sort(this.handlerAdapters);??
  • ????????}??
  • ????}??
  • ????else?{??
  • ????????try?{??
  • ????????????HandlerAdapter?ha?=?context.getBean(HANDLER_ADAPTER_BEAN_NAME,?HandlerAdapter.class);??
  • ????????????this.handlerAdapters?=?Collections.singletonList(ha);??
  • ????????}??
  • ????????catch?(NoSuchBeanDefinitionException?ex)?{??
  • ????????????//?Ignore,?we'll?add?a?default?HandlerAdapter?later.??
  • ????????}??
  • ????}??
  • ??
  • ????//?Ensure?we?have?at?least?some?HandlerAdapters,?by?registering??
  • ????//?default?HandlerAdapters?if?no?other?adapters?are?found.??
  • ????if?(this.handlerAdapters?==?null)?{??
  • ????????this.handlerAdapters?=?getDefaultStrategies(context,?HandlerAdapter.class);??
  • ????????if?(logger.isDebugEnabled())?{??
  • ????????????logger.debug("No?HandlerAdapters?found?in?servlet?'"?+?getServletName()?+?"':?using?default");??
  • ????????}??
  • ????}??
  • }??
  • private void initHandlerAdapters(ApplicationContext context) {

    ????this.handlerAdapters = null;

    ?

    ????if (this.detectAllHandlerAdapters) {

    ????????// Find all HandlerAdapters in the ApplicationContext, including ancestor contexts.

    ????????Map<String, HandlerAdapter> matchingBeans = BeanFactoryUtils.beansOfTypeIncludingAncestors(context, HandlerAdapter.class, true, false);

    ????????if (!matchingBeans.isEmpty()) {

    ????????????this.handlerAdapters = new ArrayList<HandlerAdapter>(matchingBeans.values());

    ????????????// We keep HandlerAdapters in sorted order.

    ????????????OrderComparator.sort(this.handlerAdapters);

    ????????}

    ????}

    ????else {

    ????????try {

    ????????????HandlerAdapter ha = context.getBean(HANDLER_ADAPTER_BEAN_NAME, HandlerAdapter.class);

    ????????????this.handlerAdapters = Collections.singletonList(ha);

    ????????}

    ????????catch (NoSuchBeanDefinitionException ex) {

    ????????????// Ignore, we'll add a default HandlerAdapter later.

    ????????}

    ????}

    ?

    ????// Ensure we have at least some HandlerAdapters, by registering

    ????// default HandlerAdapters if no other adapters are found.

    ????if (this.handlerAdapters == null) {

    ????????this.handlerAdapters = getDefaultStrategies(context, HandlerAdapter.class);

    ????????if (logger.isDebugEnabled()) {

    ????????????logger.debug("No HandlerAdapters found in servlet '" + getServletName() + "': using default");

    ????????}

    ????}

    }



    這里有必要對"默認(rèn)策略"做一個(gè)簡要的說明。SpringMVC為一些核心組件設(shè)置了默認(rèn)行為方式的說明,這個(gè)說明以一個(gè)properties文件的形式位于SpringMVC分發(fā)包(例如spring-webmvc-3.1.0.RELEASE.jar)的內(nèi)部:



    我們可以觀察一下DispatcherServlet.properties的內(nèi)容:

    引用

    # Default implementation classes for DispatcherServlet's strategy interfaces.
    # Used as fallback when no matching beans are found in the DispatcherServlet context.
    # Not meant to be customized by application developers.

    org.springframework.web.servlet.LocaleResolver=org.springframework.web.servlet.i18n.AcceptHeaderLocaleResolver

    org.springframework.web.servlet.ThemeResolver=org.springframework.web.servlet.theme.FixedThemeResolver

    org.springframework.web.servlet.HandlerMapping=org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping,\
    org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping

    org.springframework.web.servlet.HandlerAdapter=org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter,\
    org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter,\
    org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter

    org.springframework.web.servlet.HandlerExceptionResolver=org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerExceptionResolver,\
    org.springframework.web.servlet.mvc.annotation.ResponseStatusExceptionResolver,\
    org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver

    org.springframework.web.servlet.RequestToViewNameTranslator=org.springframework.web.servlet.view.DefaultRequestToViewNameTranslator

    org.springframework.web.servlet.ViewResolver=org.springframework.web.servlet.view.InternalResourceViewResolver

    org.springframework.web.servlet.FlashMapManager=org.springframework.web.servlet.support.DefaultFlashMapManager



    結(jié)合剛才initHandlerMappings的源碼,我們可以發(fā)現(xiàn)如果沒有開啟detectAllHandlerAdapters選項(xiàng)或者根據(jù)HANDLER_ADAPTER_BEAN_NAME的名稱沒有找到相應(yīng)的組件實(shí)現(xiàn)類,就會(huì)使用DispatcherServlet.properties文件中對于HandlerMapping接口的實(shí)現(xiàn)來進(jìn)行組件默認(rèn)行為的初始化。

    由此可見,DispatcherServlet.properties中所指定的所有接口的實(shí)現(xiàn)方式在Spring的容器WebApplicationContext中總有相應(yīng)的定義。這一點(diǎn),我們在組件的討論中還會(huì)詳談。

    這個(gè)部分我們的側(cè)重點(diǎn)是圖中DispatcherServlet與容器之間的關(guān)系。讀者需要理解的是圖中為什么會(huì)有兩份組件定義,它們之間的區(qū)別在哪里,以及DispatcherServlet在容器中查找組件的三種策略。

    小結(jié)

    在本文中,我們對SpringMVC的核心類:DispatcherServlet進(jìn)行了一番梳理。也對整個(gè)SpringMVC的兩條主線之一的初始化主線做了詳細(xì)的分析。

    對于DispatcherServlet而言,重要的其實(shí)并不是這個(gè)類中的代碼和邏輯,而是應(yīng)該掌握這個(gè)類在整個(gè)框架中的作用以及與SpringMVC中其他要素的關(guān)系。

    對于初始化主線而言,核心其實(shí)僅僅在于那張筆者為大家精心打造的圖。讀者只要掌握了這張圖,相信對整個(gè)SpringMVC的初始化過程會(huì)有一個(gè)全新的認(rèn)識。

    轉(zhuǎn)載于:https://www.cnblogs.com/xiangxs/p/5052025.html

    總結(jié)

    以上是生活随笔為你收集整理的SpringMVC深度探险(三) —— DispatcherServlet与初始化主线的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    四虎国产精品一区二区 | 亚洲va欧美va天堂v国产综合 | 丰满人妻精品国产99aⅴ | 色综合久久久久综合一本到桃花网 | 精品国偷自产在线视频 | 日产国产精品亚洲系列 | 久久国产精品偷任你爽任你 | 婷婷六月久久综合丁香 | 婷婷五月综合缴情在线视频 | 日本xxxx色视频在线观看免费 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 亚洲欧美色中文字幕在线 | 亚洲无人区午夜福利码高清完整版 | 成人女人看片免费视频放人 | 国产成人无码a区在线观看视频app | 国产精品久久国产三级国 | 亚洲熟悉妇女xxx妇女av | 欧美老人巨大xxxx做受 | 久久99国产综合精品 | 亚洲自偷自拍另类第1页 | 国产精品久久久午夜夜伦鲁鲁 | 一区二区传媒有限公司 | 亚洲日本一区二区三区在线 | 色老头在线一区二区三区 | 免费人成在线观看网站 | 午夜精品一区二区三区在线观看 | 欧美喷潮久久久xxxxx | 377p欧洲日本亚洲大胆 | 18禁止看的免费污网站 | 高潮毛片无遮挡高清免费 | 思思久久99热只有频精品66 | 亚洲精品国产品国语在线观看 | 久久亚洲中文字幕精品一区 | 中文字幕日韩精品一区二区三区 | 人人妻人人澡人人爽欧美一区 | 成人免费视频在线观看 | 日本爽爽爽爽爽爽在线观看免 | 国产无遮挡又黄又爽免费视频 | av无码不卡在线观看免费 | 亚洲日韩av一区二区三区中文 | 日韩亚洲欧美精品综合 | 亚洲gv猛男gv无码男同 | 精品国产一区二区三区av 性色 | 2019nv天堂香蕉在线观看 | 久久精品99久久香蕉国产色戒 | 无码午夜成人1000部免费视频 | 亚洲精品欧美二区三区中文字幕 | 欧美性黑人极品hd | 国产综合久久久久鬼色 | 久久99久久99精品中文字幕 | 日日天干夜夜狠狠爱 | 亚洲日韩av一区二区三区中文 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产成人综合在线女婷五月99播放 | 精品国偷自产在线 | 奇米影视7777久久精品人人爽 | 无码av最新清无码专区吞精 | 精品国产精品久久一区免费式 | 国产亚洲日韩欧美另类第八页 | 动漫av一区二区在线观看 | 成人av无码一区二区三区 | 亚洲热妇无码av在线播放 | 玩弄人妻少妇500系列视频 | 丰满人妻一区二区三区免费视频 | 亚洲中文字幕无码中字 | 久久人人爽人人爽人人片ⅴ | 亚洲第一无码av无码专区 | 亚洲人成影院在线无码按摩店 | 国产无套粉嫩白浆在线 | 日本一区二区更新不卡 | 亚洲综合在线一区二区三区 | 一本久道久久综合狠狠爱 | 精品国产福利一区二区 | 国产精品无套呻吟在线 | 131美女爱做视频 | 一个人免费观看的www视频 | 日日摸天天摸爽爽狠狠97 | 国产无遮挡又黄又爽免费视频 | 狠狠色色综合网站 | 亚洲国产欧美国产综合一区 | 大地资源网第二页免费观看 | 国产亚洲人成在线播放 | 免费网站看v片在线18禁无码 | 久久精品国产一区二区三区肥胖 | 99在线 | 亚洲 | 又色又爽又黄的美女裸体网站 | 久久久久se色偷偷亚洲精品av | 亚洲欧美精品aaaaaa片 | 奇米影视7777久久精品 | 一本无码人妻在中文字幕免费 | 精品无码一区二区三区爱欲 | 蜜桃av抽搐高潮一区二区 | 少妇激情av一区二区 | 婷婷综合久久中文字幕蜜桃三电影 | 成年美女黄网站色大免费全看 | 中文字幕日产无线码一区 | 中文无码成人免费视频在线观看 | 亚洲精品鲁一鲁一区二区三区 | 丝袜人妻一区二区三区 | 亚洲aⅴ无码成人网站国产app | 好爽又高潮了毛片免费下载 | 亚洲人交乣女bbw | 青青久在线视频免费观看 | 久久综合九色综合97网 | 国产午夜亚洲精品不卡下载 | 国产成人精品无码播放 | 精品国产av色一区二区深夜久久 | 欧美怡红院免费全部视频 | 伦伦影院午夜理论片 | 国产香蕉97碰碰久久人人 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 国产黄在线观看免费观看不卡 | 久久久久久av无码免费看大片 | 熟女少妇在线视频播放 | 大地资源网第二页免费观看 | 日本一区二区三区免费播放 | 少妇被黑人到高潮喷出白浆 | 99精品无人区乱码1区2区3区 | 日本丰满熟妇videos | 131美女爱做视频 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 内射爽无广熟女亚洲 | 欧美熟妇另类久久久久久多毛 | 粗大的内捧猛烈进出视频 | 国内精品九九久久久精品 | 噜噜噜亚洲色成人网站 | 久久久久久a亚洲欧洲av冫 | 亚洲国产成人av在线观看 | 精品夜夜澡人妻无码av蜜桃 | 国产激情精品一区二区三区 | 久久精品人妻少妇一区二区三区 | 国产美女极度色诱视频www | 精品无码国产自产拍在线观看蜜 | 老熟妇仑乱视频一区二区 | 亚洲精品中文字幕乱码 | 99精品国产综合久久久久五月天 | 日韩精品无码免费一区二区三区 | 国产一区二区三区四区五区加勒比 | 欧美日韩久久久精品a片 | 午夜理论片yy44880影院 | 四十如虎的丰满熟妇啪啪 | 黄网在线观看免费网站 | 免费无码肉片在线观看 | 中文字幕精品av一区二区五区 | 中文无码伦av中文字幕 | 亚洲热妇无码av在线播放 | 老熟女重囗味hdxx69 | 少妇高潮喷潮久久久影院 | 夜先锋av资源网站 | 女人被男人躁得好爽免费视频 | a国产一区二区免费入口 | 成人性做爰aaa片免费看不忠 | 午夜理论片yy44880影院 | 中文字幕无码日韩欧毛 | 精品国产一区二区三区四区在线看 | 国产色xx群视频射精 | 爆乳一区二区三区无码 | 天天摸天天透天天添 | 粗大的内捧猛烈进出视频 | 色狠狠av一区二区三区 | 国产69精品久久久久app下载 | 亚洲 另类 在线 欧美 制服 | 性啪啪chinese东北女人 | 四虎影视成人永久免费观看视频 | 国产免费久久精品国产传媒 | 久久午夜夜伦鲁鲁片无码免费 | 国产热a欧美热a在线视频 | 亚洲熟妇色xxxxx欧美老妇 | 中文无码成人免费视频在线观看 | 亚洲熟女一区二区三区 | 精品无码成人片一区二区98 | 亚洲日韩av一区二区三区四区 | 中文字幕无码日韩欧毛 | 欧美老熟妇乱xxxxx | 精品无人国产偷自产在线 | 狠狠躁日日躁夜夜躁2020 | 国语精品一区二区三区 | 国产午夜无码视频在线观看 | 国产成人午夜福利在线播放 | 亚洲欧美综合区丁香五月小说 | 国产精品毛多多水多 | 高中生自慰www网站 | 乌克兰少妇性做爰 | 少妇高潮一区二区三区99 | 欧美zoozzooz性欧美 | 丰满少妇人妻久久久久久 | 久久久久久国产精品无码下载 | 东京一本一道一二三区 | 国产熟女一区二区三区四区五区 | 波多野结衣高清一区二区三区 | 免费中文字幕日韩欧美 | 免费播放一区二区三区 | 人妻少妇精品无码专区二区 | 亚洲精品一区国产 | 日日摸天天摸爽爽狠狠97 | 性生交片免费无码看人 | 大屁股大乳丰满人妻 | 精品偷自拍另类在线观看 | 久久人人爽人人爽人人片ⅴ | 日本熟妇大屁股人妻 | 国产电影无码午夜在线播放 | 熟女少妇在线视频播放 | 纯爱无遮挡h肉动漫在线播放 | 日韩成人一区二区三区在线观看 | 国产区女主播在线观看 | 97久久超碰中文字幕 | 国产精品美女久久久 | 久久精品国产99久久6动漫 | 99久久婷婷国产综合精品青草免费 | 亚洲国精产品一二二线 | 国产手机在线αⅴ片无码观看 | 国产真人无遮挡作爱免费视频 | 亚洲阿v天堂在线 | 国精产品一品二品国精品69xx | 亚洲欧美国产精品久久 | 国产午夜无码视频在线观看 | 宝宝好涨水快流出来免费视频 | 学生妹亚洲一区二区 | 亚洲精品综合五月久久小说 | 一本精品99久久精品77 | 久久无码专区国产精品s | 色一情一乱一伦一区二区三欧美 | 亚洲成熟女人毛毛耸耸多 | 亚洲精品一区二区三区大桥未久 | 国产精品自产拍在线观看 | 亚洲精品国产a久久久久久 | 日本大香伊一区二区三区 | 国产午夜无码视频在线观看 | 成人免费视频一区二区 | 久久人人爽人人爽人人片ⅴ | 少妇无套内谢久久久久 | 午夜无码人妻av大片色欲 | 亚洲gv猛男gv无码男同 | 亚洲午夜久久久影院 | 国内综合精品午夜久久资源 | 全球成人中文在线 | 国产色视频一区二区三区 | 国产精品无码一区二区三区不卡 | аⅴ资源天堂资源库在线 | 色噜噜亚洲男人的天堂 | 午夜丰满少妇性开放视频 | 日日天干夜夜狠狠爱 | 精品夜夜澡人妻无码av蜜桃 | 波多野结衣一区二区三区av免费 | 人妻天天爽夜夜爽一区二区 | 思思久久99热只有频精品66 | 日本一卡2卡3卡四卡精品网站 | 亚洲男人av香蕉爽爽爽爽 | 亚洲国产一区二区三区在线观看 | 少妇的肉体aa片免费 | 日韩人妻无码中文字幕视频 | 午夜精品久久久久久久久 | 又粗又大又硬毛片免费看 | 亚洲国精产品一二二线 | 国产乱子伦视频在线播放 | 亚洲区欧美区综合区自拍区 | 又湿又紧又大又爽a视频国产 | 精品国产乱码久久久久乱码 | 在线天堂新版最新版在线8 | 夜夜影院未满十八勿进 | 色一情一乱一伦一区二区三欧美 | 国产一区二区三区影院 | 中文字幕无码免费久久9一区9 | 久久99精品国产麻豆蜜芽 | 天天av天天av天天透 | 青青久在线视频免费观看 | 亚洲国产欧美在线成人 | 色诱久久久久综合网ywww | 在线精品国产一区二区三区 | 国产成人精品三级麻豆 | 无码人妻精品一区二区三区不卡 | 中文字幕久久久久人妻 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国语精品一区二区三区 | 欧美放荡的少妇 | 天下第一社区视频www日本 | 日本精品人妻无码77777 天堂一区人妻无码 | 久久久www成人免费毛片 | 免费网站看v片在线18禁无码 | 亚洲а∨天堂久久精品2021 | 丁香啪啪综合成人亚洲 | 麻豆成人精品国产免费 | 偷窥日本少妇撒尿chinese | 免费视频欧美无人区码 | 国产97色在线 | 免 | 国产无遮挡又黄又爽又色 | 日本熟妇人妻xxxxx人hd | 亚洲熟女一区二区三区 | 国产午夜精品一区二区三区嫩草 | 色综合久久中文娱乐网 | 国产综合色产在线精品 | 久久99精品国产麻豆蜜芽 | 中文字幕av无码一区二区三区电影 | 一本久久伊人热热精品中文字幕 | aa片在线观看视频在线播放 | 人妻少妇精品无码专区动漫 | 国产又爽又黄又刺激的视频 | 天堂亚洲免费视频 | 国产9 9在线 | 中文 | 午夜精品久久久久久久 | 国产精品香蕉在线观看 | 中文字幕乱妇无码av在线 | 欧美喷潮久久久xxxxx | 亚洲伊人久久精品影院 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲の无码国产の无码步美 | 强伦人妻一区二区三区视频18 | 天天摸天天碰天天添 | 国产97色在线 | 免 | 妺妺窝人体色www在线小说 | 国产熟女一区二区三区四区五区 | 最近的中文字幕在线看视频 | 在线播放亚洲第一字幕 | 亚洲综合无码一区二区三区 | 久久这里只有精品视频9 | 精品 日韩 国产 欧美 视频 | 国产 浪潮av性色四虎 | 人妻有码中文字幕在线 | 国产亚洲欧美在线专区 | 久久精品人妻少妇一区二区三区 | 性啪啪chinese东北女人 | 免费人成在线视频无码 | 国产成人无码午夜视频在线观看 | 日本乱人伦片中文三区 | 高清国产亚洲精品自在久久 | 久久国产自偷自偷免费一区调 | 黑人巨大精品欧美一区二区 | 日韩人妻系列无码专区 | 中文字幕精品av一区二区五区 | 亚洲精品无码人妻无码 | 清纯唯美经典一区二区 | 精品国产一区二区三区av 性色 | 在线观看国产一区二区三区 | 少妇性l交大片 | 亚洲综合另类小说色区 | 成人精品视频一区二区 | 性史性农村dvd毛片 | 国产真实乱对白精彩久久 | √天堂中文官网8在线 | 久久国产精品偷任你爽任你 | 成人精品天堂一区二区三区 | 国产午夜亚洲精品不卡下载 | 欧美一区二区三区视频在线观看 | 成 人 免费观看网站 | 少女韩国电视剧在线观看完整 | 欧美色就是色 | 国产成人人人97超碰超爽8 | 无码精品国产va在线观看dvd | 亚洲国产高清在线观看视频 | 熟妇人妻中文av无码 | 亚洲 高清 成人 动漫 | 蜜桃视频韩日免费播放 | 国产真实伦对白全集 | 99国产精品白浆在线观看免费 | 窝窝午夜理论片影院 | 亚洲国产精华液网站w | 无码一区二区三区在线观看 | 国产精品亚洲专区无码不卡 | 女人被爽到呻吟gif动态图视看 | 国产性生交xxxxx无码 | 永久黄网站色视频免费直播 | 少妇无码av无码专区在线观看 | 俺去俺来也在线www色官网 | 国产色视频一区二区三区 | 国产无遮挡吃胸膜奶免费看 | 在线观看免费人成视频 | av在线亚洲欧洲日产一区二区 | 欧美日韩综合一区二区三区 | 人人妻人人澡人人爽欧美精品 | 亚洲日韩av一区二区三区四区 | 久久久久亚洲精品男人的天堂 | а√天堂www在线天堂小说 | 国产亚洲精品久久久久久久久动漫 | 亚洲精品国产a久久久久久 | 日本xxxx色视频在线观看免费 | 精品 日韩 国产 欧美 视频 | 99国产精品白浆在线观看免费 | 国产区女主播在线观看 | 67194成是人免费无码 | 成人性做爰aaa片免费看 | 国产精品美女久久久久av爽李琼 | 亚洲欧美日韩成人高清在线一区 | 精品国产国产综合精品 | 夜精品a片一区二区三区无码白浆 | 色婷婷香蕉在线一区二区 | 婷婷色婷婷开心五月四房播播 | 国产真实伦对白全集 | 成人无码精品一区二区三区 | 又大又硬又爽免费视频 | 国产亚洲精品久久久久久大师 | 久久精品丝袜高跟鞋 | 精品久久久久久人妻无码中文字幕 | 亚洲 另类 在线 欧美 制服 | 亚洲中文字幕成人无码 | 理论片87福利理论电影 | 亚洲va欧美va天堂v国产综合 | 欧美老人巨大xxxx做受 | 久久久av男人的天堂 | 亚洲人亚洲人成电影网站色 | 国产超碰人人爽人人做人人添 | 国产无遮挡又黄又爽又色 | 亚洲天堂2017无码中文 | 日本熟妇乱子伦xxxx | 欧美性生交活xxxxxdddd | 国产精品对白交换视频 | 久久久久久a亚洲欧洲av冫 | 人人澡人人妻人人爽人人蜜桃 | 中文字幕人妻无码一区二区三区 | 色婷婷香蕉在线一区二区 | 人人妻人人澡人人爽欧美精品 | 亚洲成a人一区二区三区 | 美女极度色诱视频国产 | 丰满少妇高潮惨叫视频 | 动漫av一区二区在线观看 | 99精品视频在线观看免费 | 亚洲中文字幕无码中文字在线 | 对白脏话肉麻粗话av | 日韩精品成人一区二区三区 | 成人欧美一区二区三区 | 无遮无挡爽爽免费视频 | 欧美老人巨大xxxx做受 | 日本丰满熟妇videos | 久久人人爽人人爽人人片ⅴ | 亚洲成熟女人毛毛耸耸多 | 粉嫩少妇内射浓精videos | 97久久国产亚洲精品超碰热 | 亚洲七七久久桃花影院 | 国产美女精品一区二区三区 | 国产亚洲精品久久久久久 | 日本乱人伦片中文三区 | 精品久久久无码中文字幕 | 成在人线av无码免观看麻豆 | 白嫩日本少妇做爰 | 久久人人爽人人人人片 | 高清无码午夜福利视频 | 亚洲另类伦春色综合小说 | 强奷人妻日本中文字幕 | 久久久精品欧美一区二区免费 | 久久久久久久人妻无码中文字幕爆 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 在线看片无码永久免费视频 | 国产精品国产自线拍免费软件 | 久久 国产 尿 小便 嘘嘘 | 狠狠cao日日穞夜夜穞av | 国产人妻大战黑人第1集 | 欧美色就是色 | 夫妻免费无码v看片 | 国产精品久久久久久无码 | 99精品久久毛片a片 | 国产亚洲日韩欧美另类第八页 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 日韩av激情在线观看 | 亚洲男人av天堂午夜在 | 国产精品久久久久影院嫩草 | 在线播放无码字幕亚洲 | 蜜桃无码一区二区三区 | 中文无码伦av中文字幕 | 国内老熟妇对白xxxxhd | 精品国产乱码久久久久乱码 | 少妇一晚三次一区二区三区 | 国产农村乱对白刺激视频 | 一二三四在线观看免费视频 | 丁香啪啪综合成人亚洲 | 秋霞成人午夜鲁丝一区二区三区 | www国产精品内射老师 | 成 人影片 免费观看 | 国产激情无码一区二区app | 波多野结衣av一区二区全免费观看 | 亚洲成av人片在线观看无码不卡 | 牲欲强的熟妇农村老妇女视频 | 欧美精品一区二区精品久久 | 国产 浪潮av性色四虎 | 少妇无套内谢久久久久 | 亚洲精品国产a久久久久久 | 18禁止看的免费污网站 | 久久人人爽人人爽人人片av高清 | 国产亚洲精品久久久闺蜜 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 无码人妻av免费一区二区三区 | 无码av岛国片在线播放 | 国产激情无码一区二区app | 亚洲精品成人av在线 | 国产又粗又硬又大爽黄老大爷视 | 国内老熟妇对白xxxxhd | 中文字幕乱码中文乱码51精品 | 牛和人交xxxx欧美 | 老熟女乱子伦 | 天天爽夜夜爽夜夜爽 | 亚洲 激情 小说 另类 欧美 | av人摸人人人澡人人超碰下载 | 中文字幕无码免费久久99 | 欧美日本日韩 | 成人一区二区免费视频 | 中国女人内谢69xxxx | 国产亚洲精品久久久久久 | 国内精品人妻无码久久久影院蜜桃 | 精品久久8x国产免费观看 | 亚洲精品国产第一综合99久久 | 亚洲成av人在线观看网址 | 婷婷丁香六月激情综合啪 | 3d动漫精品啪啪一区二区中 | 久久午夜夜伦鲁鲁片无码免费 | 少妇人妻偷人精品无码视频 | 强开小婷嫩苞又嫩又紧视频 | 扒开双腿吃奶呻吟做受视频 | 小泽玛莉亚一区二区视频在线 | 亚洲成av人片天堂网无码】 | 久久精品女人的天堂av | 日本乱偷人妻中文字幕 | 啦啦啦www在线观看免费视频 | 少妇无码一区二区二三区 | 真人与拘做受免费视频一 | 国产婷婷色一区二区三区在线 | 亚洲国产精品一区二区第一页 | 欧美人与善在线com | 日本爽爽爽爽爽爽在线观看免 | 亚洲一区av无码专区在线观看 | 亚洲春色在线视频 | 中文字幕色婷婷在线视频 | 精品aⅴ一区二区三区 | 色窝窝无码一区二区三区色欲 | 亚洲熟女一区二区三区 | 国产乱人伦av在线无码 | 久久99精品国产麻豆蜜芽 | 午夜熟女插插xx免费视频 | 久久熟妇人妻午夜寂寞影院 | 2020久久超碰国产精品最新 | 国内揄拍国内精品人妻 | 88国产精品欧美一区二区三区 | 国语精品一区二区三区 | 黑人巨大精品欧美一区二区 | 美女张开腿让人桶 | 日本熟妇乱子伦xxxx | 亚洲精品国产精品乱码不卡 | 国产精品久久久久久无码 | 国产综合久久久久鬼色 | 国精产品一区二区三区 | 久久综合香蕉国产蜜臀av | 久久精品女人的天堂av | 国产精品亚洲一区二区三区喷水 | 在线观看免费人成视频 | 精品国产精品久久一区免费式 | 午夜福利电影 | 久久精品国产亚洲精品 | 日韩av无码一区二区三区 | 色婷婷综合中文久久一本 | 亚洲成av人综合在线观看 | 四十如虎的丰满熟妇啪啪 | 狠狠综合久久久久综合网 | 国产精品久久国产精品99 | 国产精品无码成人午夜电影 | 97久久精品无码一区二区 | 精品亚洲成av人在线观看 | 亚洲欧美综合区丁香五月小说 | 亚洲精品国产精品乱码不卡 | 性史性农村dvd毛片 | 一本久道久久综合狠狠爱 | 国产乱人伦av在线无码 | 人人妻人人澡人人爽欧美一区 | 狠狠躁日日躁夜夜躁2020 | 国产欧美精品一区二区三区 | 亚洲日本va午夜在线电影 | 国产精品久久久久久无码 | 午夜精品久久久久久久久 | v一区无码内射国产 | 全球成人中文在线 | 午夜精品久久久内射近拍高清 | 宝宝好涨水快流出来免费视频 | 蜜桃视频韩日免费播放 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 4hu四虎永久在线观看 | 国产无遮挡又黄又爽免费视频 | 国产真实乱对白精彩久久 | 成人免费视频视频在线观看 免费 | 色欲人妻aaaaaaa无码 | 国产无遮挡吃胸膜奶免费看 | 精品乱码久久久久久久 | 欧美日韩视频无码一区二区三 | 丰满岳乱妇在线观看中字无码 | 麻豆果冻传媒2021精品传媒一区下载 | 国产两女互慰高潮视频在线观看 | 亚洲乱码中文字幕在线 | 牲欲强的熟妇农村老妇女视频 | 亚洲の无码国产の无码步美 | 欧美日韩在线亚洲综合国产人 | 天天拍夜夜添久久精品大 | 国产办公室秘书无码精品99 | 国产97色在线 | 免 | 国产亚洲日韩欧美另类第八页 | 久久国产精品萌白酱免费 | 亚洲精品综合五月久久小说 | 亚洲一区av无码专区在线观看 | 中文字幕 亚洲精品 第1页 | 在线观看国产午夜福利片 | 久青草影院在线观看国产 | 少妇性荡欲午夜性开放视频剧场 | 国产高清不卡无码视频 | 日日橹狠狠爱欧美视频 | 黑人巨大精品欧美黑寡妇 | 精品国产av色一区二区深夜久久 | 青青久在线视频免费观看 | 高潮毛片无遮挡高清免费 | 欧美性生交活xxxxxdddd | 免费无码的av片在线观看 | 国产精品鲁鲁鲁 | 国产精品毛多多水多 | 国产亚洲精品久久久久久久久动漫 | 天堂а√在线中文在线 | 九九在线中文字幕无码 | 亚洲欧美日韩成人高清在线一区 | 国产成人午夜福利在线播放 | 婷婷综合久久中文字幕蜜桃三电影 | 久久五月精品中文字幕 | 亚洲综合无码久久精品综合 | 俺去俺来也www色官网 | 中文字幕无码av激情不卡 | 日本一卡二卡不卡视频查询 | 日韩精品无码免费一区二区三区 | 日日麻批免费40分钟无码 | 男女性色大片免费网站 | 麻豆国产人妻欲求不满谁演的 | 国产午夜亚洲精品不卡 | 搡女人真爽免费视频大全 | 波多野结衣av一区二区全免费观看 | 蜜臀av在线播放 久久综合激激的五月天 | 国产精品久久久久久久影院 | 久久精品国产一区二区三区肥胖 | 无码人妻久久一区二区三区不卡 | 中文无码伦av中文字幕 | 国产成人无码午夜视频在线观看 | 国内精品九九久久久精品 | 女人被爽到呻吟gif动态图视看 | 日本一卡2卡3卡四卡精品网站 | 内射欧美老妇wbb | 波多野结衣av在线观看 | 亚洲国产精品久久久天堂 | 亚洲性无码av中文字幕 | 国产成人综合美国十次 | 久久亚洲中文字幕精品一区 | 精品国产av色一区二区深夜久久 | 蜜臀av无码人妻精品 | 精品一区二区不卡无码av | 白嫩日本少妇做爰 | 无码人妻精品一区二区三区不卡 | 精品国产av色一区二区深夜久久 | 夜先锋av资源网站 | 狠狠色丁香久久婷婷综合五月 | 99麻豆久久久国产精品免费 | 在线欧美精品一区二区三区 | 国产内射老熟女aaaa | 亚洲成av人片天堂网无码】 | 亚洲一区av无码专区在线观看 | 俄罗斯老熟妇色xxxx | 日韩在线不卡免费视频一区 | 婷婷五月综合激情中文字幕 | 中文字幕无码av激情不卡 | 老熟妇乱子伦牲交视频 | 中国女人内谢69xxxx | 香港三级日本三级妇三级 | 波多野结衣乳巨码无在线观看 | 97久久精品无码一区二区 | 免费看男女做好爽好硬视频 | 国精品人妻无码一区二区三区蜜柚 | 亚洲の无码国产の无码影院 | 亚洲一区av无码专区在线观看 | 性生交大片免费看女人按摩摩 | 国产精品办公室沙发 | 精品久久久久久人妻无码中文字幕 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产一区二区三区影院 | 国产成人精品视频ⅴa片软件竹菊 | 377p欧洲日本亚洲大胆 | 色婷婷av一区二区三区之红樱桃 | 无码人妻精品一区二区三区下载 | 2019午夜福利不卡片在线 | 曰韩少妇内射免费播放 | 国产精品igao视频网 | 丝袜 中出 制服 人妻 美腿 | 成人三级无码视频在线观看 | 成人欧美一区二区三区黑人 | 国产精品久久久午夜夜伦鲁鲁 | 熟女俱乐部五十路六十路av | 免费无码一区二区三区蜜桃大 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 久久久久成人精品免费播放动漫 | 久久久久久久人妻无码中文字幕爆 | 国产精品久久久久无码av色戒 | 永久免费观看国产裸体美女 | 欧美激情内射喷水高潮 | 亚洲呦女专区 | 国产av人人夜夜澡人人爽麻豆 | 九九久久精品国产免费看小说 | 欧美兽交xxxx×视频 | 国产精品99久久精品爆乳 | 色综合视频一区二区三区 | 免费无码av一区二区 | 亚洲国产精品无码一区二区三区 | 图片小说视频一区二区 | 中文字幕无码av波多野吉衣 | 夜夜夜高潮夜夜爽夜夜爰爰 | 精品午夜福利在线观看 | 日本精品久久久久中文字幕 | www成人国产高清内射 | 欧美熟妇另类久久久久久多毛 | 国语精品一区二区三区 | 国产精品成人av在线观看 | 中文字幕 人妻熟女 | 亚洲色偷偷男人的天堂 | 天天拍夜夜添久久精品 | 中文字幕无码人妻少妇免费 | 精品日本一区二区三区在线观看 | 国产女主播喷水视频在线观看 | 无码人妻精品一区二区三区下载 | 亚洲国产精品无码久久久久高潮 | www国产亚洲精品久久久日本 | 欧美亚洲国产一区二区三区 | 红桃av一区二区三区在线无码av | 色综合久久久久综合一本到桃花网 | 亚洲欧美色中文字幕在线 | 国产精品沙发午睡系列 | 丰满少妇高潮惨叫视频 | 欧美自拍另类欧美综合图片区 | 欧美放荡的少妇 | 婷婷丁香五月天综合东京热 | 女人高潮内射99精品 | 亚洲国产欧美日韩精品一区二区三区 | 中国女人内谢69xxxx | 婷婷丁香六月激情综合啪 | 色老头在线一区二区三区 | 又大又紧又粉嫩18p少妇 | 秋霞特色aa大片 | 少妇性l交大片 | 99久久久无码国产精品免费 | 中文无码伦av中文字幕 | 精品无码av一区二区三区 | 午夜福利试看120秒体验区 | 77777熟女视频在线观看 а天堂中文在线官网 | 女高中生第一次破苞av | 夜夜夜高潮夜夜爽夜夜爰爰 | 久久综合狠狠综合久久综合88 | 国产香蕉97碰碰久久人人 | 3d动漫精品啪啪一区二区中 | 欧美国产日产一区二区 | 久久精品人人做人人综合 | 2019nv天堂香蕉在线观看 | 乱人伦中文视频在线观看 | 国产精品.xx视频.xxtv | 亚洲自偷精品视频自拍 | 无码人妻久久一区二区三区不卡 | 伊人久久大香线焦av综合影院 | 在线播放免费人成毛片乱码 | 免费看男女做好爽好硬视频 | 亚洲の无码国产の无码影院 | 成人试看120秒体验区 | 精品国产一区二区三区av 性色 | 国产精品久久久久久久9999 | 性色欲网站人妻丰满中文久久不卡 | 大地资源中文第3页 | 女人被男人躁得好爽免费视频 | 亚洲精品一区二区三区在线观看 | 亚洲精品www久久久 | 天天爽夜夜爽夜夜爽 | 樱花草在线社区www | 国产av无码专区亚洲a∨毛片 | a在线亚洲男人的天堂 | 亚洲成av人综合在线观看 | 国产精品久久久久9999小说 | 午夜无码区在线观看 | 精品一区二区三区波多野结衣 | 伦伦影院午夜理论片 | 内射老妇bbwx0c0ck | 蜜桃臀无码内射一区二区三区 | 鲁大师影院在线观看 | 天天爽夜夜爽夜夜爽 | 久久久久久九九精品久 | 亚洲熟妇色xxxxx欧美老妇y | 欧美人与动性行为视频 | 波多野结衣乳巨码无在线观看 | 亚洲区欧美区综合区自拍区 | 中文字幕乱码中文乱码51精品 | 亚洲精品国产a久久久久久 | 强伦人妻一区二区三区视频18 | 乌克兰少妇xxxx做受 | 国产精品久久久午夜夜伦鲁鲁 | 欧美一区二区三区视频在线观看 | 在线观看免费人成视频 | 一区二区三区乱码在线 | 欧洲 | 午夜男女很黄的视频 | 伊人久久大香线蕉亚洲 | 噜噜噜亚洲色成人网站 | 日韩视频 中文字幕 视频一区 | 亚洲一区二区三区在线观看网站 | 国产精品美女久久久网av | 久久无码人妻影院 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲欧美日韩国产精品一区二区 | 精品久久8x国产免费观看 | 亚洲日韩av一区二区三区中文 | 免费无码一区二区三区蜜桃大 | 图片小说视频一区二区 | 狠狠综合久久久久综合网 | 小泽玛莉亚一区二区视频在线 | 日本饥渴人妻欲求不满 | 天天摸天天透天天添 | 久久久中文久久久无码 | 国产亚洲精品久久久ai换 | 亚欧洲精品在线视频免费观看 | 亚洲一区av无码专区在线观看 | 粗大的内捧猛烈进出视频 | 又粗又大又硬毛片免费看 | 麻豆av传媒蜜桃天美传媒 | 国产在热线精品视频 | 久青草影院在线观看国产 | 99久久精品无码一区二区毛片 | 精品乱码久久久久久久 | 免费无码av一区二区 | 国产精品亚洲а∨无码播放麻豆 | 精品国产一区二区三区av 性色 | 国产尤物精品视频 | 荫蒂被男人添的好舒服爽免费视频 | 捆绑白丝粉色jk震动捧喷白浆 | 国产内射爽爽大片视频社区在线 | 少妇性l交大片 | 人妻无码久久精品人妻 | 综合人妻久久一区二区精品 | 理论片87福利理论电影 | 日本一区二区三区免费高清 | 人妻互换免费中文字幕 | 成人亚洲精品久久久久软件 | 国产亚洲日韩欧美另类第八页 | 精品无人区无码乱码毛片国产 | 久久99精品久久久久婷婷 | 波多野结衣 黑人 | 国产免费观看黄av片 | 日本大香伊一区二区三区 | 色窝窝无码一区二区三区色欲 | 高潮毛片无遮挡高清免费视频 | 欧洲极品少妇 | 精品无码国产一区二区三区av | 无码人妻丰满熟妇区五十路百度 | 精品久久8x国产免费观看 | 日韩精品成人一区二区三区 | 亚洲色大成网站www | 国产网红无码精品视频 | 精品厕所偷拍各类美女tp嘘嘘 | 日韩精品无码免费一区二区三区 | 日日摸夜夜摸狠狠摸婷婷 | 精品少妇爆乳无码av无码专区 | 国产真人无遮挡作爱免费视频 | 99麻豆久久久国产精品免费 | 日韩人妻系列无码专区 | 欧美激情内射喷水高潮 | 欧美丰满老熟妇xxxxx性 | 一二三四在线观看免费视频 | 亚洲精品国产品国语在线观看 | 久激情内射婷内射蜜桃人妖 | 久久无码专区国产精品s | 久精品国产欧美亚洲色aⅴ大片 | 丰腴饱满的极品熟妇 | 日本欧美一区二区三区乱码 | 人人妻人人澡人人爽欧美一区九九 | 搡女人真爽免费视频大全 | 妺妺窝人体色www婷婷 | 精品国产av色一区二区深夜久久 | 美女扒开屁股让男人桶 | 桃花色综合影院 | 六十路熟妇乱子伦 | 久久久久国色av免费观看性色 | 麻豆国产97在线 | 欧洲 | 亚洲经典千人经典日产 | 亚欧洲精品在线视频免费观看 | 亚洲精品国产品国语在线观看 | 人人妻在人人 | 日韩欧美成人免费观看 | 亚洲国产精品久久人人爱 | 熟妇人妻无乱码中文字幕 | 在线视频网站www色 | 日本乱人伦片中文三区 | 狂野欧美性猛xxxx乱大交 | 狂野欧美性猛xxxx乱大交 | 国产麻豆精品精东影业av网站 | 日本熟妇浓毛 | 国产av一区二区精品久久凹凸 | 免费网站看v片在线18禁无码 | 亚洲日本va午夜在线电影 | 国产香蕉尹人视频在线 | 精品久久久无码人妻字幂 | 强伦人妻一区二区三区视频18 | 玩弄中年熟妇正在播放 | 国产无av码在线观看 | 无码av岛国片在线播放 | av无码不卡在线观看免费 | 中文字幕无码免费久久9一区9 | 一本久久a久久精品vr综合 | 狠狠综合久久久久综合网 | 亚洲国产综合无码一区 | 欧洲极品少妇 | 纯爱无遮挡h肉动漫在线播放 | 亚洲性无码av中文字幕 | 无码精品国产va在线观看dvd | 国产精品无套呻吟在线 | 人人妻人人藻人人爽欧美一区 | 纯爱无遮挡h肉动漫在线播放 | 国色天香社区在线视频 | 日韩av无码一区二区三区 | 精品一区二区三区波多野结衣 | 日本一区二区三区免费播放 | 日韩av无码中文无码电影 | 中文字幕乱码人妻二区三区 | 国内精品久久久久久中文字幕 | 亚洲无人区午夜福利码高清完整版 | 国产亚洲精品久久久ai换 | 国产成人av免费观看 | 亚洲а∨天堂久久精品2021 | 人人妻人人澡人人爽人人精品 | 在教室伦流澡到高潮hnp视频 | 久久人人爽人人爽人人片av高清 | 小鲜肉自慰网站xnxx | 亚洲精品午夜国产va久久成人 | 内射欧美老妇wbb | 日韩成人一区二区三区在线观看 | 18禁止看的免费污网站 | 久久午夜无码鲁丝片 | 国产口爆吞精在线视频 | 亚洲无人区午夜福利码高清完整版 | 老熟妇仑乱视频一区二区 | 丰满护士巨好爽好大乳 | 国产成人无码a区在线观看视频app | 中文字幕中文有码在线 | 久久人妻内射无码一区三区 | 女高中生第一次破苞av | 精品国产乱码久久久久乱码 | 亚洲区欧美区综合区自拍区 | 久久综合久久自在自线精品自 | 欧美成人高清在线播放 | 欧美亚洲日韩国产人成在线播放 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 久久五月精品中文字幕 | 女高中生第一次破苞av | 丝袜 中出 制服 人妻 美腿 | 捆绑白丝粉色jk震动捧喷白浆 | 熟妇女人妻丰满少妇中文字幕 | 久久五月精品中文字幕 | 无码人妻黑人中文字幕 | 桃花色综合影院 | 天天躁日日躁狠狠躁免费麻豆 | 久久精品中文字幕一区 | 丝袜美腿亚洲一区二区 | 任你躁国产自任一区二区三区 | 综合网日日天干夜夜久久 | 老子影院午夜精品无码 | 亚洲精品一区二区三区大桥未久 | av人摸人人人澡人人超碰下载 | 亚洲国产精品成人久久蜜臀 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产精品久久久久久亚洲毛片 | 学生妹亚洲一区二区 | 妺妺窝人体色www婷婷 | 狠狠噜狠狠狠狠丁香五月 | 国产色在线 | 国产 | 男人的天堂2018无码 | 亚洲国产精品一区二区美利坚 | 欧美大屁股xxxxhd黑色 | 国产精品久久久久7777 | 欧美肥老太牲交大战 | 妺妺窝人体色www在线小说 | 亚洲成av人片在线观看无码不卡 | 亚洲国产精华液网站w | 日本大香伊一区二区三区 | 精品无码一区二区三区的天堂 | 好爽又高潮了毛片免费下载 | 丁香花在线影院观看在线播放 | 精品国产成人一区二区三区 | 一本色道久久综合亚洲精品不卡 | 国产精品igao视频网 | 亚洲成a人片在线观看日本 | 国产女主播喷水视频在线观看 | 俺去俺来也www色官网 | 国产超级va在线观看视频 | 国产精品视频免费播放 | 国产黑色丝袜在线播放 | 任你躁国产自任一区二区三区 | 亚洲区小说区激情区图片区 | 亚洲国产精品一区二区第一页 | 国产亚洲精品精品国产亚洲综合 | 国产成人精品一区二区在线小狼 | 亚洲小说图区综合在线 | 麻豆国产丝袜白领秘书在线观看 | 国产无遮挡吃胸膜奶免费看 | 国产真人无遮挡作爱免费视频 | 无遮无挡爽爽免费视频 | 成人欧美一区二区三区黑人 | 成人一在线视频日韩国产 | 欧美精品无码一区二区三区 | 久久综合久久自在自线精品自 | 啦啦啦www在线观看免费视频 | 国产精品va在线观看无码 | 国内丰满熟女出轨videos | 激情综合激情五月俺也去 | 国产亚洲人成在线播放 | 亚洲精品国产精品乱码不卡 | 少妇高潮喷潮久久久影院 | 国产成人精品一区二区在线小狼 | 少妇太爽了在线观看 | 精品无人区无码乱码毛片国产 | 国产 精品 自在自线 | 2020久久香蕉国产线看观看 | 少妇性荡欲午夜性开放视频剧场 | 香港三级日本三级妇三级 | 久久精品中文闷骚内射 | 日本免费一区二区三区最新 | 国产精品无套呻吟在线 | 国产精品对白交换视频 | 久久精品中文闷骚内射 | 在线а√天堂中文官网 | 丰满少妇高潮惨叫视频 | 极品尤物被啪到呻吟喷水 | 天天综合网天天综合色 | 色欲综合久久中文字幕网 | 国产综合久久久久鬼色 | 精品国偷自产在线视频 | 少妇高潮喷潮久久久影院 | 综合人妻久久一区二区精品 | 亚洲欧洲无卡二区视頻 | 国产成人综合色在线观看网站 | 国产绳艺sm调教室论坛 | 日韩少妇内射免费播放 | 亚洲 欧美 激情 小说 另类 | 亚洲 日韩 欧美 成人 在线观看 | 欧美日韩视频无码一区二区三 | 粉嫩少妇内射浓精videos | 久久国内精品自在自线 | 欧美午夜特黄aaaaaa片 | 天下第一社区视频www日本 | 波多野结衣av一区二区全免费观看 | 欧美放荡的少妇 | 久久久久久久女国产乱让韩 | 亚洲欧美中文字幕5发布 | 波多野结衣av一区二区全免费观看 | 国产成人综合色在线观看网站 | 在线亚洲高清揄拍自拍一品区 | 99久久人妻精品免费一区 | 久久久成人毛片无码 | 国产亚洲精品久久久久久国模美 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 伊人久久大香线焦av综合影院 | 久久国产精品二国产精品 | a在线亚洲男人的天堂 | 日韩少妇内射免费播放 | 日本欧美一区二区三区乱码 | 欧美日韩一区二区综合 | 欧美日韩一区二区三区自拍 | 国产免费久久久久久无码 | 无码午夜成人1000部免费视频 | 沈阳熟女露脸对白视频 | 日韩精品一区二区av在线 | 欧美激情一区二区三区成人 | 国产又粗又硬又大爽黄老大爷视 | 国产国产精品人在线视 | 国产成人综合美国十次 | 国精品人妻无码一区二区三区蜜柚 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 亚洲日韩av一区二区三区中文 | 午夜理论片yy44880影院 | 女人高潮内射99精品 | 秋霞成人午夜鲁丝一区二区三区 | 精品无码成人片一区二区98 | 国产在线精品一区二区三区直播 | 丰满少妇弄高潮了www | 亚洲の无码国产の无码影院 | 亚洲男人av香蕉爽爽爽爽 | 成人三级无码视频在线观看 | 丝袜美腿亚洲一区二区 | 色综合久久88色综合天天 | 高清不卡一区二区三区 | 国产精品第一区揄拍无码 | 国产综合久久久久鬼色 | √8天堂资源地址中文在线 | 国产内射爽爽大片视频社区在线 | 亚洲精品国偷拍自产在线麻豆 | 丰满少妇高潮惨叫视频 | 正在播放东北夫妻内射 | 日日天日日夜日日摸 | 国产成人无码av片在线观看不卡 | 无码帝国www无码专区色综合 | 成人欧美一区二区三区 | 久久久久成人片免费观看蜜芽 | 欧美精品无码一区二区三区 | 男女性色大片免费网站 | 伦伦影院午夜理论片 | 国产特级毛片aaaaaa高潮流水 | 无码国模国产在线观看 | 国产激情一区二区三区 | 性生交大片免费看l | 蜜臀av在线播放 久久综合激激的五月天 | 欧美国产日韩亚洲中文 | 国产亚洲视频中文字幕97精品 | 日本护士xxxxhd少妇 | 东京热男人av天堂 | 久激情内射婷内射蜜桃人妖 | 亚洲性无码av中文字幕 | 激情亚洲一区国产精品 | 欧美日韩在线亚洲综合国产人 | 日本爽爽爽爽爽爽在线观看免 | 免费国产黄网站在线观看 | 久久午夜无码鲁丝片 | 7777奇米四色成人眼影 | 欧美放荡的少妇 | 色一情一乱一伦 | 人人妻人人澡人人爽人人精品浪潮 | 成人免费视频视频在线观看 免费 | 一二三四社区在线中文视频 | 亚洲欧美国产精品久久 | 亚洲精品综合五月久久小说 | 伊人久久婷婷五月综合97色 | 精品亚洲韩国一区二区三区 | 青青青手机频在线观看 | 亚洲熟妇色xxxxx欧美老妇 | 国产99久久精品一区二区 | 久久久久人妻一区精品色欧美 | 亚洲国产成人av在线观看 | 亚洲综合精品香蕉久久网 | 九月婷婷人人澡人人添人人爽 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 在线亚洲高清揄拍自拍一品区 | 久久无码中文字幕免费影院蜜桃 | 中文字幕无码人妻少妇免费 | 无码人妻丰满熟妇区毛片18 | 国产人妻大战黑人第1集 | 老头边吃奶边弄进去呻吟 | 人人妻人人藻人人爽欧美一区 | 亚洲综合伊人久久大杳蕉 | 九月婷婷人人澡人人添人人爽 | 国产无套粉嫩白浆在线 | 亚洲熟悉妇女xxx妇女av | 成 人 网 站国产免费观看 | 国产精品久久久久7777 | 国产69精品久久久久app下载 | 娇妻被黑人粗大高潮白浆 | 国产无套粉嫩白浆在线 | 国产手机在线αⅴ片无码观看 | 亚洲日本一区二区三区在线 | 色婷婷av一区二区三区之红樱桃 | 无码吃奶揉捏奶头高潮视频 | 欧美三级a做爰在线观看 | a国产一区二区免费入口 | 麻豆人妻少妇精品无码专区 | 国内精品人妻无码久久久影院 | 丁香花在线影院观看在线播放 | 国产av久久久久精东av | 国内综合精品午夜久久资源 | 夜先锋av资源网站 | 男女下面进入的视频免费午夜 | 一本色道久久综合亚洲精品不卡 | 国产精品第一区揄拍无码 | 精品无码国产自产拍在线观看蜜 | 中文字幕亚洲情99在线 | 在线观看国产一区二区三区 | 久久99久久99精品中文字幕 | 国产成人无码区免费内射一片色欲 | 国产激情无码一区二区app | 人人妻人人澡人人爽人人精品浪潮 | 欧美日韩一区二区三区自拍 | 高清国产亚洲精品自在久久 | 小泽玛莉亚一区二区视频在线 | 99久久精品日本一区二区免费 | 性啪啪chinese东北女人 | 国产特级毛片aaaaaaa高清 | 曰本女人与公拘交酡免费视频 | 国产亚洲欧美在线专区 | 久久午夜无码鲁丝片午夜精品 | 粗大的内捧猛烈进出视频 | 真人与拘做受免费视频一 | 在线天堂新版最新版在线8 | 亚洲 高清 成人 动漫 | 中文毛片无遮挡高清免费 | 好男人www社区 | 久久伊人色av天堂九九小黄鸭 | 国产偷抇久久精品a片69 | 99久久久国产精品无码免费 | 国产av一区二区三区最新精品 | 亚洲午夜久久久影院 | 久久久久久久久888 | 国产人妻精品一区二区三区不卡 | 国产精品久久久久7777 | 国产成人一区二区三区别 | 国产成人无码av片在线观看不卡 | 久久亚洲日韩精品一区二区三区 | 1000部啪啪未满十八勿入下载 | 亚洲欧美日韩国产精品一区二区 | 国产激情无码一区二区app | 精品偷拍一区二区三区在线看 | 国产人妖乱国产精品人妖 | 曰韩无码二三区中文字幕 | 亚洲无人区一区二区三区 | 日本欧美一区二区三区乱码 | 亚洲人成网站免费播放 | 久久国语露脸国产精品电影 | 妺妺窝人体色www婷婷 | 久久亚洲精品中文字幕无男同 | 激情五月综合色婷婷一区二区 | 动漫av网站免费观看 | 国产精品美女久久久 | 99久久久无码国产精品免费 | 免费人成在线视频无码 | 67194成是人免费无码 | 中文字幕av伊人av无码av | 无码人妻丰满熟妇区五十路百度 | 精品国产一区二区三区四区在线看 | 国产在线无码精品电影网 | 亚洲成av人影院在线观看 | 婷婷丁香五月天综合东京热 | 奇米影视7777久久精品 | 国产卡一卡二卡三 | 亚洲高清偷拍一区二区三区 | 天堂在线观看www | 99精品国产综合久久久久五月天 | 亚洲区小说区激情区图片区 | 精品人人妻人人澡人人爽人人 | 亚洲の无码国产の无码影院 | 成人免费无码大片a毛片 | 内射爽无广熟女亚洲 | 日产精品高潮呻吟av久久 | 国产精品多人p群无码 | 中文字幕日产无线码一区 | 无码人妻丰满熟妇区毛片18 | 国产精品国产三级国产专播 | 国产人妻久久精品二区三区老狼 | 亚洲日韩乱码中文无码蜜桃臀网站 | 成在人线av无码免费 | 最近免费中文字幕中文高清百度 | 中文久久乱码一区二区 | 国产午夜福利100集发布 | 欧美日韩色另类综合 | 欧美性猛交内射兽交老熟妇 | 55夜色66夜色国产精品视频 | 亚洲va中文字幕无码久久不卡 | 国产电影无码午夜在线播放 | 亚洲一区二区观看播放 | 欧美日韩人成综合在线播放 | 亚洲精品一区三区三区在线观看 | 欧美高清在线精品一区 | 欧美真人作爱免费视频 | 午夜福利不卡在线视频 | 国产精品美女久久久 | 无码一区二区三区在线 | 亚洲理论电影在线观看 | 久久久国产一区二区三区 | 东京无码熟妇人妻av在线网址 | 久久精品女人天堂av免费观看 | 免费男性肉肉影院 | 国产精品久久国产三级国 | 鲁大师影院在线观看 | 亚洲人亚洲人成电影网站色 | 狂野欧美激情性xxxx | 人妻人人添人妻人人爱 | 久久精品人人做人人综合试看 | 亚洲国产日韩a在线播放 | 国产艳妇av在线观看果冻传媒 | 小sao货水好多真紧h无码视频 | 国产午夜亚洲精品不卡 | 大肉大捧一进一出好爽视频 | 中文字幕色婷婷在线视频 | 久久五月精品中文字幕 | 中文字幕无码人妻少妇免费 | 中文字幕人成乱码熟女app | 97精品国产97久久久久久免费 | 青青草原综合久久大伊人精品 | 男女下面进入的视频免费午夜 | 无码av岛国片在线播放 | 亚洲人成人无码网www国产 | 国产凸凹视频一区二区 | 丰满少妇人妻久久久久久 | 日欧一片内射va在线影院 | 久久精品女人天堂av免费观看 | 亚洲gv猛男gv无码男同 | 97精品国产97久久久久久免费 | 亚洲一区二区三区含羞草 | 性欧美大战久久久久久久 | 国产黑色丝袜在线播放 | 人人爽人人澡人人高潮 | 国产亚洲精品久久久久久国模美 | 精品久久久久久人妻无码中文字幕 | 亚洲欧美国产精品专区久久 | 东京热男人av天堂 | 国产精品18久久久久久麻辣 | 日日摸夜夜摸狠狠摸婷婷 | 久久精品女人的天堂av | 少妇性荡欲午夜性开放视频剧场 | 玩弄中年熟妇正在播放 | 久久精品女人天堂av免费观看 | 国产香蕉97碰碰久久人人 | 无码免费一区二区三区 | 亚洲 高清 成人 动漫 | 国产精品久免费的黄网站 | 国产卡一卡二卡三 | 亚洲另类伦春色综合小说 | 日本一区二区更新不卡 | 亚洲熟妇色xxxxx欧美老妇 | 国产又爽又猛又粗的视频a片 | 成在人线av无码免费 | 亚洲日本va午夜在线电影 | 男女猛烈xx00免费视频试看 | 一本久道久久综合婷婷五月 | 男人和女人高潮免费网站 | 亚洲欧洲中文日韩av乱码 | 欧美一区二区三区 | 曰本女人与公拘交酡免费视频 | 日韩人妻无码中文字幕视频 | 婷婷综合久久中文字幕蜜桃三电影 | 精品国产一区二区三区av 性色 | 人妻天天爽夜夜爽一区二区 | 婷婷综合久久中文字幕蜜桃三电影 | 国产午夜亚洲精品不卡下载 | 免费国产成人高清在线观看网站 | 亚洲gv猛男gv无码男同 | 男人扒开女人内裤强吻桶进去 | 性做久久久久久久久 | 国产卡一卡二卡三 | 国模大胆一区二区三区 | 国产精品鲁鲁鲁 | 欧洲精品码一区二区三区免费看 | 国产农村乱对白刺激视频 | √8天堂资源地址中文在线 | 98国产精品综合一区二区三区 | 乱人伦人妻中文字幕无码 | 亚洲小说图区综合在线 | 久久久亚洲欧洲日产国码αv | 国产精品高潮呻吟av久久4虎 | 日韩人妻少妇一区二区三区 | 久久99精品久久久久久动态图 | 乱人伦人妻中文字幕无码 | 国产国产精品人在线视 | 亚洲中文字幕在线观看 | 夜先锋av资源网站 | 狠狠噜狠狠狠狠丁香五月 | 丁香花在线影院观看在线播放 | 国产精品欧美成人 | 丰满肥臀大屁股熟妇激情视频 | 亚洲自偷精品视频自拍 | 中文亚洲成a人片在线观看 | 一本久道久久综合狠狠爱 | 曰韩无码二三区中文字幕 | 久久综合给久久狠狠97色 | 亚洲精品美女久久久久久久 | 亚洲精品综合一区二区三区在线 | 亚洲综合在线一区二区三区 | 久久久精品欧美一区二区免费 | 久久久www成人免费毛片 | 日韩在线不卡免费视频一区 | 欧美 丝袜 自拍 制服 另类 | 国产精品久久国产三级国 | 性开放的女人aaa片 | 蜜桃av抽搐高潮一区二区 | 香港三级日本三级妇三级 | aⅴ亚洲 日韩 色 图网站 播放 | 牛和人交xxxx欧美 | 久久精品国产精品国产精品污 | 麻豆国产97在线 | 欧洲 | 亚洲一区二区三区在线观看网站 | 亚洲国产精品美女久久久久 | 中文字幕无线码免费人妻 | 日韩欧美中文字幕公布 | 红桃av一区二区三区在线无码av | 久久久久久国产精品无码下载 | 无码人妻黑人中文字幕 | 亚洲热妇无码av在线播放 | 色窝窝无码一区二区三区色欲 | 久久精品女人的天堂av | 亚洲精品国产精品乱码不卡 | 狠狠cao日日穞夜夜穞av | 噜噜噜亚洲色成人网站 | 亚洲熟熟妇xxxx | 欧美三级不卡在线观看 | 欧美日韩亚洲国产精品 | 成人试看120秒体验区 | 国产精品鲁鲁鲁 | 亚洲精品久久久久avwww潮水 | 国产区女主播在线观看 | 亚洲成熟女人毛毛耸耸多 | 亚洲а∨天堂久久精品2021 | 国产手机在线αⅴ片无码观看 | 亚洲日韩av一区二区三区四区 | 清纯唯美经典一区二区 | 国产精品国产三级国产专播 | 纯爱无遮挡h肉动漫在线播放 | 麻豆国产97在线 | 欧洲 | 乱中年女人伦av三区 | 成熟妇人a片免费看网站 | √8天堂资源地址中文在线 | 亚洲精品综合五月久久小说 | 麻豆成人精品国产免费 | 无码乱肉视频免费大全合集 | 97精品国产97久久久久久免费 | 欧美激情一区二区三区成人 | 成 人影片 免费观看 | 亚洲自偷精品视频自拍 | 国产成人综合在线女婷五月99播放 | 国产麻豆精品一区二区三区v视界 | 国产 浪潮av性色四虎 | 久久99精品久久久久久 | 蜜臀aⅴ国产精品久久久国产老师 | 久久久久久久人妻无码中文字幕爆 | 国产热a欧美热a在线视频 | 日本熟妇浓毛 | 国产精品99久久精品爆乳 | 日日麻批免费40分钟无码 | 中文无码成人免费视频在线观看 | 亚洲精品国产a久久久久久 | 色爱情人网站 | 少妇被黑人到高潮喷出白浆 | 少妇无码av无码专区在线观看 | 精品亚洲成av人在线观看 | 亚洲一区二区三区含羞草 | 日本精品人妻无码免费大全 | 国产人妻精品一区二区三区不卡 | 国产激情综合五月久久 | 精品亚洲韩国一区二区三区 | 少妇激情av一区二区 | 奇米影视7777久久精品人人爽 | 内射欧美老妇wbb | 欧美老人巨大xxxx做受 | 欧美刺激性大交 | 欧美亚洲国产一区二区三区 | 成人无码视频免费播放 | 午夜福利试看120秒体验区 | 精品成在人线av无码免费看 | 欧美精品在线观看 | 国产情侣作爱视频免费观看 | 2019午夜福利不卡片在线 | 熟女体下毛毛黑森林 | 野外少妇愉情中文字幕 | 捆绑白丝粉色jk震动捧喷白浆 | 桃花色综合影院 | 中文字幕无码免费久久99 | 精品国偷自产在线视频 | 亚洲人成网站色7799 | 无码成人精品区在线观看 | 色综合久久久无码网中文 | 国内少妇偷人精品视频免费 | 88国产精品欧美一区二区三区 | 国产又爽又黄又刺激的视频 | 色偷偷人人澡人人爽人人模 | 日韩精品无码一本二本三本色 | 99久久人妻精品免费一区 | 久久精品国产99久久6动漫 | 一本久道高清无码视频 | 亚洲综合另类小说色区 | 无码一区二区三区在线观看 | 又粗又大又硬毛片免费看 | 在线播放免费人成毛片乱码 | 久久午夜无码鲁丝片午夜精品 | www国产精品内射老师 | 久久久久久av无码免费看大片 | 国产乱人伦av在线无码 | 国产精品亚洲а∨无码播放麻豆 | 精品一区二区三区无码免费视频 | 噜噜噜亚洲色成人网站 | 婷婷五月综合缴情在线视频 | 国产精品久久久一区二区三区 | 欧美 日韩 亚洲 在线 | 亚洲男人av天堂午夜在 | 国产乱子伦视频在线播放 | 国产精品美女久久久网av | 国产精品久久久久久无码 | 国产猛烈高潮尖叫视频免费 | 精品一区二区三区无码免费视频 | 亚洲午夜无码久久 | 成人女人看片免费视频放人 | 国产精品久久久久9999小说 | 中文字幕无码av波多野吉衣 | 日日摸日日碰夜夜爽av | 亚洲区欧美区综合区自拍区 | 国产一区二区三区精品视频 | 国产舌乚八伦偷品w中 | 狠狠色噜噜狠狠狠7777奇米 | 久久久久亚洲精品男人的天堂 | 欧美自拍另类欧美综合图片区 | 国产精品高潮呻吟av久久4虎 | 熟女少妇人妻中文字幕 | 国产综合在线观看 | 国产精品无码一区二区桃花视频 | 国产凸凹视频一区二区 | 亚洲国产精华液网站w | 又大又硬又黄的免费视频 | 成人aaa片一区国产精品 | 成人片黄网站色大片免费观看 | 99久久人妻精品免费一区 | 老太婆性杂交欧美肥老太 | 天下第一社区视频www日本 | 久久久久成人精品免费播放动漫 | 捆绑白丝粉色jk震动捧喷白浆 | 人人超人人超碰超国产 | 欧美 日韩 亚洲 在线 | 国产9 9在线 | 中文 | 国产精品va在线播放 | 亚洲国产精品无码一区二区三区 | 2019午夜福利不卡片在线 | 狠狠cao日日穞夜夜穞av | 亚洲国产精品美女久久久久 | 精品无码国产自产拍在线观看蜜 | 亚洲日本va午夜在线电影 | 中文字幕无码人妻少妇免费 | 无码任你躁久久久久久久 | 日韩成人一区二区三区在线观看 | 国产人妖乱国产精品人妖 | 亚洲人成影院在线观看 | 国产在线aaa片一区二区99 | 成 人 免费观看网站 | 亚洲国产精品一区二区第一页 | 精品久久8x国产免费观看 | 正在播放东北夫妻内射 | 波多野结衣一区二区三区av免费 | 久久久久久久久888 | 日日摸天天摸爽爽狠狠97 | 大肉大捧一进一出好爽视频 | 亚洲日本一区二区三区在线 | 中文无码成人免费视频在线观看 | 狠狠色丁香久久婷婷综合五月 | 中文字幕av无码一区二区三区电影 | www国产亚洲精品久久网站 | 久久久精品国产sm最大网站 | 国产精品福利视频导航 | 日本高清一区免费中文视频 | 国产后入清纯学生妹 | 亚洲国产精华液网站w | 兔费看少妇性l交大片免费 | 久久久久久av无码免费看大片 | 成人性做爰aaa片免费看 | 久久综合九色综合欧美狠狠 | 狂野欧美性猛xxxx乱大交 | 特大黑人娇小亚洲女 | 秋霞成人午夜鲁丝一区二区三区 | 欧洲美熟女乱又伦 | 久久久久国色av免费观看性色 | 午夜精品一区二区三区的区别 | 性欧美牲交xxxxx视频 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产午夜福利100集发布 | 国产在线精品一区二区三区直播 | 九九久久精品国产免费看小说 | 蜜臀aⅴ国产精品久久久国产老师 | 无码一区二区三区在线 | 在教室伦流澡到高潮hnp视频 | 成熟妇人a片免费看网站 | 国产精品二区一区二区aⅴ污介绍 | 久久人人爽人人爽人人片av高清 | 99久久精品午夜一区二区 | 国产精品人人妻人人爽 | 少妇无码av无码专区在线观看 | 日本护士毛茸茸高潮 | 好屌草这里只有精品 | 精品偷自拍另类在线观看 | 无码乱肉视频免费大全合集 | 无码av免费一区二区三区试看 | 大地资源中文第3页 | 色综合天天综合狠狠爱 | 亚洲中文字幕在线无码一区二区 | 亚洲国产av精品一区二区蜜芽 | 免费视频欧美无人区码 | 欧美日韩在线亚洲综合国产人 | 国产一区二区不卡老阿姨 | 理论片87福利理论电影 | 老太婆性杂交欧美肥老太 | 久久精品国产99久久6动漫 | 国产精品爱久久久久久久 | 中文字幕亚洲情99在线 | 欧美性色19p | 人妻少妇精品视频专区 | 欧美日本精品一区二区三区 | 大肉大捧一进一出视频出来呀 | 久精品国产欧美亚洲色aⅴ大片 | 男女作爱免费网站 | 成人亚洲精品久久久久软件 | 无遮无挡爽爽免费视频 | 丁香花在线影院观看在线播放 | 人人妻人人澡人人爽人人精品 | 18禁黄网站男男禁片免费观看 | 日本熟妇浓毛 | 国产97色在线 | 免 | 久久精品无码一区二区三区 | 色婷婷久久一区二区三区麻豆 | 少妇性l交大片欧洲热妇乱xxx | 亚洲第一无码av无码专区 | 精品成在人线av无码免费看 | 婷婷丁香五月天综合东京热 | 日本熟妇大屁股人妻 | 熟女少妇人妻中文字幕 | 人妻少妇精品无码专区二区 | 免费看男女做好爽好硬视频 | 午夜福利电影 | 无码精品人妻一区二区三区av | 国产一区二区不卡老阿姨 | 国产又爽又黄又刺激的视频 | 亚洲色大成网站www国产 | 国产口爆吞精在线视频 | 亚洲色成人中文字幕网站 | 成年美女黄网站色大免费全看 | 色老头在线一区二区三区 | 欧美日韩精品 | 精品国产一区二区三区av 性色 | 少妇厨房愉情理9仑片视频 | 日日麻批免费40分钟无码 | 午夜性刺激在线视频免费 | 人人妻人人澡人人爽人人精品 | 久久精品一区二区三区四区 | 久久伊人色av天堂九九小黄鸭 | 在教室伦流澡到高潮hnp视频 | 波多野结衣aⅴ在线 | 久久久久久九九精品久 | 草草网站影院白丝内射 | 无码国产色欲xxxxx视频 | 无码播放一区二区三区 | 亚洲理论电影在线观看 | 亚洲精品一区国产 | 国产香蕉尹人综合在线观看 | 无码人妻精品一区二区三区下载 | 国产一区二区三区日韩精品 | 亚洲欧美日韩国产精品一区二区 | 理论片87福利理论电影 | 日韩精品a片一区二区三区妖精 | 中文字幕日韩精品一区二区三区 | 粗大的内捧猛烈进出视频 | 无码人妻少妇伦在线电影 | 色欲人妻aaaaaaa无码 | 精品夜夜澡人妻无码av蜜桃 | 亚洲狠狠婷婷综合久久 | 99久久人妻精品免费二区 | 欧美老人巨大xxxx做受 | 精品偷自拍另类在线观看 | 5858s亚洲色大成网站www | 国产 精品 自在自线 | 亚洲 激情 小说 另类 欧美 | 日韩精品a片一区二区三区妖精 | 午夜理论片yy44880影院 | 国产明星裸体无码xxxx视频 | 青青草原综合久久大伊人精品 | 97久久精品无码一区二区 | 正在播放老肥熟妇露脸 | 成人欧美一区二区三区 | 一本一道久久综合久久 | 日本www一道久久久免费榴莲 | 无码乱肉视频免费大全合集 | 久久久久久国产精品无码下载 | 露脸叫床粗话东北少妇 | 巨爆乳无码视频在线观看 | 丰满护士巨好爽好大乳 | 99久久婷婷国产综合精品青草免费 | 日本乱人伦片中文三区 | 久久亚洲精品成人无码 | 国产热a欧美热a在线视频 | 正在播放东北夫妻内射 | 日本在线高清不卡免费播放 | 丰满少妇高潮惨叫视频 | 国产在线aaa片一区二区99 | 无码福利日韩神码福利片 | 内射爽无广熟女亚洲 | 欧美 日韩 人妻 高清 中文 | 99精品国产综合久久久久五月天 | 日韩欧美成人免费观看 | 精品国产青草久久久久福利 | 久在线观看福利视频 | 又湿又紧又大又爽a视频国产 | 一本无码人妻在中文字幕免费 | 久久 国产 尿 小便 嘘嘘 | 久久久久免费看成人影片 | 日韩av无码一区二区三区 | 丰满人妻精品国产99aⅴ | 性开放的女人aaa片 | 福利一区二区三区视频在线观看 | 女人和拘做爰正片视频 | 中文字幕无码免费久久9一区9 | 欧洲熟妇色 欧美 | 一二三四在线观看免费视频 | 网友自拍区视频精品 |