久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

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

javascript

Spring全家桶面试真题

發(fā)布時(shí)間:2023/12/19 javascript 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring全家桶面试真题 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

    • 1. Spring Boot
        • 1.1 說說你對(duì)Spring Boot的理解
        • 1.2 Spring Boot Starter有什么用?
        • 1.3 介紹Spring Boot的啟動(dòng)流程
        • 1.4 Spring Boot項(xiàng)目是如何導(dǎo)入包的?
        • 1.5 請(qǐng)描述Spring Boot自動(dòng)裝配的過程
        • 1.6 說說你對(duì)Spring Boot注解的了解
    • 2. Spring
        • 2.1 請(qǐng)你說說Spring的核心是什么
        • 2.2 說一說你對(duì)Spring容器的了解
        • 2.3 說一說你對(duì)BeanFactory的了解
        • 2.4 說一說你對(duì)Spring IOC的理解
        • 2.5 Spring是如何管理Bean的?
        • 2.6 介紹Bean的作用域
        • 2.7 說一說Bean的生命周期
        • 2.8 Spring是怎么解決循環(huán)依賴的?
        • 2.9 @Autowired和@Resource注解有什么區(qū)別?
        • 2.10 Spring中默認(rèn)提供的單例是線程安全的嗎?
        • 2.11 說一說你對(duì)Spring AOP的理解
        • 2.12 請(qǐng)你說說AOP的應(yīng)用場景
        • 2.13 Spring AOP不能對(duì)哪些類進(jìn)行增強(qiáng)?
        • 2.14 JDK動(dòng)態(tài)代理和CGLIB有什么區(qū)別?
        • 2.15 既然有沒有接口都可以用CGLIB,為什么Spring還要使用JDK動(dòng)態(tài)代理?
        • 2.16 Spring如何管理事務(wù)?
        • 2.17 Spring的事務(wù)傳播方式有哪些?
        • 2.18 Spring的事務(wù)如何配置,常用注解有哪些?
        • 2.19 說一說你對(duì)聲明式事務(wù)的理解
    • 3. Spring MVC
        • 3.1 什么是MVC?
        • 3.2 DAO層是做什么的?
        • 3.3 介紹一下Spring MVC的執(zhí)行流程
        • 3.4 說一說你知道的Spring MVC注解
        • 3.5 介紹一下Spring MVC的攔截器
        • 3.6 怎么去做請(qǐng)求攔截?
    • 4. MyBatis
        • 4.1 談?wù)凪yBatis和JPA的區(qū)別
        • 4.2 MyBatis輸入輸出支持的類型有哪些?
        • 4.3 MyBatis里如何實(shí)現(xiàn)一對(duì)多關(guān)聯(lián)查詢?
        • 4.4 MyBatis中的$和#有什么區(qū)別?
        • 4.5 既然不安全,為什么還需要?什么時(shí)候會(huì)用到它?
        • 4.6 MyBatis的xml文件和Mapper接口是怎么綁定的?
        • 4.7 MyBatis分頁和自己寫的分頁哪個(gè)效率高?
        • 4.8 了解MyBatis緩存機(jī)制嗎?
    • 5. 其他
        • 5.1 cookie和session的區(qū)別是什么?
        • 5.2 cookie和session各自適合的場景是什么?
        • 5.3 請(qǐng)介紹session的工作原理
        • 5.4 get請(qǐng)求與post請(qǐng)求有什么區(qū)別?
        • 5.5 get請(qǐng)求的參數(shù)能放到body里面嗎?
        • 5.6 post不冪等是為什么?
        • 5.7 頁面報(bào)400錯(cuò)誤是什么意思?
        • 5.8 請(qǐng)求數(shù)據(jù)出現(xiàn)亂碼該怎么處理?
        • 5.9 如何在SpringBoot框架下實(shí)現(xiàn)一個(gè)定時(shí)任務(wù)?
        • 5.10 調(diào)用接口時(shí)要記錄日志,該怎么設(shè)計(jì)?
        • 5.11 了解Spring Boot JPA嗎?
        • 5.7 頁面報(bào)400錯(cuò)誤是什么意思?
        • 5.8 請(qǐng)求數(shù)據(jù)出現(xiàn)亂碼該怎么處理?
        • 5.9 如何在SpringBoot框架下實(shí)現(xiàn)一個(gè)定時(shí)任務(wù)?
        • 5.10 調(diào)用接口時(shí)要記錄日志,該怎么設(shè)計(jì)?
        • 5.11 了解Spring Boot JPA嗎?

1. Spring Boot

1.1 說說你對(duì)Spring Boot的理解

參考答案

從本質(zhì)上來說,Spring Boot就是Spring,它做了那些沒有它你自己也會(huì)去做的Spring Bean配置。Spring Boot使用“習(xí)慣優(yōu)于配置”的理念讓你的項(xiàng)目快速地運(yùn)行起來,使用Spring Boot很容易創(chuàng)建一個(gè)能獨(dú)立運(yùn)行、準(zhǔn)生產(chǎn)級(jí)別、基于Spring框架的項(xiàng)目,使用Spring Boot你可以不用或者只需要很少的Spring配置。

簡而言之,Spring Boot本身并不提供Spring的核心功能,而是作為Spring的腳手架框架,以達(dá)到快速構(gòu)建項(xiàng)目、預(yù)置三方配置、開箱即用的目的。Spring Boot有如下的優(yōu)點(diǎn):

  • 可以快速構(gòu)建項(xiàng)目;
  • 可以對(duì)主流開發(fā)框架的無配置集成;
  • 項(xiàng)目可獨(dú)立運(yùn)行,無需外部依賴Servlet容器;
  • 提供運(yùn)行時(shí)的應(yīng)用監(jiān)控;
  • 可以極大地提高開發(fā)、部署效率;
  • 可以與云計(jì)算天然集成。

1.2 Spring Boot Starter有什么用?

參考答案

Spring Boot通過提供眾多起步依賴(Starter)降低項(xiàng)目依賴的復(fù)雜度。起步依賴本質(zhì)上是一個(gè)Maven項(xiàng)目對(duì)象模型(Project Object Model, POM),定義了對(duì)其他庫的傳遞依賴,這些東西加在一起即支持某項(xiàng)功能。很多起步依賴的命名都暗示了它們提供的某種或某類功能。

舉例來說,你打算把這個(gè)閱讀列表應(yīng)用程序做成一個(gè)Web應(yīng)用程序。與其向項(xiàng)目的構(gòu)建文件里添加一堆單獨(dú)的庫依賴,還不如聲明這是一個(gè)Web應(yīng)用程序來得簡單。你只要添加Spring Boot的Web起步依賴就好了。

1.3 介紹Spring Boot的啟動(dòng)流程

參考答案

首先,Spring Boot項(xiàng)目創(chuàng)建完成會(huì)默認(rèn)生成一個(gè)名為 *Application 的入口類,我們是通過該類的main方法啟動(dòng)Spring Boot項(xiàng)目的。在main方法中,通過SpringApplication的靜態(tài)方法,即run方法進(jìn)行SpringApplication類的實(shí)例化操作,然后再針對(duì)實(shí)例化對(duì)象調(diào)用另外一個(gè)run方法來完成整個(gè)項(xiàng)目的初始化和啟動(dòng)。

SpringApplication調(diào)用的run方法的大致流程,如下圖:

其中,SpringApplication在run方法中重點(diǎn)做了以下操作:

  • 獲取監(jiān)聽器和參數(shù)配置;
  • 打印Banner信息;
  • 創(chuàng)建并初始化容器;
  • 監(jiān)聽器發(fā)送通知。

當(dāng)然,除了上述核心操作,run方法運(yùn)行過程中還涉及啟動(dòng)時(shí)長統(tǒng)計(jì)、異常報(bào)告、啟動(dòng)日志、異常處理等輔助操作。比較完整的流程,可以參考如下源代碼:

public ConfigurableApplicationContext run(String... args) {// 創(chuàng)建StopWatch對(duì)象,用于統(tǒng)計(jì)run方法啟動(dòng)時(shí)長。StopWatch stopWatch = new StopWatch();// 啟動(dòng)統(tǒng)計(jì)stopWatch.start();ConfigurableApplicationContext context = null;Collection<SpringBootExceptionReporter> exceptionReporters = new ArrayList<>();// 配置Headless屬性configureHeadlessProperty();// 獲得SpringApplicationRunListener數(shù)組,// 該數(shù)組封裝于SpringApplicationRunListeners對(duì)象的listeners中。SpringApplicationRunListeners listeners = getRunListeners(args);// 啟動(dòng)監(jiān)聽,遍歷SpringApplicationRunListener數(shù)組每個(gè)元素,并執(zhí)行。listeners.starting();try {// 創(chuàng)建ApplicationArguments對(duì)象ApplicationArguments applicationArguments = new DefaultApplicationArguments(args);// 加載屬性配置,包括所有的配置屬性。ConfigurableEnvironment environment = prepareEnvironment(listeners, applicationArguments);configureIgnoreBeanInfo(environment);// 打印BannerBanner printedBanner = printBanner(environment);// 創(chuàng)建容器context = createApplicationContext();// 異常報(bào)告器exceptionReporters = getSpringFactoriesInstances(SpringBootExceptionReporter.class,new Class[] { ConfigurableApplicationContext.class }, context);// 準(zhǔn)備容器,組件對(duì)象之間進(jìn)行關(guān)聯(lián)。prepareContext(context, environment, listeners, applicationArguments, printedBanner);// 初始化容器refreshContext(context);// 初始化操作之后執(zhí)行,默認(rèn)實(shí)現(xiàn)為空。afterRefresh(context, applicationArguments);// 停止時(shí)長統(tǒng)計(jì)stopWatch.stop();// 打印啟動(dòng)日志if (this.logStartupInfo) {new StartupInfoLogger(this.mainApplicationClass).logStarted(getApplicationLog(), stopWatch);}// 通知監(jiān)聽器:容器完成啟動(dòng)。listeners.started(context);// 調(diào)用ApplicationRunner和CommandLineRunner的運(yùn)行方法。callRunners(context, applicationArguments);} catch (Throwable ex) {// 異常處理handleRunFailure(context, ex, exceptionReporters, listeners);throw new IllegalStateException(ex);}try {// 通知監(jiān)聽器:容器正在運(yùn)行。listeners.running(context);} catch (Throwable ex) {// 異常處理handleRunFailure(context, ex, exceptionReporters, null);throw new IllegalStateException(ex);}return context; }

1.4 Spring Boot項(xiàng)目是如何導(dǎo)入包的?

參考答案

通過Spring Boot Starter導(dǎo)入包。

Spring Boot通過提供眾多起步依賴(Starter)降低項(xiàng)目依賴的復(fù)雜度。起步依賴本質(zhì)上是一個(gè)Maven項(xiàng)目對(duì)象模型(Project Object Model, POM),定義了對(duì)其他庫的傳遞依賴,這些東西加在一起即支持某項(xiàng)功能。很多起步依賴的命名都暗示了它們提供的某種或某類功能。

舉例來說,你打算把這個(gè)閱讀列表應(yīng)用程序做成一個(gè)Web應(yīng)用程序。與其向項(xiàng)目的構(gòu)建文件里添加一堆單獨(dú)的庫依賴,還不如聲明這是一個(gè)Web應(yīng)用程序來得簡單。你只要添加Spring Boot的Web起步依賴就好了。

1.5 請(qǐng)描述Spring Boot自動(dòng)裝配的過程

參考答案

使用Spring Boot時(shí),我們只需引入對(duì)應(yīng)的Starters,Spring Boot啟動(dòng)時(shí)便會(huì)自動(dòng)加載相關(guān)依賴,配置相應(yīng)的初始化參數(shù),以最快捷、簡單的形式對(duì)第三方軟件進(jìn)行集成,這便是Spring Boot的自動(dòng)配置功能。Spring Boot實(shí)現(xiàn)該運(yùn)作機(jī)制鎖涉及的核心部分如下圖所示:

整個(gè)自動(dòng)裝配的過程是:Spring Boot通過@EnableAutoConfiguration注解開啟自動(dòng)配置,加載spring.factories中注冊(cè)的各種AutoConfiguration類,當(dāng)某個(gè)AutoConfiguration類滿足其注解@Conditional指定的生效條件(Starters提供的依賴、配置或Spring容器中是否存在某個(gè)Bean等)時(shí),實(shí)例化該AutoConfiguration類中定義的Bean(組件等),并注入Spring容器,就可以完成依賴框架的自動(dòng)配置。

1.6 說說你對(duì)Spring Boot注解的了解

參考答案

@SpringBootApplication注解:

在Spring Boot入口類中,唯一的一個(gè)注解就是@SpringBootApplication。它是Spring Boot項(xiàng)目的核心注解,用于開啟自動(dòng)配置,準(zhǔn)確說是通過該注解內(nèi)組合的@EnableAutoConfiguration開啟了自動(dòng)配置。

@EnableAutoConfiguration注解:

@EnableAutoConfiguration的主要功能是啟動(dòng)Spring應(yīng)用程序上下文時(shí)進(jìn)行自動(dòng)配置,它會(huì)嘗試猜測并配置項(xiàng)目可能需要的Bean。自動(dòng)配置通常是基于項(xiàng)目classpath中引入的類和已定義的Bean來實(shí)現(xiàn)的。在此過程中,被自動(dòng)配置的組件來自項(xiàng)目自身和項(xiàng)目依賴的jar包中。

@Import注解:

@EnableAutoConfiguration的關(guān)鍵功能是通過@Import注解導(dǎo)入的ImportSelector來完成的。從源代碼得知@Import(AutoConfigurationImportSelector.class)是@EnableAutoConfiguration注解的組成部分,也是自動(dòng)配置功能的核心實(shí)現(xiàn)者。

@Conditional注解:

@Conditional注解是由Spring 4.0版本引入的新特性,可根據(jù)是否滿足指定的條件來決定是否進(jìn)行Bean的實(shí)例化及裝配,比如,設(shè)定當(dāng)類路徑下包含某個(gè)jar包的時(shí)候才會(huì)對(duì)注解的類進(jìn)行實(shí)例化操作。總之,就是根據(jù)一些特定條件來控制Bean實(shí)例化的行為。

@Conditional衍生注解:

在Spring Boot的autoconfigure項(xiàng)目中提供了各類基于@Conditional注解的衍生注解,它們適用不同的場景并提供了不同的功能。通過閱讀這些注解的源碼,你會(huì)發(fā)現(xiàn)它們其實(shí)都組合了@Conditional注解,不同之處是它們?cè)谧⒔庵兄付ǖ臈l件(Condition)不同。

  • @ConditionalOnBean:在容器中有指定Bean的條件下。
  • @ConditionalOnClass:在classpath類路徑下有指定類的條件下。
  • @ConditionalOnCloudPlatform:當(dāng)指定的云平臺(tái)處于active狀態(tài)時(shí)。
  • @ConditionalOnExpression:基于SpEL表達(dá)式的條件判斷。
  • @ConditionalOnJava:基于JVM版本作為判斷條件。
  • @ConditionalOnJndi:在JNDI存在的條件下查找指定的位置。
  • @ConditionalOnMissingBean:當(dāng)容器里沒有指定Bean的條件時(shí)。
  • @ConditionalOnMissingClass:當(dāng)類路徑下沒有指定類的條件時(shí)。
  • @ConditionalOnNotWebApplication:在項(xiàng)目不是一個(gè)Web項(xiàng)目的條件下。
  • @ConditionalOnProperty:在指定的屬性有指定值的條件下。
  • @ConditionalOnResource:類路徑是否有指定的值。
  • @ConditionalOnSingleCandidate:當(dāng)指定的Bean在容器中只有一個(gè)或者有多個(gè)但是指定了首選的Bean時(shí)。
  • @ConditionalOnWebApplication:在項(xiàng)目是一個(gè)Web項(xiàng)目的條件下。

2. Spring

2.1 請(qǐng)你說說Spring的核心是什么

參考答案

Spring框架包含眾多模塊,如Core、Testing、Data Access、Web Servlet等,其中Core是整個(gè)Spring框架的核心模塊。Core模塊提供了IoC容器、AOP功能、數(shù)據(jù)綁定、類型轉(zhuǎn)換等一系列的基礎(chǔ)功能,而這些功能以及其他模塊的功能都是建立在IoC和AOP之上的,所以IoC和AOP是Spring框架的核心。

IoC(Inversion of Control)是控制反轉(zhuǎn)的意思,這是一種面向?qū)ο缶幊痰脑O(shè)計(jì)思想。在不采用這種思想的情況下,我們需要自己維護(hù)對(duì)象與對(duì)象之間的依賴關(guān)系,很容易造成對(duì)象之間的耦合度過高,在一個(gè)大型的項(xiàng)目中這十分的不利于代碼的維護(hù)。IoC則可以解決這種問題,它可以幫我們維護(hù)對(duì)象與對(duì)象之間的依賴關(guān)系,降低對(duì)象之間的耦合度。

說到IoC就不得不說DI(Dependency Injection),DI是依賴注入的意思,它是IoC實(shí)現(xiàn)的實(shí)現(xiàn)方式,就是說IoC是通過DI來實(shí)現(xiàn)的。由于IoC這個(gè)詞匯比較抽象而DI卻更直觀,所以很多時(shí)候我們就用DI來代替它,在很多時(shí)候我們簡單地將IoC和DI劃等號(hào),這是一種習(xí)慣。而實(shí)現(xiàn)依賴注入的關(guān)鍵是IoC容器,它的本質(zhì)就是一個(gè)工廠。

AOP(Aspect Oriented Programing)是面向切面編程思想,這種思想是對(duì)OOP的補(bǔ)充,它可以在OOP的基礎(chǔ)上進(jìn)一步提高編程的效率。簡單來說,它可以統(tǒng)一解決一批組件的共性需求(如權(quán)限檢查、記錄日志、事務(wù)管理等)。在AOP思想下,我們可以將解決共性需求的代碼獨(dú)立出來,然后通過配置的方式,聲明這些代碼在什么地方、什么時(shí)機(jī)調(diào)用。當(dāng)滿足調(diào)用條件時(shí),AOP會(huì)將該業(yè)務(wù)代碼織入到我們指定的位置,從而統(tǒng)一解決了問題,又不需要修改這一批組件的代碼。

2.2 說一說你對(duì)Spring容器的了解

參考答案

Spring主要提供了兩種類型的容器:BeanFactory和ApplicationContext。

  • BeanFactory:是基礎(chǔ)類型的IoC容器,提供完整的IoC服務(wù)支持。如果沒有特殊指定,默認(rèn)采用延
    遲初始化策略。只有當(dāng)客戶端對(duì)象需要訪問容器中的某個(gè)受管對(duì)象的時(shí)候,才對(duì)該受管對(duì)象進(jìn)行初始化以及依賴注入操作。所以,相對(duì)來說,容器啟動(dòng)初期速度較快,所需要的資源有限。對(duì)于資源有限,并且功能要求不是很嚴(yán)格的場景,BeanFactory是比較合適的IoC容器選擇。
  • ApplicationContext:它是在BeanFactory的基礎(chǔ)上構(gòu)建的,是相對(duì)比較高級(jí)的容器實(shí)現(xiàn),除了擁有BeanFactory的所有支持,ApplicationContext還提供了其他高級(jí)特性,比如事件發(fā)布、國際化信息支持等。ApplicationContext所管理的對(duì)象,在該類型容器啟動(dòng)之后,默認(rèn)全部初始化并綁定完成。所以,相對(duì)于BeanFactory來說,ApplicationContext要求更多的系統(tǒng)資源,同時(shí),因?yàn)樵趩?dòng)時(shí)就完成所有初始化,容
    器啟動(dòng)時(shí)間較之BeanFactory也會(huì)長一些。在那些系統(tǒng)資源充足,并且要求更多功能的場景中,ApplicationContext類型的容器是比較合適的選擇。

2.3 說一說你對(duì)BeanFactory的了解

參考答案

BeanFactory是一個(gè)類工廠,與傳統(tǒng)類工廠不同的是,BeanFactory是類的通用工廠,它可以創(chuàng)建并管理各種類的對(duì)象。這些可被創(chuàng)建和管理的對(duì)象本身沒有什么特別之處,僅是一個(gè)POJO,Spring稱這些被創(chuàng)建和管理的Java對(duì)象為Bean。并且,Spring中所說的Bean比JavaBean更為寬泛一些,所有可以被Spring容器實(shí)例化并管理的Java類都可以成為Bean。

BeanFactory是Spring容器的頂層接口,Spring為BeanFactory提供了多種實(shí)現(xiàn),最常用的是XmlBeanFactory。但它在Spring 3.2中已被廢棄,建議使用XmlBeanDefinitionReader、DefaultListableBeanFactory替代。BeanFactory最主要的方法就是 getBean(String beanName),該方法從容器中返回特定名稱的Bean。

2.4 說一說你對(duì)Spring IOC的理解

參考答案

IoC(Inversion of Control)是控制反轉(zhuǎn)的意思,這是一種面向?qū)ο缶幊痰脑O(shè)計(jì)思想。在不采用這種思想的情況下,我們需要自己維護(hù)對(duì)象與對(duì)象之間的依賴關(guān)系,很容易造成對(duì)象之間的耦合度過高,在一個(gè)大型的項(xiàng)目中這十分的不利于代碼的維護(hù)。IoC則可以解決這種問題,它可以幫我們維護(hù)對(duì)象與對(duì)象之間的依賴關(guān)系,降低對(duì)象之間的耦合度。

說到IoC就不得不說DI(Dependency Injection),DI是依賴注入的意思,它是IoC實(shí)現(xiàn)的實(shí)現(xiàn)方式,就是說IoC是通過DI來實(shí)現(xiàn)的。由于IoC這個(gè)詞匯比較抽象而DI卻更直觀,所以很多時(shí)候我們就用DI來代替它,在很多時(shí)候我們簡單地將IoC和DI劃等號(hào),這是一種習(xí)慣。而實(shí)現(xiàn)依賴注入的關(guān)鍵是IoC容器,它的本質(zhì)就是一個(gè)工廠。

在具體的實(shí)現(xiàn)中,主要由三種注入方式:

  • 構(gòu)造方法注入

    就是被注入對(duì)象可以在它的構(gòu)造方法中聲明依賴對(duì)象的參數(shù)列表,讓外部知道它需要哪些依賴對(duì)象。然后,IoC Service Provider會(huì)檢查被注入的對(duì)象的構(gòu)造方法,取得它所需要的依賴對(duì)象列表,進(jìn)而為其注入相應(yīng)的對(duì)象。構(gòu)造方法注入方式比較直觀,對(duì)象被構(gòu)造完成后,即進(jìn)入就緒狀態(tài),可以馬上使用。

  • setter方法注入

    通過setter方法,可以更改相應(yīng)的對(duì)象屬性。所以,當(dāng)前對(duì)象只要為其依賴對(duì)象所對(duì)應(yīng)的屬性添加setter方法,就可以通過setter方法將相應(yīng)的依賴對(duì)象設(shè)置到被注入對(duì)象中。setter方法注入雖不像構(gòu)造方法注入那樣,讓對(duì)象構(gòu)造完成后即可使用,但相對(duì)來說更寬松一些,
    可以在對(duì)象構(gòu)造完成后再注入。

  • 接口注入

    相對(duì)于前兩種注入方式來說,接口注入沒有那么簡單明了。被注入對(duì)象如果想要IoC Service Provider為其注入依賴對(duì)象,就必須實(shí)現(xiàn)某個(gè)接口。這個(gè)接口提供一個(gè)方法,用來為其注入依賴對(duì)象。IoC Service Provider最終通過這些接口來了解應(yīng)該為被注入對(duì)象注入什么依賴對(duì)象。相對(duì)于前兩種依賴注入方式,接口注入比較死板和煩瑣。

  • 總體來說,構(gòu)造方法注入和setter方法注入因?yàn)槠淝秩胄暂^弱,且易于理解和使用,所以是現(xiàn)在使用最多的注入方式。而接口注入因?yàn)榍秩胄暂^強(qiáng),近年來已經(jīng)不流行了。

    2.5 Spring是如何管理Bean的?

    參考答案

    Spring通過IoC容器來管理Bean,我們可以通過XML配置或者注解配置,來指導(dǎo)IoC容器對(duì)Bean的管理。因?yàn)樽⒔馀渲帽萖ML配置方便很多,所以現(xiàn)在大多時(shí)候會(huì)使用注解配置的方式。

    以下是管理Bean時(shí)常用的一些注解:

  • @ComponentScan用于聲明掃描策略,通過它的聲明,容器就知道要掃描哪些包下帶有聲明的類,也可以知道哪些特定的類是被排除在外的。
  • @Component、@Repository、@Service、@Controller用于聲明Bean,它們的作用一樣,但是語義不同。@Component用于聲明通用的Bean,@Repository用于聲明DAO層的Bean,@Service用于聲明業(yè)務(wù)層的Bean,@Controller用于聲明視圖層的控制器Bean,被這些注解聲明的類就可以被容器掃描并創(chuàng)建。
  • @Autowired、@Qualifier用于注入Bean,即告訴容器應(yīng)該為當(dāng)前屬性注入哪個(gè)Bean。其中,@Autowired是按照Bean的類型進(jìn)行匹配的,如果這個(gè)屬性的類型具有多個(gè)Bean,就可以通過@Qualifier指定Bean的名稱,以消除歧義。
  • @Scope用于聲明Bean的作用域,默認(rèn)情況下Bean是單例的,即在整個(gè)容器中這個(gè)類型只有一個(gè)實(shí)例。可以通過@Scope注解指定prototype值將其聲明為多例的,也可以將Bean聲明為session級(jí)作用域、request級(jí)作用域等等,但最常用的還是默認(rèn)的單例模式。
  • @PostConstruct、@PreDestroy用于聲明Bean的生命周期。其中,被@PostConstruct修飾的方法將在Bean實(shí)例化后被調(diào)用,@PreDestroy修飾的方法將在容器銷毀前被調(diào)用。
  • 2.6 介紹Bean的作用域

    參考答案

    默認(rèn)情況下,Bean在Spring容器中是單例的,我們可以通過@Scope注解修改Bean的作用域。該注解有如下5個(gè)取值,它們代表了Bean的5種不同類型的作用域:

    2.7 說一說Bean的生命周期

    參考答案

    Spring容器管理Bean,涉及對(duì)Bean的創(chuàng)建、初始化、調(diào)用、銷毀等一系列的流程,這個(gè)流程就是Bean的生命周期。整個(gè)流程參考下圖:

    這個(gè)過程是由Spring容器自動(dòng)管理的,其中有兩個(gè)環(huán)節(jié)我們可以進(jìn)行干預(yù)。

  • 我們可以自定義初始化方法,并在該方法前增加@PostConstruct注解,屆時(shí)Spring容器將在調(diào)用SetBeanFactory方法之后調(diào)用該方法。
  • 我們可以自定義銷毀方法,并在該方法前增加@PreDestroy注解,屆時(shí)Spring容器將在自身銷毀前,調(diào)用這個(gè)方法。
  • 2.8 Spring是怎么解決循環(huán)依賴的?

    參考答案

    首先,需要明確的是spring對(duì)循環(huán)依賴的處理有三種情況:

  • 構(gòu)造器的循環(huán)依賴:這種依賴spring是處理不了的,直接拋出BeanCurrentlylnCreationException異常。
  • 單例模式下的setter循環(huán)依賴:通過“三級(jí)緩存”處理循環(huán)依賴。
  • 非單例循環(huán)依賴:無法處理。
  • 接下來,我們具體看看spring是如何處理第二種循環(huán)依賴的。

    Spring單例對(duì)象的初始化大略分為三步:

  • createBeanInstance:實(shí)例化,其實(shí)也就是調(diào)用對(duì)象的構(gòu)造方法實(shí)例化對(duì)象;
  • populateBean:填充屬性,這一步主要是多bean的依賴屬性進(jìn)行填充;
  • initializeBean:調(diào)用spring xml中的init 方法。
  • 從上面講述的單例bean初始化步驟我們可以知道,循環(huán)依賴主要發(fā)生在第一步、第二步。也就是構(gòu)造器循環(huán)依賴和field循環(huán)依賴。 Spring為了解決單例的循環(huán)依賴問題,使用了三級(jí)緩存。

    /** Cache of singleton objects: bean name –> bean instance */ private final Map singletonObjects = new ConcurrentHashMap(256); /** Cache of singleton factories: bean name –> ObjectFactory */ private final Map> singletonFactories = new HashMap>(16); /** Cache of early singleton objects: bean name –> bean instance */ private final Map earlySingletonObjects = new HashMap(16);

    這三級(jí)緩存的作用分別是:

    • singletonFactories : 進(jìn)入實(shí)例化階段的單例對(duì)象工廠的cache (三級(jí)緩存);
    • earlySingletonObjects :完成實(shí)例化但是尚未初始化的,提前暴光的單例對(duì)象的Cache (二級(jí)緩存);
    • singletonObjects:完成初始化的單例對(duì)象的cache(一級(jí)緩存)。

    我們?cè)趧?chuàng)建bean的時(shí)候,會(huì)首先從cache中獲取這個(gè)bean,這個(gè)緩存就是sigletonObjects。主要的調(diào)用方法是:

    protected Object getSingleton(String beanName, boolean allowEarlyReference) {Object singletonObject = this.singletonObjects.get(beanName);//isSingletonCurrentlyInCreation()判斷當(dāng)前單例bean是否正在創(chuàng)建中if (singletonObject == null && isSingletonCurrentlyInCreation(beanName)) {synchronized (this.singletonObjects) {singletonObject = this.earlySingletonObjects.get(beanName);//allowEarlyReference 是否允許從singletonFactories中通過getObject拿到對(duì)象if (singletonObject == null && allowEarlyReference) {ObjectFactory<?> singletonFactory = this.singletonFactories.get(beanName);if (singletonFactory != null) {singletonObject = singletonFactory.getObject();//從singletonFactories中移除,并放入earlySingletonObjects中。//其實(shí)也就是從三級(jí)緩存移動(dòng)到了二級(jí)緩存this.earlySingletonObjects.put(beanName, singletonObject);this.singletonFactories.remove(beanName);}}}}return (singletonObject != NULL_OBJECT ? singletonObject : null); }

    從上面三級(jí)緩存的分析,我們可以知道,Spring解決循環(huán)依賴的訣竅就在于singletonFactories這個(gè)三級(jí)cache。這個(gè)cache的類型是ObjectFactory,定義如下:

    public interface ObjectFactory<T> {T getObject() throws BeansException; }

    這個(gè)接口在AbstractBeanFactory里實(shí)現(xiàn),并在核心方法doCreateBean()引用下面的方法:

    protected void addSingletonFactory(String beanName, ObjectFactory<?> singletonFactory) {Assert.notNull(singletonFactory, "Singleton factory must not be null");synchronized (this.singletonObjects) {if (!this.singletonObjects.containsKey(beanName)) {this.singletonFactories.put(beanName, singletonFactory);this.earlySingletonObjects.remove(beanName);this.registeredSingletons.add(beanName);}} }

    這段代碼發(fā)生在createBeanInstance之后,populateBean()之前,也就是說單例對(duì)象此時(shí)已經(jīng)被創(chuàng)建出來(調(diào)用了構(gòu)造器)。這個(gè)對(duì)象已經(jīng)被生產(chǎn)出來了,此時(shí)將這個(gè)對(duì)象提前曝光出來,讓大家使用。

    這樣做有什么好處呢?讓我們來分析一下“A的某個(gè)field或者setter依賴了B的實(shí)例對(duì)象,同時(shí)B的某個(gè)field或者setter依賴了A的實(shí)例對(duì)象”這種循環(huán)依賴的情況。A首先完成了初始化的第一步,并且將自己提前曝光到singletonFactories中,此時(shí)進(jìn)行初始化的第二步,發(fā)現(xiàn)自己依賴對(duì)象B,此時(shí)就嘗試去get(B),發(fā)現(xiàn)B還沒有被create,所以走create流程,B在初始化第一步的時(shí)候發(fā)現(xiàn)自己依賴了對(duì)象A,于是嘗試get(A),嘗試一級(jí)緩存singletonObjects(肯定沒有,因?yàn)锳還沒初始化完全),嘗試二級(jí)緩存earlySingletonObjects(也沒有),嘗試三級(jí)緩存singletonFactories,由于A通過ObjectFactory將自己提前曝光了,所以B能夠通過ObjectFactory.getObject拿到A對(duì)象(雖然A還沒有初始化完全,但是總比沒有好呀),B拿到A對(duì)象后順利完成了初始化階段1、2、3,完全初始化之后將自己放入到一級(jí)緩存singletonObjects中。此時(shí)返回A中,A此時(shí)能拿到B的對(duì)象順利完成自己的初始化階段2、3,最終A也完成了初始化,進(jìn)去了一級(jí)緩存singletonObjects中,而且更加幸運(yùn)的是,由于B拿到了A的對(duì)象引用,所以B現(xiàn)在hold住的A對(duì)象完成了初始化。

    2.9 @Autowired和@Resource注解有什么區(qū)別?

    參考答案

  • @Autowired是Spring提供的注解,@Resource是JDK提供的注解。
  • @Autowired是只能按類型注入,@Resource默認(rèn)按名稱注入,也支持按類型注入。
  • @Autowired按類型裝配依賴對(duì)象,默認(rèn)情況下它要求依賴對(duì)象必須存在,如果允許null值,可以設(shè)置它required屬性為false,如果我們想使用按名稱裝配,可以結(jié)合@Qualifier注解一起使用。@Resource有兩個(gè)中重要的屬性:name和type。name屬性指定byName,如果沒有指定name屬性,當(dāng)注解標(biāo)注在字段上,即默認(rèn)取字段的名稱作為bean名稱尋找依賴對(duì)象,當(dāng)注解標(biāo)注在屬性的setter方法上,即默認(rèn)取屬性名作為bean名稱尋找依賴對(duì)象。需要注意的是,@Resource如果沒有指定name屬性,并且按照默認(rèn)的名稱仍然找不到依賴對(duì)象時(shí), @Resource注解會(huì)回退到按類型裝配。但一旦指定了name屬性,就只能按名稱裝配了。
  • 2.10 Spring中默認(rèn)提供的單例是線程安全的嗎?

    參考答案

    不是。

    Spring容器本身并沒有提供Bean的線程安全策略。如果單例的Bean是一個(gè)無狀態(tài)的Bean,即線程中的操作不會(huì)對(duì)Bean的成員執(zhí)行查詢以外的操作,那么這個(gè)單例的Bean是線程安全的。比如,Controller、Service、DAO這樣的組件,通常都是單例且線程安全的。如果單例的Bean是一個(gè)有狀態(tài)的Bean,則可以采用ThreadLocal對(duì)狀態(tài)數(shù)據(jù)做線程隔離,來保證線程安全。

    2.11 說一說你對(duì)Spring AOP的理解

    參考答案

    AOP(Aspect Oriented Programming)是面向切面編程,它是一種編程思想,是面向?qū)ο缶幊?#xff08;OOP)的一種補(bǔ)充。面向?qū)ο缶幊虒⒊绦虺橄蟪筛鱾€(gè)層次的對(duì)象,而面向切面編程是將程序抽象成各個(gè)切面。如下圖,可以很形象地看出,所謂切面,相當(dāng)于應(yīng)用對(duì)象間的橫切點(diǎn),我們可以將其單獨(dú)抽象為單獨(dú)的模塊。

    AOP的術(shù)語:

    • 連接點(diǎn)(join point):對(duì)應(yīng)的是具體被攔截的對(duì)象,因?yàn)镾pring只能支持方法,所以被攔截的對(duì)象往往就是指特定的方法,AOP將通過動(dòng)態(tài)代理技術(shù)把它織入對(duì)應(yīng)的流程中。
    • 切點(diǎn)(point cut):有時(shí)候,我們的切面不單單應(yīng)用于單個(gè)方法,也可能是多個(gè)類的不同方法,這時(shí),可以通過正則式和指示器的規(guī)則去定義,從而適配連接點(diǎn)。切點(diǎn)就是提供這樣一個(gè)功能的概念。
    • 通知(advice):就是按照約定的流程下的方法,分為前置通知、后置通知、環(huán)繞通知、事后返回通知和異常通知,它會(huì)根據(jù)約定織入流程中。
    • 目標(biāo)對(duì)象(target):即被代理對(duì)象。
    • 引入(introduction):是指引入新的類和其方法,增強(qiáng)現(xiàn)有Bean的功能。
    • 織入(weaving):它是一個(gè)通過動(dòng)態(tài)代理技術(shù),為原有服務(wù)對(duì)象生成代理對(duì)象,然后將與切點(diǎn)定義匹配的連接點(diǎn)攔截,并按約定將各類通知織入約定流程的過程。
    • 切面(aspect):是一個(gè)可以定義切點(diǎn)、各類通知和引入的內(nèi)容,SpringAOP將通過它的信息來增強(qiáng)Bean的功能或者將對(duì)應(yīng)的方法織入流程。

    Spring AOP:

    AOP可以有多種實(shí)現(xiàn)方式,而Spring AOP支持如下兩種實(shí)現(xiàn)方式。

    • JDK動(dòng)態(tài)代理:這是Java提供的動(dòng)態(tài)代理技術(shù),可以在運(yùn)行時(shí)創(chuàng)建接口的代理實(shí)例。Spring AOP默認(rèn)采用這種方式,在接口的代理實(shí)例中織入代碼。
    • CGLib動(dòng)態(tài)代理:采用底層的字節(jié)碼技術(shù),在運(yùn)行時(shí)創(chuàng)建子類代理的實(shí)例。當(dāng)目標(biāo)對(duì)象不存在接口時(shí),Spring AOP就會(huì)采用這種方式,在子類實(shí)例中織入代碼。

    2.12 請(qǐng)你說說AOP的應(yīng)用場景

    參考答案

    Spring AOP為IoC的使用提供了更多的便利,一方面,應(yīng)用可以直接使用AOP的功能,設(shè)計(jì)應(yīng)用的橫切關(guān)注點(diǎn),把跨越應(yīng)用程序多個(gè)模塊的功能抽象出來,并通過簡單的AOP的使用,靈活地編制到模塊中,比如可以通過AOP實(shí)現(xiàn)應(yīng)用程序中的日志功能。另一方面,在Spring內(nèi)部,一些支持模塊也是通過Spring AOP來實(shí)現(xiàn)的,比如事務(wù)處理。從這兩個(gè)角度就已經(jīng)可以看到Spring AOP的核心地位了。

    2.13 Spring AOP不能對(duì)哪些類進(jìn)行增強(qiáng)?

    參考答案

  • Spring AOP只能對(duì)IoC容器中的Bean進(jìn)行增強(qiáng),對(duì)于不受容器管理的對(duì)象不能增強(qiáng)。
  • 由于CGLib采用動(dòng)態(tài)創(chuàng)建子類的方式生成代理對(duì)象,所以不能對(duì)final修飾的類進(jìn)行代理。
  • 2.14 JDK動(dòng)態(tài)代理和CGLIB有什么區(qū)別?

    參考答案

    JDK動(dòng)態(tài)代理

    這是Java提供的動(dòng)態(tài)代理技術(shù),可以在運(yùn)行時(shí)創(chuàng)建接口的代理實(shí)例。Spring AOP默認(rèn)采用這種方式,在接口的代理實(shí)例中織入代碼。

    CGLib動(dòng)態(tài)代理

    采用底層的字節(jié)碼技術(shù),在運(yùn)行時(shí)創(chuàng)建子類代理的實(shí)例。當(dāng)目標(biāo)對(duì)象不存在接口時(shí),Spring AOP就會(huì)采用這種方式,在子類實(shí)例中織入代碼。

    2.15 既然有沒有接口都可以用CGLIB,為什么Spring還要使用JDK動(dòng)態(tài)代理?

    參考答案

    在性能方面,CGLib創(chuàng)建的代理對(duì)象比JDK動(dòng)態(tài)代理創(chuàng)建的代理對(duì)象高很多。但是,CGLib在創(chuàng)建代理對(duì)象時(shí)所花費(fèi)的時(shí)間比JDK動(dòng)態(tài)代理多很多。所以,對(duì)于單例的對(duì)象因?yàn)闊o需頻繁創(chuàng)建代理對(duì)象,采用CGLib動(dòng)態(tài)代理比較合適。反之,對(duì)于多例的對(duì)象因?yàn)樾枰l繁的創(chuàng)建代理對(duì)象,則JDK動(dòng)態(tài)代理更合適。

    2.16 Spring如何管理事務(wù)?

    參考答案

    Spring為事務(wù)管理提供了一致的編程模板,在高層次上建立了統(tǒng)一的事務(wù)抽象。也就是說,不管是選擇MyBatis、Hibernate、JPA還是Spring JDBC,Spring都可以讓用戶以統(tǒng)一的編程模型進(jìn)行事務(wù)管理。

    Spring支持兩種事務(wù)編程模型:

  • 編程式事務(wù)

    Spring提供了TransactionTemplate模板,利用該模板我們可以通過編程的方式實(shí)現(xiàn)事務(wù)管理,而無需關(guān)注資源獲取、復(fù)用、釋放、事務(wù)同步及異常處理等操作。相對(duì)于聲明式事務(wù)來說,這種方式相對(duì)麻煩一些,但是好在更為靈活,我們可以將事務(wù)管理的范圍控制的更為精確。

  • 聲明式事務(wù)

    Spring事務(wù)管理的亮點(diǎn)在于聲明式事務(wù)管理,它允許我們通過聲明的方式,在IoC配置中指定事務(wù)的邊界和事務(wù)屬性,Spring會(huì)自動(dòng)在指定的事務(wù)邊界上應(yīng)用事務(wù)屬性。相對(duì)于編程式事務(wù)來說,這種方式十分的方便,只需要在需要做事務(wù)管理的方法上,增加@Transactional注解,以聲明事務(wù)特征即可。

  • 2.17 Spring的事務(wù)傳播方式有哪些?

    參考答案

    當(dāng)我們調(diào)用一個(gè)業(yè)務(wù)方法時(shí),它的內(nèi)部可能會(huì)調(diào)用其他的業(yè)務(wù)方法,以完成一個(gè)完整的業(yè)務(wù)操作。這種業(yè)務(wù)方法嵌套調(diào)用的時(shí)候,如果這兩個(gè)方法都是要保證事務(wù)的,那么就要通過Spring的事務(wù)傳播機(jī)制控制當(dāng)前事務(wù)如何傳播到被嵌套調(diào)用的業(yè)務(wù)方法中。

    Spring在TransactionDefinition接口中規(guī)定了7種類型的事務(wù)傳播行為,它們規(guī)定了事務(wù)方法和事務(wù)方法發(fā)生嵌套調(diào)用時(shí)如何進(jìn)行傳播,如下表:

    事務(wù)傳播類型說明
    PROPAGATION_REQUIRED如果當(dāng)前沒有事務(wù),則新建一個(gè)事務(wù);如果已存在一個(gè)事務(wù),則加入到這個(gè)事務(wù)中。這是最常見的選擇。
    PROPAGATION_SUPPORTS支持當(dāng)前事務(wù),如果當(dāng)前沒有事務(wù),則以非事務(wù)方式執(zhí)行。
    PROPAGATION_MANDATORY使用當(dāng)前的事務(wù),如果當(dāng)前沒有事務(wù),則拋出異常。
    PROPAGATION_REQUIRES_NEW新建事務(wù),如果當(dāng)前存在事務(wù),則把當(dāng)前事務(wù)掛起。
    PROPAGATION_NOT_SUPPORTED以非事務(wù)方式執(zhí)行操作,如果當(dāng)前存在事務(wù),則把當(dāng)前事務(wù)掛起。
    PROPAGATION_NEVER以非事務(wù)方式執(zhí)行操作,如果當(dāng)前存在事務(wù),則拋出異常。
    PROPAGATION_NESTED如果當(dāng)前存在事務(wù),則在嵌套事務(wù)內(nèi)執(zhí)行;如果當(dāng)前沒有事務(wù),則執(zhí)行與PROPAGATION_REQUIRED類似的操作。

    2.18 Spring的事務(wù)如何配置,常用注解有哪些?

    參考答案

    事務(wù)的打開、回滾和提交是由事務(wù)管理器來完成的,我們使用不同的數(shù)據(jù)庫訪問框架,就要使用與之對(duì)應(yīng)的事務(wù)管理器。在Spring Boot中,當(dāng)你添加了數(shù)據(jù)庫訪問框架的起步依賴時(shí),它就會(huì)進(jìn)行自動(dòng)配置,即自動(dòng)實(shí)例化正確的事務(wù)管理器。

    對(duì)于聲明式事務(wù),是使用@Transactional進(jìn)行標(biāo)注的。這個(gè)注解可以標(biāo)注在類或者方法上。

    • 當(dāng)它標(biāo)注在類上時(shí),代表這個(gè)類所有公共(public)非靜態(tài)的方法都將啟用事務(wù)功能。
    • 當(dāng)它標(biāo)注在方法上時(shí),代表這個(gè)方法將啟用事務(wù)功能。

    另外,在@Transactional注解上,我們可以使用isolation屬性聲明事務(wù)的隔離級(jí)別,使用propagation屬性聲明事務(wù)的傳播機(jī)制。

    2.19 說一說你對(duì)聲明式事務(wù)的理解

    參考答案

    Spring事務(wù)管理的亮點(diǎn)在于聲明式事務(wù)管理,它允許我們通過聲明的方式,在IoC配置中指定事務(wù)的邊界和事務(wù)屬性,Spring會(huì)自動(dòng)在指定的事務(wù)邊界上應(yīng)用事務(wù)屬性。相對(duì)于編程式事務(wù)來說,這種方式十分的方便,只需要在需要做事務(wù)管理的方法上,增加@Transactional注解,以聲明事務(wù)特征即可。

    3. Spring MVC

    3.1 什么是MVC?

    參考答案

    MVC是一種設(shè)計(jì)模式,在這種模式下軟件被分為三層,即Model(模型)、View(視圖)、Controller(控制器)。Model代表的是數(shù)據(jù),View代表的是用戶界面,Controller代表的是數(shù)據(jù)的處理邏輯,它是Model和View這兩層的橋梁。將軟件分層的好處是,可以將對(duì)象之間的耦合度降低,便于代碼的維護(hù)。

    3.2 DAO層是做什么的?

    參考答案

    DAO是Data Access Obejct的縮寫,即數(shù)據(jù)訪問對(duì)象,在項(xiàng)目中它通常作為獨(dú)立的一層,專門用于訪問數(shù)據(jù)庫。這一層的具體實(shí)現(xiàn)技術(shù)有很多,常用的有Spring JDBC、Hibernate、JPA、MyBatis等,在Spring框架下無論采用哪一種技術(shù)訪問數(shù)據(jù)庫,它的編程模式都是統(tǒng)一的。

    3.3 介紹一下Spring MVC的執(zhí)行流程

    參考答案

  • 整個(gè)過程開始于客戶端發(fā)出的一個(gè)HTTP請(qǐng)求,Web應(yīng)用服務(wù)器接收到這個(gè)請(qǐng)求。如果匹配DispatcherServlet的請(qǐng)求映射路徑,則Web容器將該請(qǐng)求轉(zhuǎn)交給DispatcherServlet處理。
  • DispatcherServlet接收到這個(gè)請(qǐng)求后,將根據(jù)請(qǐng)求的信息(包括URL、HTTP方法、請(qǐng)求報(bào)文頭、請(qǐng)求參數(shù)、Cookie等)及HandlerMapping的配置找到處理請(qǐng)求的處理器(Handler)。可將HandlerMapping看做路由控制器,將Handler看做目標(biāo)主機(jī)。值得注意的是,在Spring MVC中并沒有定義一個(gè)Handler接口,實(shí)際上任何一個(gè)Object都可以成為請(qǐng)求處理器。
  • 當(dāng)DispatcherServlet根據(jù)HandlerMapping得到對(duì)應(yīng)當(dāng)前請(qǐng)求的Handler后,通過HandlerAdapter對(duì)Handler進(jìn)行封裝,再以統(tǒng)一的適配器接口調(diào)用Handler。HandlerAdapter是Spring MVC框架級(jí)接口,顧名思義,HandlerAdapter是一個(gè)適配器,它用統(tǒng)一的接口對(duì)各種Handler方法進(jìn)行調(diào)用。
  • 處理器完成業(yè)務(wù)邏 輯的處理后,將返回一個(gè)ModelAndView給DispatcherServlet,ModelAndView包含了視圖邏輯名和模型數(shù)據(jù)信息。
  • ModelAndView中包含的是“邏輯視圖名”而非真正的視圖對(duì)象,DispatcherServlet借由ViewResolver完成邏輯視圖名到真實(shí)視圖對(duì)象的解析工作。
  • 當(dāng)?shù)玫秸鎸?shí)的視圖對(duì)象View后,DispatcherServlet就使用這個(gè)View對(duì)象對(duì)ModelAndView中的模型數(shù)據(jù)進(jìn)行視圖渲染。
  • 最終客戶端得到的響應(yīng)消息可能是一個(gè)普通的HTML頁面,也可能是一個(gè)XML或JSON串,甚至是一張圖片或一個(gè)PDF文檔等不同的媒體形式。
  • 3.4 說一說你知道的Spring MVC注解

    參考答案

    @RequestMapping:

    作用:該注解的作用就是用來處理請(qǐng)求地址映射的,也就是說將其中的處理器方法映射到url路徑上。

    屬性:

    • method:是讓你指定請(qǐng)求的method的類型,比如常用的有g(shù)et和post。
    • value:是指請(qǐng)求的實(shí)際地址,如果是多個(gè)地址就用{}來指定就可以啦。
    • produces:指定返回的內(nèi)容類型,當(dāng)request請(qǐng)求頭中的Accept類型中包含指定的類型才可以返回的。
    • consumes:指定處理請(qǐng)求的提交內(nèi)容類型,比如一些json、html、text等的類型。
    • headers:指定request中必須包含那些的headed值時(shí),它才會(huì)用該方法處理請(qǐng)求的。
    • params:指定request中一定要有的參數(shù)值,它才會(huì)使用該方法處理請(qǐng)求。

    @RequestParam:

    作用:是將請(qǐng)求參數(shù)綁定到你的控制器的方法參數(shù)上,是Spring MVC中的接收普通參數(shù)的注解。

    屬性:

    • value是請(qǐng)求參數(shù)中的名稱。
    • required是請(qǐng)求參數(shù)是否必須提供參數(shù),它的默認(rèn)是true,意思是表示必須提供。

    @RequestBody:

    作用:如果作用在方法上,就表示該方法的返回結(jié)果是直接按寫入的Http responsebody中(一般在異步獲取數(shù)據(jù)時(shí)使用的注解)。

    屬性:required,是否必須有請(qǐng)求體。它的默認(rèn)值是true,在使用該注解時(shí),值得注意的當(dāng)為true時(shí)get的請(qǐng)求方式是報(bào)錯(cuò)的,如果你取值為false的話,get的請(qǐng)求是null。

    @PathVaribale:

    作用:該注解是用于綁定url中的占位符,但是注意,spring3.0以后,url才開始支持占位符的,它是Spring MVC支持的rest風(fēng)格url的一個(gè)重要的標(biāo)志。

    3.5 介紹一下Spring MVC的攔截器

    參考答案

    攔截器會(huì)對(duì)處理器進(jìn)行攔截,這樣通過攔截器就可以增強(qiáng)處理器的功能。Spring MVC中,所有的攔截器都需要實(shí)現(xiàn)HandlerInterceptor接口,該接口包含如下三個(gè)方法:preHandle()、postHandle()、afterCompletion()。

    這些方法的執(zhí)行流程如下圖:

    通過上圖可以看出,Spring MVC攔截器的執(zhí)行流程如下:

    • 執(zhí)行preHandle方法,它會(huì)返回一個(gè)布爾值。如果為false,則結(jié)束所有流程,如果為true,則執(zhí)行下一步。
    • 執(zhí)行處理器邏輯,它包含控制器的功能。
    • 執(zhí)行postHandle方法。
    • 執(zhí)行視圖解析和視圖渲染。
    • 執(zhí)行afterCompletion方法。

    Spring MVC攔截器的開發(fā)步驟如下:

  • 開發(fā)攔截器:

    實(shí)現(xiàn)handlerInterceptor接口,從三個(gè)方法中選擇合適的方法,實(shí)現(xiàn)攔截時(shí)要執(zhí)行的具體業(yè)務(wù)邏輯。

  • 注冊(cè)攔截器:

    定義配置類,并讓它實(shí)現(xiàn)WebMvcConfigurer接口,在接口的addInterceptors方法中,注冊(cè)攔截器,并定義該攔截器匹配哪些請(qǐng)求路徑。

  • 3.6 怎么去做請(qǐng)求攔截?

    參考答案

    如果是對(duì)Controller記性攔截,則可以使用Spring MVC的攔截器。

    如果是對(duì)所有的請(qǐng)求(如訪問靜態(tài)資源的請(qǐng)求)進(jìn)行攔截,則可以使用Filter。

    如果是對(duì)除了Controller之外的其他Bean的請(qǐng)求進(jìn)行攔截,則可以使用Spring AOP。

    4. MyBatis

    4.1 談?wù)凪yBatis和JPA的區(qū)別

    參考答案

    ORM映射不同:

    MyBatis是半自動(dòng)的ORM框架,提供數(shù)據(jù)庫與結(jié)果集的映射;

    JPA(默認(rèn)采用Hibernate實(shí)現(xiàn))是全自動(dòng)的ORM框架,提供對(duì)象與數(shù)據(jù)庫的映射。

    可移植性不同:

    JPA通過它強(qiáng)大的映射結(jié)構(gòu)和HQL語言,大大降低了對(duì)象與數(shù)據(jù)庫的耦合性;

    MyBatis由于需要寫SQL,因此與數(shù)據(jù)庫的耦合性直接取決于SQL的寫法,如果SQL不具備通用性而用了很多數(shù)據(jù)庫的特性SQL的話,移植性就會(huì)降低很多,移植時(shí)成本很高。

    日志系統(tǒng)的完整性不同:

    JPA日志系統(tǒng)非常健全、涉及廣泛,包括:SQL記錄、關(guān)系異常、優(yōu)化警告、緩存提示、臟數(shù)據(jù)警告等;

    MyBatis除了基本的記錄功能外,日志功能薄弱很多。

    SQL優(yōu)化上的區(qū)別:

    由于Mybatis的SQL都是寫在XML里,因此優(yōu)化SQL比Hibernate方便很多。

    而Hibernate的SQL很多都是自動(dòng)生成的,無法直接維護(hù)SQL。雖有HQL,但功能還是不及SQL強(qiáng)大,見到報(bào)表等復(fù)雜需求時(shí)HQL就無能為力,也就是說HQL是有局限的Hhibernate雖然也支持原生SQL,但開發(fā)模式上卻與ORM不同,需要轉(zhuǎn)換思維,因此使用上不是非常方便。總之寫SQL的靈活度上Hibernate不及Mybatis。

    4.2 MyBatis輸入輸出支持的類型有哪些?

    參考答案

    parameterType:

    MyBatis支持多種輸入輸出類型,包括:

  • 簡單的類型,如整數(shù)、小數(shù)、字符串等;
  • 集合類型,如Map等;
  • 自定義的JavaBean。
  • 其中,簡單的類型,其數(shù)值直接映射到參數(shù)上。對(duì)于Map或JavaBean則將其屬性按照名稱映射到參數(shù)上。

    4.3 MyBatis里如何實(shí)現(xiàn)一對(duì)多關(guān)聯(lián)查詢?

    參考答案

    一對(duì)多映射有兩種配置方式,都是使用collection標(biāo)簽實(shí)現(xiàn)的。在此之前,為了能夠存儲(chǔ)一對(duì)多的數(shù)據(jù),需要在主表對(duì)應(yīng)的實(shí)體類中增加集合屬性,用于封裝子表對(duì)應(yīng)的實(shí)體類。

    嵌套查詢:

  • 通過select標(biāo)簽定義查詢主表的SQL,返回結(jié)果通過reusltMap進(jìn)行映射。
  • 在resultMap中,除了映射主表屬性,還要通過collection標(biāo)簽映射子表屬性,該標(biāo)簽需包含如下內(nèi)容:
    • 通過property屬性指定子表屬性名;
    • 通過javaType屬性指定封裝子表屬性的集合類型;
    • 通過ofType屬性指定子表的實(shí)體類型;
    • 通過select屬性指定查詢子表所依賴的SQL,這個(gè)SQL需單獨(dú)定義,內(nèi)部包含查詢子表的語句。
  • 嵌套結(jié)果:

  • 通過select標(biāo)簽定義關(guān)聯(lián)查詢主表和子表的SQL,返回結(jié)果通過resultMap進(jìn)行映射。
  • 在resultMap中,除了映射主表屬性,還要通過collection標(biāo)簽映射子表屬性,該標(biāo)簽需包含如下內(nèi)容:
    • 通過property屬性指定子表屬性名;
    • 通過ofType屬性指定子表的實(shí)體類型;
    • 通過result子標(biāo)簽定義子表字段和屬性的映射關(guān)系。
  • 4.4 MyBatis中的$和#有什么區(qū)別?

    參考答案

    使用#設(shè)置參數(shù)時(shí),MyBatis會(huì)創(chuàng)建預(yù)編譯的SQL語句,然后在執(zhí)行SQL時(shí)MyBatis會(huì)為預(yù)編譯SQL中的占位符(?)賦值。預(yù)編譯的SQL語句執(zhí)行效率高,并且可以防止注入攻擊。

    使用$設(shè)置參數(shù)時(shí),MyBatis只是創(chuàng)建普通的SQL語句,然后在執(zhí)行SQL語句時(shí)MyBatis將參數(shù)直接拼入到SQL里。這種方式在效率、安全性上均不如前者,但是可以解決一些特殊情況下的問題。例如,在一些動(dòng)態(tài)表格(根據(jù)不同的條件產(chǎn)生不同的動(dòng)態(tài)列)中,我們要傳遞SQL的列名,根據(jù)某些列進(jìn)行排序,或者傳遞列名給SQL都是比較常見的場景,這就無法使用預(yù)編譯的方式了。

    4.5 既然不安全,為什么還需要?什么時(shí)候會(huì)用到它?

    參考答案

    它可以解決一些特殊情況下的問題。例如,在一些動(dòng)態(tài)表格(根據(jù)不同的條件產(chǎn)生不同的動(dòng)態(tài)列)中,我們要傳遞SQL的列名,根據(jù)某些列進(jìn)行排序,或者傳遞列名給SQL都是比較常見的場景,這就無法使用預(yù)編譯的方式了。

    4.6 MyBatis的xml文件和Mapper接口是怎么綁定的?

    參考答案

    是通過xml文件中,<mapper> 根標(biāo)簽的namespace屬性進(jìn)行綁定的,即namespace屬性的值需要配置成接口的全限定名稱,MyBatis內(nèi)部就會(huì)通過這個(gè)值將這個(gè)接口與這個(gè)xml關(guān)聯(lián)起來。

    4.7 MyBatis分頁和自己寫的分頁哪個(gè)效率高?

    參考答案

    自己寫的分頁效率高。

    在MyBatis中,我們可以通過分頁插件實(shí)現(xiàn)分頁,也可以通過分頁SQL自己實(shí)現(xiàn)分頁。其中,分頁插件的原理是,攔截查詢SQL,在這個(gè)SQL基礎(chǔ)上自動(dòng)為其添加limit分頁條件。它會(huì)大大的提高開發(fā)的效率,但是無法對(duì)分頁語句做出有針對(duì)性的優(yōu)化,比如分頁偏移量很大的情況,而這些在自己寫的分頁SQL里卻是可以靈活實(shí)現(xiàn)的。

    4.8 了解MyBatis緩存機(jī)制嗎?

    參考答案

    MyBatis的緩存分為一級(jí)緩存和二級(jí)緩存。

    一級(jí)緩存:

    一級(jí)緩存也叫本地緩存,它默認(rèn)會(huì)啟用,并且不能關(guān)閉。一級(jí)緩存存在于SqlSession的生命周期中,即它是SqlSession級(jí)別的緩存。在同一個(gè) SqlSession 中查詢時(shí),MyBatis 會(huì)把執(zhí)行的方法和參數(shù)通過算法生成緩存的鍵值,將鍵值和查詢結(jié)果存入一個(gè)Map對(duì)象中。如果同一個(gè)SqlSession 中執(zhí)行的方法和參數(shù)完全一致,那么通過算法會(huì)生成相同的鍵值,當(dāng)Map 緩存對(duì)象中己經(jīng)存在該鍵值時(shí),則會(huì)返回緩存中的對(duì)象。

    二級(jí)緩存:

    二級(jí)緩存存在于SqlSessionFactory 的生命周期中,即它是SqlSessionFactory級(jí)別的緩存。若想使用二級(jí)緩存,需要在如下兩處進(jìn)行配置。

    在MyBatis 的全局配置settings 中有一個(gè)參數(shù)cacheEnabled,這個(gè)參數(shù)是二級(jí)緩存的全局開關(guān),默認(rèn)值是true ,初始狀態(tài)為啟用狀態(tài)。

    MyBatis 的二級(jí)緩存是和命名空間綁定的,即二級(jí)緩存需要配置在Mapper.xml 映射文件中。在保證二級(jí)緩存的全局配置開啟的情況下,給Mapper.xml 開啟二級(jí)緩存只需要在Mapper. xml 中添加如下代碼:

    <cache />

    二級(jí)緩存具有如下效果:

    • 映射語句文件中的所有SELECT 語句將會(huì)被緩存。
    • 映射語句文件中的所有時(shí)INSERT 、UPDATE 、DELETE 語句會(huì)刷新緩存。
    • 緩存會(huì)使用Least Rece ntly U sed ( LRU ,最近最少使用的)算法來收回。
    • 根據(jù)時(shí)間表(如no Flush Int erv al ,沒有刷新間隔),緩存不會(huì)以任何時(shí)間順序來刷新。
    • 緩存會(huì)存儲(chǔ)集合或?qū)ο?#xff08;無論查詢方法返回什么類型的值)的1024 個(gè)引用。
    • 緩存會(huì)被視為read/write(可讀/可寫)的,意味著對(duì)象檢索不是共享的,而且可以安全地被調(diào)用者修改,而不干擾其他調(diào)用者或線程所做的潛在修改。

    5. 其他

    5.1 cookie和session的區(qū)別是什么?

    參考答案

  • 存儲(chǔ)位置不同:cookie存放于客戶端;session存放于服務(wù)端。
  • 存儲(chǔ)容量不同:單個(gè)cookie保存的數(shù)據(jù)<=4KB,一個(gè)站點(diǎn)最多保存20個(gè)cookie;而session并沒有上限。
  • 存儲(chǔ)方式不同:cookie只能保存ASCII字符串,并需要通過編碼當(dāng)時(shí)存儲(chǔ)為Unicode字符或者二進(jìn)制數(shù)據(jù);session中能夠存儲(chǔ)任何類型的數(shù)據(jù),例如字符串、整數(shù)、集合等。
  • 隱私策略不同:cookie對(duì)客戶端是可見的,別有用心的人可以分析存放在本地的cookie并進(jìn)行cookie欺騙,所以它是不安全的;session存儲(chǔ)在服務(wù)器上,對(duì)客戶端是透明的,不存在敏感信息泄露的風(fēng)險(xiǎn)。
  • 生命周期不同:可以通過設(shè)置cookie的屬性,達(dá)到cookie長期有效的效果;session依賴于名為JSESSIONID的cookie,而該cookie的默認(rèn)過期時(shí)間為-1,只需關(guān)閉窗口該session就會(huì)失效,因此session不能長期有效。
  • 服務(wù)器壓力不同:cookie保存在客戶端,不占用服務(wù)器資源;session保管在服務(wù)器上,每個(gè)用戶都會(huì)產(chǎn)生一個(gè)session,如果并發(fā)量大的話,則會(huì)消耗大量的服務(wù)器內(nèi)存。
  • 瀏覽器支持不同:cookie是需要瀏覽器支持的,如果客戶端禁用了cookie,則會(huì)話跟蹤就會(huì)失效;運(yùn)用session就需要使用URL重寫的方式,所有用到session的URL都要進(jìn)行重寫,否則session會(huì)話跟蹤也會(huì)失效。
  • 跨域支持不同:cookie支持跨域訪問,session不支持跨域訪問。
  • 5.2 cookie和session各自適合的場景是什么?

    參考答案

    對(duì)于敏感數(shù)據(jù),應(yīng)存放在session里,因?yàn)閏ookie不安全。

    對(duì)于普通數(shù)據(jù),優(yōu)先考慮存放在cookie里,這樣會(huì)減少對(duì)服務(wù)器資源的占用。

    5.3 請(qǐng)介紹session的工作原理

    參考答案

    session依賴于cookie。

    當(dāng)客戶端首次訪問服務(wù)器時(shí),服務(wù)器會(huì)為其創(chuàng)建一個(gè)session對(duì)象,該對(duì)象具有一個(gè)唯一標(biāo)識(shí)SESSIONID。并且在響應(yīng)階段,服務(wù)器會(huì)創(chuàng)建一個(gè)cookie,并將SESSIONID存入其中。

    客戶端通過響應(yīng)的cookie而持有SESSIONID,所以當(dāng)它再次訪問服務(wù)器時(shí),會(huì)通過cookie攜帶這個(gè)SESSIONID。服務(wù)器獲取到SESSIONID后,就可以找到與之對(duì)應(yīng)的session對(duì)象,進(jìn)而從這個(gè)session中獲取該客戶端的狀態(tài)。

    5.4 get請(qǐng)求與post請(qǐng)求有什么區(qū)別?

    參考答案

    • GET在瀏覽器回退時(shí)是無害的,而POST會(huì)再次提交請(qǐng)求。
    • GET產(chǎn)生的URL地址可以被Bookmark,而POST不可以。
    • GET請(qǐng)求會(huì)被瀏覽器主動(dòng)cache,而POST不會(huì),除非手動(dòng)設(shè)置。
    • GET請(qǐng)求只能進(jìn)行url編碼,而POST支持多種編碼方式。
    • GET請(qǐng)求參數(shù)會(huì)被完整保留在瀏覽器歷史記錄里,而POST中的參數(shù)不會(huì)被保留。
    • GET請(qǐng)求在URL中傳送的參數(shù)是有長度限制的,而POST沒有。
    • 對(duì)參數(shù)的數(shù)據(jù)類型,GET只接受ASCII字符,而POST沒有限制。
    • GET比POST更不安全,因?yàn)閰?shù)直接暴露在URL上,所以不能用來傳遞敏感信息。
    • GET參數(shù)通過URL傳遞,POST放在Request body中。

    5.5 get請(qǐng)求的參數(shù)能放到body里面嗎?

    參考答案

    GET請(qǐng)求是可以將參數(shù)放到BODY里面的,官方并沒有明確禁止,但給出的建議是這樣不符合規(guī)范,無法保證所有的實(shí)現(xiàn)都支持。這就意味著,如果你試圖這樣做,可能出現(xiàn)各種未知的問題,所以應(yīng)該當(dāng)避免。

    5.6 post不冪等是為什么?

    參考答案

    HTTP方法的冪等性是指一次和多次請(qǐng)求某一個(gè)資源應(yīng)該具有同樣的副作用。冪等性屬于語義范疇,正如編譯器只能幫助檢查語法錯(cuò)誤一樣,HTTP規(guī)范也沒有辦法通過消息格式等語法手段來定義它。

    POST所對(duì)應(yīng)的URI并非創(chuàng)建的資源本身,而是資源的接收者。比如:POST http://www.forum.com/articles的語義是在http://www.forum.com/articles下創(chuàng)建一篇帖子,HTTP響應(yīng)中應(yīng)包含帖子的創(chuàng)建狀態(tài)以及帖子的URI。兩次相同的POST請(qǐng)求會(huì)在服務(wù)器端創(chuàng)建兩份資源,它們具有不同的URI。所以,POST方法不具備冪等性。

    5.7 頁面報(bào)400錯(cuò)誤是什么意思?

    參考答案

    400狀態(tài)碼標(biāo)識(shí)請(qǐng)求的語義有誤,當(dāng)前請(qǐng)求無法被服務(wù)器理解。除非進(jìn)行修改,否則客戶端不應(yīng)該重復(fù)提交這個(gè)請(qǐng)求。通常情況下,是本次請(qǐng)求中包含有錯(cuò)誤的參數(shù),此時(shí)應(yīng)該排查前端傳遞的參數(shù)。

    5.8 請(qǐng)求數(shù)據(jù)出現(xiàn)亂碼該怎么處理?

    參考答案

    服務(wù)端出現(xiàn)請(qǐng)求亂碼的原因是,客戶端編碼與服務(wù)器解碼方案不一致,可以有如下幾種解決辦法:

  • 將獲得的數(shù)據(jù)按照客戶端編碼轉(zhuǎn)成BYTE,再將BYTE按服務(wù)端編碼轉(zhuǎn)成字符串,這種方案對(duì)各種請(qǐng)求方式均有效,但是十分的麻煩。
  • 在接受請(qǐng)求數(shù)據(jù)之前,顯示聲明實(shí)體內(nèi)容的編碼與服務(wù)器一致,這種方式只對(duì)POST請(qǐng)求有效。
  • 修改服務(wù)器的配置文件,顯示聲明請(qǐng)求路徑的編碼與服務(wù)器一致,這種方式只對(duì)GET請(qǐng)求有效。
  • 5.9 如何在SpringBoot框架下實(shí)現(xiàn)一個(gè)定時(shí)任務(wù)?

    參考答案

    Spring給我們提供了可執(zhí)行定時(shí)任務(wù)的線程池ThreadPoolTaskScheduler,該線程池提供了多個(gè)可以與執(zhí)行定時(shí)任務(wù)的方法,如下圖。在Spring Boot中,只需要在配置類中啟用線程池注解,就可以直接使用這個(gè)線程池了。

    5.10 調(diào)用接口時(shí)要記錄日志,該怎么設(shè)計(jì)?

    參考答案

    可以定義一個(gè)記錄日志的組件,并通過AOP將其織入到這個(gè)接口的調(diào)用中。這種方式對(duì)接口無需做任何改造,業(yè)務(wù)代碼中也無需增加任何調(diào)用的邏輯,完美地消除了記錄日志和業(yè)務(wù)代碼的耦合度。

    5.11 了解Spring Boot JPA嗎?

    參考答案

    I。所以,POST方法不具備冪等性。

    5.7 頁面報(bào)400錯(cuò)誤是什么意思?

    參考答案

    400狀態(tài)碼標(biāo)識(shí)請(qǐng)求的語義有誤,當(dāng)前請(qǐng)求無法被服務(wù)器理解。除非進(jìn)行修改,否則客戶端不應(yīng)該重復(fù)提交這個(gè)請(qǐng)求。通常情況下,是本次請(qǐng)求中包含有錯(cuò)誤的參數(shù),此時(shí)應(yīng)該排查前端傳遞的參數(shù)。

    5.8 請(qǐng)求數(shù)據(jù)出現(xiàn)亂碼該怎么處理?

    參考答案

    服務(wù)端出現(xiàn)請(qǐng)求亂碼的原因是,客戶端編碼與服務(wù)器解碼方案不一致,可以有如下幾種解決辦法:

  • 將獲得的數(shù)據(jù)按照客戶端編碼轉(zhuǎn)成BYTE,再將BYTE按服務(wù)端編碼轉(zhuǎn)成字符串,這種方案對(duì)各種請(qǐng)求方式均有效,但是十分的麻煩。
  • 在接受請(qǐng)求數(shù)據(jù)之前,顯示聲明實(shí)體內(nèi)容的編碼與服務(wù)器一致,這種方式只對(duì)POST請(qǐng)求有效。
  • 修改服務(wù)器的配置文件,顯示聲明請(qǐng)求路徑的編碼與服務(wù)器一致,這種方式只對(duì)GET請(qǐng)求有效。
  • 5.9 如何在SpringBoot框架下實(shí)現(xiàn)一個(gè)定時(shí)任務(wù)?

    參考答案

    Spring給我們提供了可執(zhí)行定時(shí)任務(wù)的線程池ThreadPoolTaskScheduler,該線程池提供了多個(gè)可以與執(zhí)行定時(shí)任務(wù)的方法,如下圖。在Spring Boot中,只需要在配置類中啟用線程池注解,就可以直接使用這個(gè)線程池了。

    [外鏈圖片轉(zhuǎn)存中…(img-taMsqLji-1641471118189)]

    5.10 調(diào)用接口時(shí)要記錄日志,該怎么設(shè)計(jì)?

    參考答案

    可以定義一個(gè)記錄日志的組件,并通過AOP將其織入到這個(gè)接口的調(diào)用中。這種方式對(duì)接口無需做任何改造,業(yè)務(wù)代碼中也無需增加任何調(diào)用的邏輯,完美地消除了記錄日志和業(yè)務(wù)代碼的耦合度。

    5.11 了解Spring Boot JPA嗎?

    參考答案

    JPA即Java Persistence API,它是一個(gè)基于O/R映射的標(biāo)準(zhǔn)規(guī)范。也就是說它指定以了標(biāo)準(zhǔn)規(guī)則,不提供實(shí)現(xiàn),軟件提供商可以按照標(biāo)準(zhǔn)規(guī)范來實(shí)現(xiàn),而使用者只需按照規(guī)范中定義的方式來使用,不用和軟件提供商打交道。JPA主要實(shí)現(xiàn)有Hibernate、EclipseLink、OpenJPA等,我們使用JPA來開發(fā),無論是采用哪一種實(shí)現(xiàn)方式都一樣。

    總結(jié)

    以上是生活随笔為你收集整理的Spring全家桶面试真题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

    成人精品视频一区二区 | 亚洲日韩av片在线观看 | 熟女俱乐部五十路六十路av | 人妻少妇精品无码专区动漫 | 国产手机在线αⅴ片无码观看 | 成人一在线视频日韩国产 | 性欧美疯狂xxxxbbbb | 国产办公室秘书无码精品99 | 日本乱人伦片中文三区 | 国产色在线 | 国产 | 88国产精品欧美一区二区三区 | 日韩欧美成人免费观看 | 国产舌乚八伦偷品w中 | 鲁一鲁av2019在线 | 国产精品手机免费 | 爆乳一区二区三区无码 | 国产va免费精品观看 | 日韩人妻系列无码专区 | 熟女少妇在线视频播放 | 给我免费的视频在线观看 | ass日本丰满熟妇pics | 久久精品中文闷骚内射 | 亚洲综合伊人久久大杳蕉 | √8天堂资源地址中文在线 | 欧美性生交活xxxxxdddd | 精品国产麻豆免费人成网站 | 国产精品无码久久av | 少妇激情av一区二区 | 欧美怡红院免费全部视频 | 亚洲精品无码人妻无码 | 国内精品一区二区三区不卡 | 国产在线一区二区三区四区五区 | 欧美野外疯狂做受xxxx高潮 | 欧美自拍另类欧美综合图片区 | 成人免费视频视频在线观看 免费 | 日本大香伊一区二区三区 | 又色又爽又黄的美女裸体网站 | 国精品人妻无码一区二区三区蜜柚 | 沈阳熟女露脸对白视频 | 国产综合在线观看 | 欧美日本精品一区二区三区 | 天天燥日日燥 | 久久精品人人做人人综合 | 全黄性性激高免费视频 | 日本va欧美va欧美va精品 | 久久亚洲精品中文字幕无男同 | 亚洲a无码综合a国产av中文 | 国产成人无码av一区二区 | 久久天天躁狠狠躁夜夜免费观看 | 亚洲日本va中文字幕 | 精品成人av一区二区三区 | 精品无人区无码乱码毛片国产 | 国产精华av午夜在线观看 | 野外少妇愉情中文字幕 | 免费乱码人妻系列无码专区 | 亚洲精品久久久久中文第一幕 | 一区二区传媒有限公司 | 国产97人人超碰caoprom | 国产农村妇女高潮大叫 | 欧美日韩人成综合在线播放 | 无码帝国www无码专区色综合 | 激情内射日本一区二区三区 | 国产麻豆精品精东影业av网站 | 中文字幕中文有码在线 | 亚洲欧美色中文字幕在线 | 日韩人妻无码一区二区三区久久99 | 国产精品办公室沙发 | 亚洲精品午夜国产va久久成人 | 亚洲中文字幕乱码av波多ji | 国产69精品久久久久app下载 | 亚洲国产一区二区三区在线观看 | 免费观看黄网站 | 高清无码午夜福利视频 | 成人综合网亚洲伊人 | 人妻插b视频一区二区三区 | 国产莉萝无码av在线播放 | 人妻中文无码久热丝袜 | 亚洲一区二区三区播放 | 午夜性刺激在线视频免费 | 久久久久久久人妻无码中文字幕爆 | 国产精品久久久久久亚洲影视内衣 | 亚洲欧美日韩国产精品一区二区 | 国产精品内射视频免费 | 欧美zoozzooz性欧美 | 性色欲情网站iwww九文堂 | 在教室伦流澡到高潮hnp视频 | 亚洲一区二区三区四区 | 日韩精品一区二区av在线 | 中文字幕日产无线码一区 | 亚洲中文字幕va福利 | 欧美精品在线观看 | 国产特级毛片aaaaaa高潮流水 | 亚洲 欧美 激情 小说 另类 | 成人精品一区二区三区中文字幕 | 亚洲色大成网站www国产 | 中文字幕av伊人av无码av | 99久久99久久免费精品蜜桃 | 在线亚洲高清揄拍自拍一品区 | 又大又硬又黄的免费视频 | 亚洲精品久久久久久久久久久 | 亚洲精品午夜国产va久久成人 | аⅴ资源天堂资源库在线 | 国产片av国语在线观看 | 欧美精品无码一区二区三区 | 人人妻人人澡人人爽精品欧美 | 欧美性色19p | 丝袜足控一区二区三区 | 国产成人综合美国十次 | 国产无遮挡又黄又爽免费视频 | 中文字幕精品av一区二区五区 | 久久久久久久女国产乱让韩 | 久久99久久99精品中文字幕 | 亚洲一区二区三区 | 久久综合激激的五月天 | 精品少妇爆乳无码av无码专区 | 国产深夜福利视频在线 | 亚洲国产日韩a在线播放 | 少妇无套内谢久久久久 | 亚洲精品成a人在线观看 | 欧美 日韩 亚洲 在线 | 青草视频在线播放 | 精品久久久中文字幕人妻 | 亚洲 日韩 欧美 成人 在线观看 | 日韩精品a片一区二区三区妖精 | 国产精品爱久久久久久久 | 日产精品高潮呻吟av久久 | 又大又黄又粗又爽的免费视频 | 精品国产av色一区二区深夜久久 | 无码福利日韩神码福利片 | 国产精品a成v人在线播放 | 国产精品-区区久久久狼 | 色偷偷人人澡人人爽人人模 | 色婷婷综合中文久久一本 | 欧美日韩一区二区免费视频 | 国产成人亚洲综合无码 | 色婷婷久久一区二区三区麻豆 | 一本久道高清无码视频 | 国产精品二区一区二区aⅴ污介绍 | 西西人体www44rt大胆高清 | 欧美三级a做爰在线观看 | 久久无码中文字幕免费影院蜜桃 | 欧美刺激性大交 | 日日躁夜夜躁狠狠躁 | 一本色道婷婷久久欧美 | a片在线免费观看 | 一本久道高清无码视频 | 色欲久久久天天天综合网精品 | 成人免费视频在线观看 | 国产精品成人av在线观看 | 学生妹亚洲一区二区 | 波多野结衣高清一区二区三区 | 一二三四在线观看免费视频 | 娇妻被黑人粗大高潮白浆 | 内射老妇bbwx0c0ck | 男女作爱免费网站 | 精品国产一区二区三区四区 | 无码中文字幕色专区 | 狠狠色欧美亚洲狠狠色www | yw尤物av无码国产在线观看 | 成人片黄网站色大片免费观看 | 久久国语露脸国产精品电影 | 国产真实夫妇视频 | 亚洲精品国产a久久久久久 | 激情内射日本一区二区三区 | 天天摸天天碰天天添 | 成人aaa片一区国产精品 | 国产成人综合美国十次 | 男人的天堂2018无码 | 51国偷自产一区二区三区 | 国产精品igao视频网 | 国内精品人妻无码久久久影院蜜桃 | 国产精品内射视频免费 | 精品亚洲韩国一区二区三区 | 伊人久久大香线焦av综合影院 | 99re在线播放 | 一二三四社区在线中文视频 | 亚洲精品综合五月久久小说 | 国产激情艳情在线看视频 | 国产精品久久福利网站 | 在线播放亚洲第一字幕 | 内射后入在线观看一区 | 中文无码精品a∨在线观看不卡 | 久久久久成人片免费观看蜜芽 | 国内精品九九久久久精品 | 国产亚洲人成在线播放 | 亚洲色欲色欲天天天www | 一本色道久久综合狠狠躁 | 久久精品国产日本波多野结衣 | 思思久久99热只有频精品66 | 久久久成人毛片无码 | 人人妻人人澡人人爽欧美一区 | 国产精品自产拍在线观看 | 日产精品99久久久久久 | 欧美亚洲日韩国产人成在线播放 | 久久国产精品精品国产色婷婷 | 精品亚洲成av人在线观看 | www国产亚洲精品久久久日本 | 亚洲成av人片天堂网无码】 | 最新国产乱人伦偷精品免费网站 | 人妻有码中文字幕在线 | 精品国产精品久久一区免费式 | 十八禁真人啪啪免费网站 | 亚洲熟悉妇女xxx妇女av | 西西人体www44rt大胆高清 | 久久无码中文字幕免费影院蜜桃 | 免费国产成人高清在线观看网站 | 久久久久se色偷偷亚洲精品av | 18禁黄网站男男禁片免费观看 | 18禁黄网站男男禁片免费观看 | 人妻少妇精品久久 | 国产精品人人妻人人爽 | 成年美女黄网站色大免费全看 | 日韩少妇内射免费播放 | 久久天天躁狠狠躁夜夜免费观看 | 亚洲乱码国产乱码精品精 | 激情国产av做激情国产爱 | 亚洲国产精品久久久久久 | 又大又黄又粗又爽的免费视频 | 国产网红无码精品视频 | 精品国产乱码久久久久乱码 | 76少妇精品导航 | 久久久精品人妻久久影视 | 人妻少妇精品无码专区动漫 | 真人与拘做受免费视频 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产片av国语在线观看 | 国产精品亚洲综合色区韩国 | 精品国精品国产自在久国产87 | 美女毛片一区二区三区四区 | 亚洲 激情 小说 另类 欧美 | 99久久人妻精品免费二区 | 亚洲а∨天堂久久精品2021 | 久久综合网欧美色妞网 | 亚洲成av人影院在线观看 | 精品国产一区二区三区av 性色 | 日日干夜夜干 | 国产av人人夜夜澡人人爽麻豆 | 国产精品高潮呻吟av久久4虎 | 成年美女黄网站色大免费全看 | 爆乳一区二区三区无码 | 亚洲乱码国产乱码精品精 | 无码人妻少妇伦在线电影 | 亚洲 日韩 欧美 成人 在线观看 | 国内少妇偷人精品视频免费 | 国产乡下妇女做爰 | 亚洲阿v天堂在线 | 久久久久久九九精品久 | 亚洲性无码av中文字幕 | 99精品视频在线观看免费 | 免费人成网站视频在线观看 | 伊人久久大香线焦av综合影院 | 久久亚洲日韩精品一区二区三区 | 99久久久国产精品无码免费 | 波多野结衣av在线观看 | 久久久久成人片免费观看蜜芽 | 国产精品久久久久久亚洲影视内衣 | 玩弄中年熟妇正在播放 | 对白脏话肉麻粗话av | 欧美成人免费全部网站 | 兔费看少妇性l交大片免费 | 亚洲一区二区观看播放 | 精品人人妻人人澡人人爽人人 | 成人女人看片免费视频放人 | aⅴ亚洲 日韩 色 图网站 播放 | 国产猛烈高潮尖叫视频免费 | 亚洲 a v无 码免 费 成 人 a v | 丰满人妻被黑人猛烈进入 | 久久午夜无码鲁丝片 | 国产成人综合在线女婷五月99播放 | 亚洲精品无码人妻无码 | 国产卡一卡二卡三 | 麻豆果冻传媒2021精品传媒一区下载 | 永久黄网站色视频免费直播 | 2019午夜福利不卡片在线 | 国内揄拍国内精品少妇国语 | 99久久人妻精品免费一区 | 色一情一乱一伦 | 曰本女人与公拘交酡免费视频 | 人妻人人添人妻人人爱 | 欧美第一黄网免费网站 | 国产真人无遮挡作爱免费视频 | 亚洲成色在线综合网站 | 国产人妻精品一区二区三区 | 亚洲综合无码一区二区三区 | 国产精品资源一区二区 | 亚洲码国产精品高潮在线 | 熟妇激情内射com | 久久久久se色偷偷亚洲精品av | 免费无码的av片在线观看 | 国产精品二区一区二区aⅴ污介绍 | 中文字幕人妻无码一区二区三区 | 一区二区三区乱码在线 | 欧洲 | 欧美肥老太牲交大战 | 少妇性荡欲午夜性开放视频剧场 | 少妇无码一区二区二三区 | 在线成人www免费观看视频 | 午夜福利不卡在线视频 | 欧美亚洲日韩国产人成在线播放 | 亚洲一区二区三区国产精华液 | 亚洲毛片av日韩av无码 | 久久人人爽人人爽人人片ⅴ | 国产精品嫩草久久久久 | 理论片87福利理论电影 | 国产精品丝袜黑色高跟鞋 | 亚洲精品国产精品乱码视色 | 窝窝午夜理论片影院 | 少妇无套内谢久久久久 | 中国大陆精品视频xxxx | 中文字幕+乱码+中文字幕一区 | 久久精品女人的天堂av | 亚洲精品国产精品乱码不卡 | 丰满少妇熟乱xxxxx视频 | 无人区乱码一区二区三区 | 香港三级日本三级妇三级 | 一区二区三区乱码在线 | 欧洲 | 亚拍精品一区二区三区探花 | 无套内谢老熟女 | 成 人 网 站国产免费观看 | 亚洲成色www久久网站 | 亚无码乱人伦一区二区 | 欧美黑人乱大交 | 精品国产aⅴ无码一区二区 | 丰满人妻翻云覆雨呻吟视频 | 国产精品久久久久久亚洲毛片 | 国内精品久久久久久中文字幕 | 国产亚洲精品久久久久久久 | 国产热a欧美热a在线视频 | 日本又色又爽又黄的a片18禁 | 日欧一片内射va在线影院 | 色窝窝无码一区二区三区色欲 | 国产麻豆精品精东影业av网站 | 高清不卡一区二区三区 | 99久久婷婷国产综合精品青草免费 | 日韩精品无码一区二区中文字幕 | 97久久精品无码一区二区 | 欧美老妇交乱视频在线观看 | 97精品人妻一区二区三区香蕉 | 激情亚洲一区国产精品 | 网友自拍区视频精品 | 成人亚洲精品久久久久软件 | 欧美大屁股xxxxhd黑色 | 国产午夜精品一区二区三区嫩草 | 亚洲国精产品一二二线 | 精品国产一区二区三区四区 | 亚洲欧美日韩综合久久久 | 丰满诱人的人妻3 | 亚洲人成网站在线播放942 | 国产内射爽爽大片视频社区在线 | 国产舌乚八伦偷品w中 | 131美女爱做视频 | 国产成人久久精品流白浆 | а√天堂www在线天堂小说 | 中文字幕人妻丝袜二区 | 福利一区二区三区视频在线观看 | 欧美肥老太牲交大战 | 国内精品人妻无码久久久影院 | 丰满人妻精品国产99aⅴ | 欧洲熟妇色 欧美 | 日本一卡二卡不卡视频查询 | 老司机亚洲精品影院无码 | 国产人成高清在线视频99最全资源 | 5858s亚洲色大成网站www | 精品成人av一区二区三区 | 51国偷自产一区二区三区 | 欧美性猛交内射兽交老熟妇 | 国产尤物精品视频 | 久久久久av无码免费网 | 亚洲精品成人福利网站 | 女人被男人躁得好爽免费视频 | 偷窥日本少妇撒尿chinese | 婷婷综合久久中文字幕蜜桃三电影 | 高清无码午夜福利视频 | 高潮毛片无遮挡高清免费视频 | 久久国产精品精品国产色婷婷 | 好爽又高潮了毛片免费下载 | 亚洲精品一区国产 | 熟妇人妻无码xxx视频 | 日本熟妇浓毛 | 亚洲国产精品久久久久久 | 午夜精品久久久内射近拍高清 | 亚洲区欧美区综合区自拍区 | 小sao货水好多真紧h无码视频 | 国产无遮挡又黄又爽免费视频 | 色婷婷久久一区二区三区麻豆 | 日本大香伊一区二区三区 | 性色欲情网站iwww九文堂 | 亚洲色欲色欲天天天www | 99久久99久久免费精品蜜桃 | 小泽玛莉亚一区二区视频在线 | 日韩视频 中文字幕 视频一区 | 精品 日韩 国产 欧美 视频 | 久久亚洲中文字幕无码 | 无码人妻av免费一区二区三区 | 亚洲精品一区二区三区在线观看 | 国产成人精品三级麻豆 | 天堂久久天堂av色综合 | 国产精品高潮呻吟av久久4虎 | 亚洲精品欧美二区三区中文字幕 | 图片小说视频一区二区 | 99re在线播放 | 动漫av一区二区在线观看 | 国产精品亚洲五月天高清 | 中文字幕无码免费久久99 | 国产特级毛片aaaaaa高潮流水 | 久久精品99久久香蕉国产色戒 | 午夜福利不卡在线视频 | 久久久亚洲欧洲日产国码αv | 18无码粉嫩小泬无套在线观看 | 人妻少妇精品视频专区 | 成人性做爰aaa片免费看不忠 | 国产肉丝袜在线观看 | 精品无码国产自产拍在线观看蜜 | 国产香蕉尹人视频在线 | 无码午夜成人1000部免费视频 | 无码任你躁久久久久久久 | 玩弄人妻少妇500系列视频 | 国内精品一区二区三区不卡 | 日韩精品乱码av一区二区 | 熟妇人妻激情偷爽文 | 内射老妇bbwx0c0ck | 国产精品99爱免费视频 | 欧美日韩综合一区二区三区 | 精品偷自拍另类在线观看 | 无套内谢老熟女 | 又大又硬又黄的免费视频 | 伊人久久大香线蕉av一区二区 | 亚洲精品一区二区三区四区五区 | 女人高潮内射99精品 | 夜夜高潮次次欢爽av女 | 99久久精品午夜一区二区 | 国产精品国产自线拍免费软件 | 国内少妇偷人精品视频免费 | 亚洲精品久久久久avwww潮水 | 伊人久久大香线蕉午夜 | 精品偷拍一区二区三区在线看 | 性欧美videos高清精品 | 日韩精品一区二区av在线 | 亚洲综合无码久久精品综合 | 2020久久超碰国产精品最新 | 色 综合 欧美 亚洲 国产 | 精品水蜜桃久久久久久久 | 婷婷综合久久中文字幕蜜桃三电影 | 人人妻人人澡人人爽欧美精品 | 久久久www成人免费毛片 | 久久久久亚洲精品中文字幕 | 成人无码视频免费播放 | 久久午夜无码鲁丝片 | 国产亚洲欧美日韩亚洲中文色 | 精品久久久久久人妻无码中文字幕 | 亚洲欧美中文字幕5发布 | 狂野欧美性猛交免费视频 | 在线a亚洲视频播放在线观看 | 综合人妻久久一区二区精品 | 国产成人无码午夜视频在线观看 | 一个人看的视频www在线 | 内射巨臀欧美在线视频 | 日日天日日夜日日摸 | 中文毛片无遮挡高清免费 | 国产在热线精品视频 | 色妞www精品免费视频 | 久久久无码中文字幕久... | 国产激情一区二区三区 | 丝袜 中出 制服 人妻 美腿 | 亚洲啪av永久无码精品放毛片 | 精品乱码久久久久久久 | 无码av中文字幕免费放 | 1000部啪啪未满十八勿入下载 | 极品尤物被啪到呻吟喷水 | 骚片av蜜桃精品一区 | 久久亚洲日韩精品一区二区三区 | 亚洲小说图区综合在线 | 亚洲综合无码一区二区三区 | 樱花草在线播放免费中文 | 无码人妻出轨黑人中文字幕 | 国产免费久久精品国产传媒 | 久久久久久久久蜜桃 | 欧美黑人巨大xxxxx | 久久久av男人的天堂 | 国产午夜无码视频在线观看 | 少妇被黑人到高潮喷出白浆 | 55夜色66夜色国产精品视频 | 噜噜噜亚洲色成人网站 | 亚洲日本在线电影 | 国产在线无码精品电影网 | 国产麻豆精品一区二区三区v视界 | 精品国产麻豆免费人成网站 | 夜夜躁日日躁狠狠久久av | 又大又黄又粗又爽的免费视频 | 欧美日韩一区二区免费视频 | 欧美性色19p | 精品无码国产自产拍在线观看蜜 | 国产成人一区二区三区在线观看 | 搡女人真爽免费视频大全 | 自拍偷自拍亚洲精品10p | 鲁鲁鲁爽爽爽在线视频观看 | 亚洲欧洲无卡二区视頻 | 国产熟女一区二区三区四区五区 | 无码免费一区二区三区 | 精品国精品国产自在久国产87 | 熟女少妇人妻中文字幕 | 亚洲欧美中文字幕5发布 | 伊人久久大香线焦av综合影院 | 天堂一区人妻无码 | 久久国产精品偷任你爽任你 | 欧美猛少妇色xxxxx | 久久久久久av无码免费看大片 | 在线播放亚洲第一字幕 | 日产精品高潮呻吟av久久 | 色综合久久中文娱乐网 | 伊人久久大香线焦av综合影院 | 国产亚洲精品精品国产亚洲综合 | 一本精品99久久精品77 | 精品久久久无码人妻字幂 | 中文字幕久久久久人妻 | 亚洲男人av香蕉爽爽爽爽 | 97se亚洲精品一区 | 人人澡人摸人人添 | 国产成人无码av片在线观看不卡 | 麻豆国产人妻欲求不满谁演的 | 日本在线高清不卡免费播放 | 熟女俱乐部五十路六十路av | 好男人社区资源 | 中文字幕乱码人妻二区三区 | 99精品视频在线观看免费 | 成 人 免费观看网站 | 荫蒂被男人添的好舒服爽免费视频 | 国产精品久久久久久亚洲影视内衣 | 免费国产成人高清在线观看网站 | 亚洲の无码国产の无码影院 | 大色综合色综合网站 | 亚洲精品国偷拍自产在线麻豆 | 初尝人妻少妇中文字幕 | 思思久久99热只有频精品66 | 最近的中文字幕在线看视频 | 亚洲欧美精品伊人久久 | 无码人妻av免费一区二区三区 | 日本大乳高潮视频在线观看 | 久久 国产 尿 小便 嘘嘘 | 亚洲成a人一区二区三区 | 国产人妻久久精品二区三区老狼 | 日本欧美一区二区三区乱码 | 国产一区二区三区日韩精品 | 国产亚洲精品久久久久久久 | 超碰97人人做人人爱少妇 | 7777奇米四色成人眼影 | 国产精品高潮呻吟av久久4虎 | 国产一区二区三区日韩精品 | 久久午夜无码鲁丝片午夜精品 | 水蜜桃av无码 | 欧美 亚洲 国产 另类 | 大地资源网第二页免费观看 | 国产口爆吞精在线视频 | 国产精品香蕉在线观看 | 少妇高潮喷潮久久久影院 | 自拍偷自拍亚洲精品被多人伦好爽 | 性色欲网站人妻丰满中文久久不卡 | 露脸叫床粗话东北少妇 | 国产亚洲欧美在线专区 | 午夜性刺激在线视频免费 | 久久国产精品偷任你爽任你 | 牲欲强的熟妇农村老妇女 | 亚洲无人区午夜福利码高清完整版 | 久久久久久av无码免费看大片 | 精品国产青草久久久久福利 | 亚洲の无码国产の无码影院 | 中国女人内谢69xxxxxa片 | 精品一区二区三区波多野结衣 | 国产精华av午夜在线观看 | 久久久久免费看成人影片 | 国产情侣作爱视频免费观看 | 国产极品美女高潮无套在线观看 | 欧美国产日韩久久mv | 精品人人妻人人澡人人爽人人 | 18禁止看的免费污网站 | 亚洲日本va中文字幕 | 日韩精品一区二区av在线 | 鲁大师影院在线观看 | 久久国产精品精品国产色婷婷 | 精品国产乱码久久久久乱码 | 鲁大师影院在线观看 | 少妇厨房愉情理9仑片视频 | 欧美第一黄网免费网站 | 色婷婷香蕉在线一区二区 | 精品无码国产自产拍在线观看蜜 | 国产亚洲欧美在线专区 | 欧美一区二区三区视频在线观看 | 四十如虎的丰满熟妇啪啪 | 暴力强奷在线播放无码 | 男女爱爱好爽视频免费看 | 伊人久久大香线蕉午夜 | 国产乱人伦av在线无码 | 无遮挡啪啪摇乳动态图 | 日韩欧美中文字幕公布 | 97se亚洲精品一区 | 欧美 丝袜 自拍 制服 另类 | 亚洲狠狠婷婷综合久久 | 大肉大捧一进一出好爽视频 | 波多野结衣高清一区二区三区 | 丰满岳乱妇在线观看中字无码 | 国产高清av在线播放 | 国产97人人超碰caoprom | 99久久精品日本一区二区免费 | 国产亚洲人成a在线v网站 | 日本熟妇乱子伦xxxx | 亚洲国产精品毛片av不卡在线 | 亚洲一区二区三区香蕉 | 扒开双腿吃奶呻吟做受视频 | 国产精品理论片在线观看 | 精品日本一区二区三区在线观看 | 少妇高潮一区二区三区99 | 国产麻豆精品精东影业av网站 | 亚洲а∨天堂久久精品2021 | 日韩少妇白浆无码系列 | 天天综合网天天综合色 | 久久国产自偷自偷免费一区调 | 国产农村乱对白刺激视频 | 香蕉久久久久久av成人 | 伊人久久大香线蕉午夜 | 丰满少妇女裸体bbw | 人妻少妇精品无码专区动漫 | 亚洲熟妇色xxxxx欧美老妇y | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 波多野结衣高清一区二区三区 | 国产精品久久久久9999小说 | 无码人妻精品一区二区三区不卡 | 国产精品毛片一区二区 | 骚片av蜜桃精品一区 | 性做久久久久久久免费看 | 无遮挡啪啪摇乳动态图 | 亚洲日韩精品欧美一区二区 | √8天堂资源地址中文在线 | 丰满护士巨好爽好大乳 | 精品久久8x国产免费观看 | 牛和人交xxxx欧美 | 国产情侣作爱视频免费观看 | 欧美色就是色 | 日韩精品无码免费一区二区三区 | 国产色xx群视频射精 | 中文字幕无码免费久久99 | 亚洲人成影院在线观看 | 亚洲欧美色中文字幕在线 | 欧美黑人巨大xxxxx | аⅴ资源天堂资源库在线 | 色综合视频一区二区三区 | 老子影院午夜伦不卡 | 水蜜桃亚洲一二三四在线 | 亚洲 高清 成人 动漫 | 精品偷自拍另类在线观看 | 色五月五月丁香亚洲综合网 | 日韩精品无码一区二区中文字幕 | 国产精品欧美成人 | 亚洲一区二区三区播放 | 曰本女人与公拘交酡免费视频 | 久久人人爽人人爽人人片av高清 | 性欧美疯狂xxxxbbbb | 无码国模国产在线观看 | 丰满人妻一区二区三区免费视频 | 黑人大群体交免费视频 | 天堂无码人妻精品一区二区三区 | 97精品人妻一区二区三区香蕉 | 捆绑白丝粉色jk震动捧喷白浆 | av在线亚洲欧洲日产一区二区 | 性色av无码免费一区二区三区 | 国产亲子乱弄免费视频 | 国内精品一区二区三区不卡 | 十八禁真人啪啪免费网站 | 日本又色又爽又黄的a片18禁 | 无码中文字幕色专区 | 88国产精品欧美一区二区三区 | 亚洲精品无码人妻无码 | 日日碰狠狠丁香久燥 | 国产精品高潮呻吟av久久 | 亚洲一区二区三区含羞草 | 丝袜美腿亚洲一区二区 | 日本欧美一区二区三区乱码 | 2019nv天堂香蕉在线观看 | 国产精品嫩草久久久久 | 伊人久久大香线蕉av一区二区 | 日欧一片内射va在线影院 | 久久综合网欧美色妞网 | 人妻夜夜爽天天爽三区 | 少妇性荡欲午夜性开放视频剧场 | 亚洲精品国产第一综合99久久 | 最近的中文字幕在线看视频 | 精品久久久久香蕉网 | ass日本丰满熟妇pics | 精品一区二区不卡无码av | 激情综合激情五月俺也去 | 大乳丰满人妻中文字幕日本 | 99久久久无码国产aaa精品 | 日本一区二区三区免费高清 | 色一情一乱一伦 | 日本丰满熟妇videos | 狂野欧美性猛交免费视频 | 免费看男女做好爽好硬视频 | 1000部啪啪未满十八勿入下载 | av在线亚洲欧洲日产一区二区 | 曰韩无码二三区中文字幕 | 成人影院yy111111在线观看 | 国产精品沙发午睡系列 | 国产成人一区二区三区在线观看 | 四虎影视成人永久免费观看视频 | 亚洲自偷精品视频自拍 | 国模大胆一区二区三区 | 99久久99久久免费精品蜜桃 | 四十如虎的丰满熟妇啪啪 | 久久人人爽人人爽人人片av高清 | 色欲久久久天天天综合网精品 | 久9re热视频这里只有精品 | 亚洲综合久久一区二区 | 久久久久久久久蜜桃 | 荫蒂添的好舒服视频囗交 | 人人澡人人透人人爽 | 四虎影视成人永久免费观看视频 | 国产极品视觉盛宴 | 亚洲人成网站色7799 | 欧美日韩色另类综合 | 樱花草在线播放免费中文 | 日本精品少妇一区二区三区 | 又粗又大又硬毛片免费看 | 国内精品久久久久久中文字幕 | 亚洲成a人片在线观看日本 | 日韩 欧美 动漫 国产 制服 | 亚洲国产欧美日韩精品一区二区三区 | 给我免费的视频在线观看 | 一本色道久久综合狠狠躁 | 少妇性l交大片欧洲热妇乱xxx | 无码av岛国片在线播放 | 国产偷抇久久精品a片69 | 无码纯肉视频在线观看 | 成人影院yy111111在线观看 | 无码任你躁久久久久久久 | v一区无码内射国产 | 装睡被陌生人摸出水好爽 | 国产特级毛片aaaaaaa高清 | 日韩亚洲欧美中文高清在线 | 无码一区二区三区在线观看 | 国产凸凹视频一区二区 | 国产亚洲欧美在线专区 | 精品国产精品久久一区免费式 | 国产精品无码久久av | 国产免费观看黄av片 | √天堂资源地址中文在线 | 国産精品久久久久久久 | 久久99国产综合精品 | 国产成人综合美国十次 | 国产真实乱对白精彩久久 | 国产成人精品视频ⅴa片软件竹菊 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 又粗又大又硬又长又爽 | 国产亚洲精品久久久久久国模美 | 熟妇人妻中文av无码 | 无码av免费一区二区三区试看 | 国产精品久久久久影院嫩草 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 熟妇人妻激情偷爽文 | 一区二区三区高清视频一 | 乱中年女人伦av三区 | 日本欧美一区二区三区乱码 | 亚洲欧美国产精品专区久久 | 嫩b人妻精品一区二区三区 | 国产97色在线 | 免 | 性开放的女人aaa片 | 一区二区三区高清视频一 | 伊人色综合久久天天小片 | 婷婷综合久久中文字幕蜜桃三电影 | 暴力强奷在线播放无码 | 久久精品中文闷骚内射 | 性生交大片免费看女人按摩摩 | 欧美 丝袜 自拍 制服 另类 | 欧美高清在线精品一区 | 色婷婷综合激情综在线播放 | 久久精品人妻少妇一区二区三区 | 久久zyz资源站无码中文动漫 | 色一情一乱一伦一视频免费看 | 国产精品久久久久无码av色戒 | 成人影院yy111111在线观看 | 国产一区二区三区影院 | 日本大乳高潮视频在线观看 | 婷婷丁香六月激情综合啪 | 国产偷抇久久精品a片69 | 少妇一晚三次一区二区三区 | 国产精品99爱免费视频 | 丝袜足控一区二区三区 | 日本精品少妇一区二区三区 | 亚洲gv猛男gv无码男同 | 四虎影视成人永久免费观看视频 | 午夜福利一区二区三区在线观看 | 在线观看国产一区二区三区 | 丰满人妻一区二区三区免费视频 | 99久久精品国产一区二区蜜芽 | 在线视频网站www色 | 在线看片无码永久免费视频 | 熟妇人妻中文av无码 | 对白脏话肉麻粗话av | 久久人人爽人人爽人人片ⅴ | 国产亚洲精品久久久久久久久动漫 | 漂亮人妻洗澡被公强 日日躁 | 色偷偷人人澡人人爽人人模 | 免费网站看v片在线18禁无码 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产偷抇久久精品a片69 | 国产口爆吞精在线视频 | 国产97色在线 | 免 | 97无码免费人妻超级碰碰夜夜 | 亚洲欧美日韩国产精品一区二区 | 乱人伦中文视频在线观看 | 丰腴饱满的极品熟妇 | 久久99精品久久久久婷婷 | 亚洲国产一区二区三区在线观看 | 中文字幕 亚洲精品 第1页 | 亚洲 a v无 码免 费 成 人 a v | 日本精品久久久久中文字幕 | 亚洲精品成人福利网站 | 亚洲人成无码网www | 国精品人妻无码一区二区三区蜜柚 | 亚洲国产日韩a在线播放 | 精品乱子伦一区二区三区 | 亚洲男人av天堂午夜在 | 免费乱码人妻系列无码专区 | 97se亚洲精品一区 | 日日躁夜夜躁狠狠躁 | 国产亚洲欧美日韩亚洲中文色 | 亚洲精品久久久久久一区二区 | 2020久久香蕉国产线看观看 | 国产成人精品无码播放 | 亚洲大尺度无码无码专区 | 久久亚洲中文字幕精品一区 | 娇妻被黑人粗大高潮白浆 | 无套内谢的新婚少妇国语播放 | 免费观看又污又黄的网站 | 无码人妻av免费一区二区三区 | 无套内谢的新婚少妇国语播放 | 日本在线高清不卡免费播放 | 亚洲精品欧美二区三区中文字幕 | 国产婷婷色一区二区三区在线 | 国产精品二区一区二区aⅴ污介绍 | 中文字幕日产无线码一区 | 亚洲中文字幕在线观看 | 一本色道婷婷久久欧美 | 国产综合久久久久鬼色 | 99久久精品午夜一区二区 | 粗大的内捧猛烈进出视频 | 久久亚洲a片com人成 | 国产综合在线观看 | 在线播放无码字幕亚洲 | 曰韩无码二三区中文字幕 | 国产美女极度色诱视频www | 国产精品igao视频网 | 国产黄在线观看免费观看不卡 | 亚洲色无码一区二区三区 | 午夜肉伦伦影院 | 亚洲精品国产a久久久久久 | 亚洲中文字幕无码中字 | 国产成人人人97超碰超爽8 | 亚洲自偷精品视频自拍 | 欧美黑人性暴力猛交喷水 | 久久午夜无码鲁丝片午夜精品 | 亚洲爆乳精品无码一区二区三区 | 国内综合精品午夜久久资源 | 亚洲欧美日韩成人高清在线一区 | 久久午夜无码鲁丝片秋霞 | 夜夜高潮次次欢爽av女 | 波多野42部无码喷潮在线 | 51国偷自产一区二区三区 | 亚洲日韩一区二区三区 | 六月丁香婷婷色狠狠久久 | 国产偷抇久久精品a片69 | 久久久精品国产sm最大网站 | 日韩欧美中文字幕公布 | 一个人看的www免费视频在线观看 | 国产亚洲美女精品久久久2020 | 亚洲精品成人福利网站 | 亚洲精品国产a久久久久久 | 国产婷婷色一区二区三区在线 | 国产人妻精品一区二区三区不卡 | 久久99热只有频精品8 | 日本丰满熟妇videos | 国产成人精品久久亚洲高清不卡 | 国产口爆吞精在线视频 | 精品夜夜澡人妻无码av蜜桃 | 国产手机在线αⅴ片无码观看 | 无码人妻丰满熟妇区五十路百度 | 欧美老熟妇乱xxxxx | 亚洲一区二区观看播放 | 亚洲精品一区二区三区在线观看 | 人妻中文无码久热丝袜 | 久久精品丝袜高跟鞋 | 国产色在线 | 国产 | 中文字幕色婷婷在线视频 | 亚洲一区二区三区四区 | 欧美乱妇无乱码大黄a片 | 麻豆国产人妻欲求不满谁演的 | 国产精品久久久久久亚洲毛片 | 性欧美牲交在线视频 | 曰本女人与公拘交酡免费视频 | 国产精品久久久久久亚洲影视内衣 | 久久综合色之久久综合 | 亚洲乱码日产精品bd | 香港三级日本三级妇三级 | 亚洲精品一区二区三区婷婷月 | 日本大乳高潮视频在线观看 | 麻豆精产国品 | 又大又硬又黄的免费视频 | 久久午夜无码鲁丝片秋霞 | 国产成人综合在线女婷五月99播放 | 日本www一道久久久免费榴莲 | 无码吃奶揉捏奶头高潮视频 | 国语精品一区二区三区 | 一本久久a久久精品vr综合 | 国产成人精品一区二区在线小狼 | 帮老师解开蕾丝奶罩吸乳网站 | 无码帝国www无码专区色综合 | 国产成人精品久久亚洲高清不卡 | 一本加勒比波多野结衣 | 欧美性猛交xxxx富婆 | 国精产品一区二区三区 | 色一情一乱一伦一视频免费看 | 中文字幕 亚洲精品 第1页 | 国产肉丝袜在线观看 | 国产精品毛多多水多 | 奇米影视888欧美在线观看 | 永久黄网站色视频免费直播 | 在线 国产 欧美 亚洲 天堂 | 久久99精品久久久久久 | 999久久久国产精品消防器材 | 亚洲中文无码av永久不收费 | 特大黑人娇小亚洲女 | 女高中生第一次破苞av | 麻豆国产丝袜白领秘书在线观看 | 大地资源网第二页免费观看 | 国产精品资源一区二区 | 色诱久久久久综合网ywww | 无码纯肉视频在线观看 | 国产午夜亚洲精品不卡 | 日本欧美一区二区三区乱码 | 久久亚洲中文字幕精品一区 | 野狼第一精品社区 | 亚洲熟悉妇女xxx妇女av | 鲁一鲁av2019在线 | 亚洲色无码一区二区三区 | 日本一本二本三区免费 | 在线观看免费人成视频 | 撕开奶罩揉吮奶头视频 | 国产xxx69麻豆国语对白 | 亚洲七七久久桃花影院 | 丰满护士巨好爽好大乳 | 丰满人妻被黑人猛烈进入 | 黑人玩弄人妻中文在线 | 97精品国产97久久久久久免费 | 色欲av亚洲一区无码少妇 | 午夜丰满少妇性开放视频 | 日韩精品无码免费一区二区三区 | 亚洲精品一区二区三区大桥未久 | 国产人妻精品一区二区三区不卡 | 亚洲小说图区综合在线 | 一本久道久久综合婷婷五月 | 成人欧美一区二区三区 | 少妇久久久久久人妻无码 | 色综合久久久无码中文字幕 | 国产亚洲欧美日韩亚洲中文色 | 色 综合 欧美 亚洲 国产 | 十八禁视频网站在线观看 | 精品一区二区三区无码免费视频 | 国产精品久久久久久亚洲影视内衣 | 日本丰满熟妇videos | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲 另类 在线 欧美 制服 | 女人被爽到呻吟gif动态图视看 | 精品偷自拍另类在线观看 | 人妻与老人中文字幕 | 精品aⅴ一区二区三区 | 美女扒开屁股让男人桶 | 中文无码成人免费视频在线观看 | 精品国产aⅴ无码一区二区 | 国精产品一品二品国精品69xx | 色综合久久88色综合天天 | 欧美放荡的少妇 | 亚洲精品成人福利网站 | 日本又色又爽又黄的a片18禁 | 国产偷自视频区视频 | 极品尤物被啪到呻吟喷水 | 精品一区二区三区波多野结衣 | 牲交欧美兽交欧美 | 免费播放一区二区三区 | 熟女俱乐部五十路六十路av | 成人三级无码视频在线观看 | 欧美日韩在线亚洲综合国产人 | 成人精品视频一区二区 | 亚洲爆乳无码专区 | 日产精品99久久久久久 | 中文字幕av无码一区二区三区电影 | 亚洲国产精品一区二区美利坚 | 中文字幕无码免费久久9一区9 | 亚洲成av人片在线观看无码不卡 | 国产成人亚洲综合无码 | 国产精品亚洲а∨无码播放麻豆 | 强奷人妻日本中文字幕 | 伦伦影院午夜理论片 | 又大又黄又粗又爽的免费视频 | 精品一二三区久久aaa片 | 女人高潮内射99精品 | 成人性做爰aaa片免费看不忠 | 亚洲精品一区二区三区四区五区 | 中文字幕乱码人妻二区三区 | 精品国产成人一区二区三区 | 丰满人妻一区二区三区免费视频 | 国产深夜福利视频在线 | 亚洲 日韩 欧美 成人 在线观看 | 国产热a欧美热a在线视频 | 国产亚洲人成a在线v网站 | 亚洲第一网站男人都懂 | 日韩精品无码一本二本三本色 | 久久婷婷五月综合色国产香蕉 | 欧美成人家庭影院 | 欧美国产日韩久久mv | 日韩亚洲欧美精品综合 | 精品国产精品久久一区免费式 | 成人女人看片免费视频放人 | 国产无遮挡又黄又爽又色 | 亚洲熟妇色xxxxx欧美老妇y | 真人与拘做受免费视频一 | 人妻少妇精品无码专区动漫 | 波多野结衣一区二区三区av免费 | 色五月丁香五月综合五月 | 国产亚洲精品久久久久久久久动漫 | 色一情一乱一伦 | 亚洲欧美日韩成人高清在线一区 | 夜夜影院未满十八勿进 | 六十路熟妇乱子伦 | 青草青草久热国产精品 | 久久久婷婷五月亚洲97号色 | 亚洲精品国产精品乱码视色 | 毛片内射-百度 | 99在线 | 亚洲 | 最近的中文字幕在线看视频 | 久久久久99精品成人片 | 久久aⅴ免费观看 | 久久午夜无码鲁丝片 | 水蜜桃色314在线观看 | 偷窥日本少妇撒尿chinese | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲爆乳无码专区 | 亚洲gv猛男gv无码男同 | 亚洲中文字幕av在天堂 | 性欧美videos高清精品 | 欧美成人免费全部网站 | 中文字幕乱码人妻无码久久 | 国产成人综合色在线观看网站 | www国产精品内射老师 | 天堂亚洲2017在线观看 | 国产成人精品视频ⅴa片软件竹菊 | 免费观看又污又黄的网站 | 亚洲精品无码人妻无码 | 亚洲一区二区三区含羞草 | 国产疯狂伦交大片 | 亚洲色偷偷男人的天堂 | 1000部夫妻午夜免费 | 日韩人妻系列无码专区 | 亚洲乱亚洲乱妇50p | 在线视频网站www色 | 99精品国产综合久久久久五月天 | 内射爽无广熟女亚洲 | 九九在线中文字幕无码 | 国产精品无码永久免费888 | 日本饥渴人妻欲求不满 | 中文字幕色婷婷在线视频 | 亚洲男人av香蕉爽爽爽爽 | 在线亚洲高清揄拍自拍一品区 | 中文字幕av日韩精品一区二区 | 亚洲熟女一区二区三区 | 精品无码成人片一区二区98 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲乱码日产精品bd | 国产超碰人人爽人人做人人添 | 妺妺窝人体色www在线小说 | 国产精品久久久久久亚洲影视内衣 | a片免费视频在线观看 | 日韩精品无码一区二区中文字幕 | 黑人粗大猛烈进出高潮视频 | 黑人粗大猛烈进出高潮视频 | 无码成人精品区在线观看 | 青草视频在线播放 | 久久久久久久久蜜桃 | 久久久国产精品无码免费专区 | 成人动漫在线观看 | 中文字幕无码视频专区 | 欧美变态另类xxxx | aa片在线观看视频在线播放 | 成人无码影片精品久久久 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 奇米影视888欧美在线观看 | 久久久久久a亚洲欧洲av冫 | 亚洲乱码中文字幕在线 | 99久久精品日本一区二区免费 | а√天堂www在线天堂小说 | 久久久久久九九精品久 | 亚洲精品国产精品乱码视色 | 乱码av麻豆丝袜熟女系列 | 免费中文字幕日韩欧美 | 精品国产一区av天美传媒 | 亚洲 欧美 激情 小说 另类 | 国产激情无码一区二区 | 国产va免费精品观看 | 精品国产一区二区三区四区在线看 | 色五月丁香五月综合五月 | 全球成人中文在线 | 欧美 日韩 人妻 高清 中文 | 性啪啪chinese东北女人 | 亚洲欧美精品aaaaaa片 | 乱人伦人妻中文字幕无码 | 亚洲欧美日韩国产精品一区二区 | 人妻中文无码久热丝袜 | 一本无码人妻在中文字幕免费 | 中文字幕无码免费久久9一区9 | 久久久精品人妻久久影视 | 夜精品a片一区二区三区无码白浆 | 人妻中文无码久热丝袜 | 人妻人人添人妻人人爱 | 7777奇米四色成人眼影 | 男女性色大片免费网站 | 国产性生大片免费观看性 | 老司机亚洲精品影院无码 | 激情综合激情五月俺也去 | 国精产品一品二品国精品69xx | 欧美大屁股xxxxhd黑色 | 欧洲欧美人成视频在线 | 国产卡一卡二卡三 | 精品国产一区av天美传媒 | 亚洲成av人综合在线观看 | 亚洲 日韩 欧美 成人 在线观看 | 无人区乱码一区二区三区 | 日产精品99久久久久久 | 亚洲自偷自拍另类第1页 | 国产99久久精品一区二区 | 国产成人一区二区三区别 | 国产免费久久久久久无码 | 亚洲熟妇色xxxxx亚洲 | 一本精品99久久精品77 | 亚洲国产欧美国产综合一区 | 精品国产乱码久久久久乱码 | 伊人久久大香线焦av综合影院 | 亚洲第一无码av无码专区 | 亚洲国产成人av在线观看 | 人妻少妇精品无码专区动漫 | 国产午夜福利亚洲第一 | 国产va免费精品观看 | 精品国产青草久久久久福利 | 欧美日韩视频无码一区二区三 | 亚洲综合无码久久精品综合 | 国产精品爱久久久久久久 | 亚洲国产欧美国产综合一区 | 国产精品二区一区二区aⅴ污介绍 | 免费无码肉片在线观看 | 亚洲欧美日韩综合久久久 | 内射巨臀欧美在线视频 | 97无码免费人妻超级碰碰夜夜 | 欧美成人高清在线播放 | 亚洲狠狠婷婷综合久久 | 性啪啪chinese东北女人 | 大肉大捧一进一出视频出来呀 | 国产精品久久久av久久久 | а√天堂www在线天堂小说 | 国产精品永久免费视频 | 一个人看的www免费视频在线观看 | 妺妺窝人体色www在线小说 | 国内综合精品午夜久久资源 | 俺去俺来也在线www色官网 | 性欧美videos高清精品 | 国产69精品久久久久app下载 | 亚洲日本一区二区三区在线 | 亚洲成a人片在线观看日本 | 日日噜噜噜噜夜夜爽亚洲精品 | 3d动漫精品啪啪一区二区中 | 狂野欧美激情性xxxx | 成人一在线视频日韩国产 | 美女黄网站人色视频免费国产 | 精品国产av色一区二区深夜久久 | 亚洲精品一区二区三区在线 | 曰韩少妇内射免费播放 | 亚洲色偷偷男人的天堂 | 亚洲精品中文字幕久久久久 | 中文久久乱码一区二区 | 日日躁夜夜躁狠狠躁 | 国产精品18久久久久久麻辣 | 少妇人妻偷人精品无码视频 | 亚洲第一网站男人都懂 | 午夜熟女插插xx免费视频 | 亚洲精品成人av在线 | 亚洲娇小与黑人巨大交 | 在教室伦流澡到高潮hnp视频 | 曰韩少妇内射免费播放 | 欧美亚洲日韩国产人成在线播放 | 国产人妻人伦精品1国产丝袜 | 欧美性黑人极品hd | 乱人伦中文视频在线观看 | 国产成人精品视频ⅴa片软件竹菊 | 免费人成在线观看网站 | 成在人线av无码免费 | 一本久道久久综合狠狠爱 | 亚洲伊人久久精品影院 | 最新国产麻豆aⅴ精品无码 | 欧美丰满少妇xxxx性 | 亚洲精品国产精品乱码视色 | 人人爽人人澡人人高潮 | 人妻中文无码久热丝袜 | 国产偷抇久久精品a片69 | 男女猛烈xx00免费视频试看 | 男女猛烈xx00免费视频试看 | 久在线观看福利视频 | 亚洲の无码国产の无码步美 | 色一情一乱一伦一区二区三欧美 | 成人免费无码大片a毛片 | 亚洲精品国产精品乱码不卡 | 国产精品久久久久久久9999 | 日本一区二区更新不卡 | 76少妇精品导航 | 久久人妻内射无码一区三区 | 国产超级va在线观看视频 | 亚洲中文字幕成人无码 | 波多野结衣高清一区二区三区 | 欧美怡红院免费全部视频 | 久久久久久亚洲精品a片成人 | 夜夜高潮次次欢爽av女 | 精品厕所偷拍各类美女tp嘘嘘 | 色一情一乱一伦一视频免费看 | 精品厕所偷拍各类美女tp嘘嘘 | 日本肉体xxxx裸交 | 午夜精品久久久久久久久 | 天堂亚洲免费视频 | 一本精品99久久精品77 | 蜜桃视频韩日免费播放 | 成人一区二区免费视频 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产亚洲美女精品久久久2020 | 中国大陆精品视频xxxx | 伊在人天堂亚洲香蕉精品区 | 狠狠cao日日穞夜夜穞av | 成人免费视频视频在线观看 免费 | 午夜精品一区二区三区的区别 | 婷婷丁香五月天综合东京热 | 大胆欧美熟妇xx | 奇米影视7777久久精品人人爽 | 在线成人www免费观看视频 | 国产xxx69麻豆国语对白 | 亚洲a无码综合a国产av中文 | 国产绳艺sm调教室论坛 | 欧美日韩一区二区三区自拍 | 日韩精品无码免费一区二区三区 | 亚洲码国产精品高潮在线 | www一区二区www免费 | 99在线 | 亚洲 | 日韩精品一区二区av在线 | 国产精品国产自线拍免费软件 | 成在人线av无码免费 | www国产亚洲精品久久久日本 | 麻豆成人精品国产免费 | 亚洲区小说区激情区图片区 | 成人女人看片免费视频放人 | 欧美丰满熟妇xxxx | 女高中生第一次破苞av | 性生交片免费无码看人 | 377p欧洲日本亚洲大胆 | 国产精品.xx视频.xxtv | 无码帝国www无码专区色综合 | 一本精品99久久精品77 | 色欲久久久天天天综合网精品 | 国产精品99爱免费视频 | 精品国产一区二区三区四区在线看 | 亚洲精品国偷拍自产在线观看蜜桃 | 东京无码熟妇人妻av在线网址 | 欧美肥老太牲交大战 | 国产综合色产在线精品 | 久久久精品欧美一区二区免费 | 欧美高清在线精品一区 | 国产精品久久精品三级 | 国产区女主播在线观看 | 国精品人妻无码一区二区三区蜜柚 | 精品亚洲成av人在线观看 | 老熟妇乱子伦牲交视频 | 国产精品久久久久无码av色戒 | 日本精品人妻无码免费大全 | 日本熟妇乱子伦xxxx | 国色天香社区在线视频 | 久久婷婷五月综合色国产香蕉 | 欧美 日韩 人妻 高清 中文 | 国产精品爱久久久久久久 | 亚洲自偷精品视频自拍 | 精品国产aⅴ无码一区二区 | 人妻少妇被猛烈进入中文字幕 | 国产极品视觉盛宴 | 日本xxxx色视频在线观看免费 | 3d动漫精品啪啪一区二区中 | 国产精品久久久久无码av色戒 | 欧美刺激性大交 | 亚洲a无码综合a国产av中文 | 日韩精品无码一区二区中文字幕 | 女人色极品影院 | 久久99国产综合精品 | 亚洲国产欧美在线成人 | 亚洲熟妇自偷自拍另类 | 亚洲精品欧美二区三区中文字幕 | 无套内谢的新婚少妇国语播放 | 国产色在线 | 国产 | 亚洲精品成a人在线观看 | 久久久国产精品无码免费专区 | 色综合久久久久综合一本到桃花网 | 女人被男人爽到呻吟的视频 | 亚洲欧美中文字幕5发布 | 国产午夜亚洲精品不卡下载 | 免费网站看v片在线18禁无码 | 自拍偷自拍亚洲精品被多人伦好爽 | 少女韩国电视剧在线观看完整 | 久久国产精品_国产精品 | 丰满人妻一区二区三区免费视频 | 少妇高潮喷潮久久久影院 | aⅴ亚洲 日韩 色 图网站 播放 | 国产午夜福利100集发布 | 亚洲国产精品毛片av不卡在线 | 免费看男女做好爽好硬视频 | 色婷婷av一区二区三区之红樱桃 | 国产成人无码区免费内射一片色欲 | 波多野结衣高清一区二区三区 | 欧美色就是色 | 强开小婷嫩苞又嫩又紧视频 | 好屌草这里只有精品 | 天干天干啦夜天干天2017 | 国产免费无码一区二区视频 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 伊人久久婷婷五月综合97色 | 中文无码成人免费视频在线观看 | 天堂а√在线地址中文在线 | 国产熟女一区二区三区四区五区 | 蜜桃无码一区二区三区 | 高清不卡一区二区三区 | 全球成人中文在线 | 国产亚洲精品久久久久久国模美 | 国产精品成人av在线观看 | 国产亚洲精品久久久闺蜜 | 国产精品永久免费视频 | 曰韩无码二三区中文字幕 | 在线视频网站www色 | 伊人久久大香线焦av综合影院 | 成人综合网亚洲伊人 | 国产亚洲精品久久久久久 | 国产国产精品人在线视 | 无码午夜成人1000部免费视频 | 亚洲色www成人永久网址 | 欧美一区二区三区视频在线观看 | 婷婷丁香六月激情综合啪 | 亚洲人成人无码网www国产 | 大乳丰满人妻中文字幕日本 | 亚洲日本va午夜在线电影 | 日韩av无码中文无码电影 | 国产精品久久久一区二区三区 | 免费人成在线视频无码 | 无码吃奶揉捏奶头高潮视频 | 精品国偷自产在线 | 国产午夜视频在线观看 | 亚洲精品中文字幕久久久久 | 久青草影院在线观看国产 | 亚洲人成网站免费播放 | 欧洲熟妇精品视频 | 国产精品久久久一区二区三区 | 午夜精品久久久久久久 | 中文字幕av无码一区二区三区电影 | www成人国产高清内射 | 天天拍夜夜添久久精品大 | 人人爽人人澡人人高潮 | 曰韩无码二三区中文字幕 | 日本饥渴人妻欲求不满 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲国产一区二区三区在线观看 | 欧美国产日产一区二区 | 激情内射亚州一区二区三区爱妻 | 亚洲天堂2017无码中文 | 少妇愉情理伦片bd | 亚洲色欲久久久综合网东京热 | 性生交片免费无码看人 | 2019午夜福利不卡片在线 | 精品国产一区二区三区四区 | 久久久亚洲欧洲日产国码αv | 强伦人妻一区二区三区视频18 | 无码av中文字幕免费放 | 成人性做爰aaa片免费看 | 亚洲综合色区中文字幕 | 日韩人妻无码一区二区三区久久99 | 又大又黄又粗又爽的免费视频 | 欧美野外疯狂做受xxxx高潮 | 中文字幕无码乱人伦 | 永久黄网站色视频免费直播 | 亚洲人成人无码网www国产 | 无码av免费一区二区三区试看 | 麻豆国产人妻欲求不满谁演的 | 一本久久a久久精品vr综合 | 18精品久久久无码午夜福利 | 无码午夜成人1000部免费视频 | 国产成人av免费观看 | 自拍偷自拍亚洲精品10p | 精品国产福利一区二区 | 日日摸天天摸爽爽狠狠97 | 亚洲成av人片在线观看无码不卡 | 激情内射亚州一区二区三区爱妻 | 日本在线高清不卡免费播放 | 久激情内射婷内射蜜桃人妖 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产人妖乱国产精品人妖 | 天堂а√在线地址中文在线 | 日本又色又爽又黄的a片18禁 | 少妇人妻大乳在线视频 | 又大又硬又黄的免费视频 | 亚洲日韩一区二区三区 | 久久久久久久久蜜桃 | 露脸叫床粗话东北少妇 | 日本熟妇大屁股人妻 | 国产精品久久福利网站 | 麻花豆传媒剧国产免费mv在线 | 国产一区二区三区精品视频 | 国产免费无码一区二区视频 | 两性色午夜视频免费播放 | 精品国产一区二区三区四区 | 国产av人人夜夜澡人人爽麻豆 | 精品无人区无码乱码毛片国产 | 亚洲综合精品香蕉久久网 | 国产成人亚洲综合无码 | 亚洲欧美色中文字幕在线 | 国产av一区二区三区最新精品 | √8天堂资源地址中文在线 | 亚洲日韩中文字幕在线播放 | 日欧一片内射va在线影院 | 国内精品九九久久久精品 | 国产乱人偷精品人妻a片 | 免费人成网站视频在线观看 | 亚洲国产av美女网站 | 久久久久久九九精品久 | 5858s亚洲色大成网站www | 亚洲乱码国产乱码精品精 | 少妇厨房愉情理9仑片视频 | 色婷婷久久一区二区三区麻豆 | 中文字幕无码免费久久9一区9 | 成人无码视频免费播放 | 中文精品无码中文字幕无码专区 | 暴力强奷在线播放无码 | 久久精品人妻少妇一区二区三区 | 国产乱子伦视频在线播放 | 扒开双腿吃奶呻吟做受视频 | 国产9 9在线 | 中文 | 亚洲热妇无码av在线播放 | 亚洲精品一区二区三区四区五区 | 狠狠色噜噜狠狠狠狠7777米奇 | a片免费视频在线观看 | 久久97精品久久久久久久不卡 | 亚洲色成人中文字幕网站 | 亚洲s色大片在线观看 | 青草青草久热国产精品 | 日韩精品a片一区二区三区妖精 | 亚洲精品成a人在线观看 | 中文字幕亚洲情99在线 | 偷窥日本少妇撒尿chinese | 精品人妻人人做人人爽夜夜爽 | 欧美野外疯狂做受xxxx高潮 | 人妻无码αv中文字幕久久琪琪布 | 国产成人无码区免费内射一片色欲 | 国内少妇偷人精品视频免费 | 国产农村妇女高潮大叫 | 欧美性猛交内射兽交老熟妇 | 色情久久久av熟女人妻网站 | 熟妇人妻中文av无码 | 日日碰狠狠躁久久躁蜜桃 | 中文精品无码中文字幕无码专区 | 日本一卡二卡不卡视频查询 | 两性色午夜免费视频 | 久久亚洲中文字幕精品一区 | 国产麻豆精品一区二区三区v视界 | 扒开双腿吃奶呻吟做受视频 | 中国女人内谢69xxxxxa片 | 亚洲中文字幕乱码av波多ji | 牛和人交xxxx欧美 | 日产精品99久久久久久 | 国产精品无码mv在线观看 | 亚洲成av人综合在线观看 | 精品乱子伦一区二区三区 | 欧美成人高清在线播放 | 男人的天堂2018无码 | 日日摸日日碰夜夜爽av | 亚洲精品欧美二区三区中文字幕 | 精品少妇爆乳无码av无码专区 | 免费人成在线视频无码 | 高潮毛片无遮挡高清免费 | 国产精品无码一区二区桃花视频 | 蜜桃视频韩日免费播放 | 国内精品一区二区三区不卡 | 久久精品国产日本波多野结衣 | 对白脏话肉麻粗话av | 天天拍夜夜添久久精品大 | 爽爽影院免费观看 | 亚洲精品综合一区二区三区在线 | 中文无码成人免费视频在线观看 | 一本久久a久久精品vr综合 | 爽爽影院免费观看 | 亚洲无人区午夜福利码高清完整版 | 亚洲国产精品一区二区美利坚 | 老熟女乱子伦 | 欧美三级不卡在线观看 | 欧美大屁股xxxxhd黑色 | 久久午夜无码鲁丝片 | 西西人体www44rt大胆高清 | 波多野结衣av一区二区全免费观看 | 国产一区二区三区四区五区加勒比 | 国产情侣作爱视频免费观看 | 久久久久成人精品免费播放动漫 | 18无码粉嫩小泬无套在线观看 | 双乳奶水饱满少妇呻吟 | 亚洲伊人久久精品影院 | 中文亚洲成a人片在线观看 | 丁香啪啪综合成人亚洲 | 午夜精品一区二区三区在线观看 | 高清无码午夜福利视频 | 九九久久精品国产免费看小说 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲欧美国产精品久久 | 欧美日韩亚洲国产精品 | 99精品视频在线观看免费 | 无码人妻久久一区二区三区不卡 | 日韩欧美中文字幕公布 | 免费乱码人妻系列无码专区 | 久久久国产精品无码免费专区 | 亚洲热妇无码av在线播放 | 国产疯狂伦交大片 | 国产精品.xx视频.xxtv | 国内少妇偷人精品视频 | 国产香蕉尹人视频在线 | 久久综合给合久久狠狠狠97色 | 国产内射爽爽大片视频社区在线 | 欧美激情内射喷水高潮 | 欧美三级a做爰在线观看 | 天堂а√在线中文在线 | 无码人妻丰满熟妇区毛片18 | 人妻体内射精一区二区三四 | 最近免费中文字幕中文高清百度 | 国产香蕉尹人综合在线观看 | 乱码午夜-极国产极内射 | 国产手机在线αⅴ片无码观看 | 99久久久国产精品无码免费 | 久久久中文字幕日本无吗 | 国产做国产爱免费视频 | 亚洲熟悉妇女xxx妇女av | 亚洲国产精品成人久久蜜臀 | 西西人体www44rt大胆高清 | 亚洲精品国产第一综合99久久 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 欧美老人巨大xxxx做受 | 国产精品对白交换视频 | 伊人久久婷婷五月综合97色 | av香港经典三级级 在线 | 日本乱偷人妻中文字幕 | 2019午夜福利不卡片在线 | 人妻少妇被猛烈进入中文字幕 | 久久久中文字幕日本无吗 | 蜜臀aⅴ国产精品久久久国产老师 | 又黄又爽又色的视频 | 99久久精品日本一区二区免费 | 国产av人人夜夜澡人人爽麻豆 | 亚洲а∨天堂久久精品2021 | 久久久亚洲欧洲日产国码αv | 欧美性猛交xxxx富婆 | 成熟妇人a片免费看网站 | 久久视频在线观看精品 | 中文字幕乱码人妻无码久久 | 最新版天堂资源中文官网 | 老熟女乱子伦 | 白嫩日本少妇做爰 | 亚洲欧洲中文日韩av乱码 | 高清不卡一区二区三区 | 欧美自拍另类欧美综合图片区 | 奇米影视7777久久精品人人爽 | 无码国产激情在线观看 | 亚洲日韩av一区二区三区四区 | 午夜精品久久久内射近拍高清 | 在线天堂新版最新版在线8 | 亚洲日本va中文字幕 | 宝宝好涨水快流出来免费视频 | 国产精品怡红院永久免费 | 搡女人真爽免费视频大全 | 亚洲精品国产精品乱码视色 | 免费人成网站视频在线观看 | 人妻天天爽夜夜爽一区二区 | 国产极品美女高潮无套在线观看 | 亚洲精品一区二区三区四区五区 | 欧美日韩一区二区免费视频 | 国产亚洲精品久久久久久大师 | 搡女人真爽免费视频大全 | 高清国产亚洲精品自在久久 | 国产乡下妇女做爰 | 亚洲中文字幕乱码av波多ji | 亚洲欧美色中文字幕在线 | 初尝人妻少妇中文字幕 | 色综合久久久久综合一本到桃花网 | 娇妻被黑人粗大高潮白浆 | 精品偷自拍另类在线观看 | 激情内射亚州一区二区三区爱妻 | 日韩人妻无码一区二区三区久久99 | 亚洲成a人片在线观看日本 | 精品无码一区二区三区爱欲 | 亚洲精品成人av在线 | 欧美黑人性暴力猛交喷水 | 熟妇人妻中文av无码 | 亚洲一区av无码专区在线观看 | 欧美性生交xxxxx久久久 | 狠狠色欧美亚洲狠狠色www | 国产成人av免费观看 | 成人精品视频一区二区三区尤物 | 成人性做爰aaa片免费看 | 在线看片无码永久免费视频 | 中文无码伦av中文字幕 | 人人妻人人澡人人爽人人精品 | 亚洲一区二区三区偷拍女厕 | 99久久久无码国产精品免费 | 在线看片无码永久免费视频 | 99国产精品白浆在线观看免费 | 无套内谢的新婚少妇国语播放 | 欧美人与牲动交xxxx | 少妇的肉体aa片免费 | 精品乱子伦一区二区三区 | 亚洲七七久久桃花影院 | 99久久婷婷国产综合精品青草免费 | 日韩av无码一区二区三区 | 久久久久久a亚洲欧洲av冫 | 成人性做爰aaa片免费看 | 丰满人妻被黑人猛烈进入 | 午夜嘿嘿嘿影院 | 无码人妻av免费一区二区三区 | 久久久久久亚洲精品a片成人 | 人人爽人人爽人人片av亚洲 | 国产亲子乱弄免费视频 | 亚洲中文字幕va福利 | 亚洲色无码一区二区三区 | 水蜜桃av无码 | 少妇性荡欲午夜性开放视频剧场 | 国产网红无码精品视频 | 无码人妻丰满熟妇区毛片18 | 色情久久久av熟女人妻网站 | 国产成人无码一二三区视频 | 亚洲人亚洲人成电影网站色 | 亚洲色欲色欲欲www在线 | 久久熟妇人妻午夜寂寞影院 | 特大黑人娇小亚洲女 | 国内少妇偷人精品视频免费 | 亚洲欧美中文字幕5发布 | 精品午夜福利在线观看 | 国产莉萝无码av在线播放 | 樱花草在线播放免费中文 | 夜夜影院未满十八勿进 | 国产精品怡红院永久免费 | 性色欲网站人妻丰满中文久久不卡 | 亚洲熟妇自偷自拍另类 | 国产两女互慰高潮视频在线观看 | 精品一区二区三区无码免费视频 | 精品国偷自产在线视频 | 久久久国产精品无码免费专区 | 1000部啪啪未满十八勿入下载 | 中文字幕无码日韩专区 | 亚洲伊人久久精品影院 | 97精品国产97久久久久久免费 | 亚洲熟妇自偷自拍另类 | 日产精品高潮呻吟av久久 | 在线观看免费人成视频 | 亚洲欧美精品aaaaaa片 | 色婷婷综合中文久久一本 | 麻豆成人精品国产免费 | 国产精品无码一区二区桃花视频 | 无遮无挡爽爽免费视频 | 日本一卡二卡不卡视频查询 | 国产三级久久久精品麻豆三级 | 久精品国产欧美亚洲色aⅴ大片 | 自拍偷自拍亚洲精品10p |