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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

史上最烂 spring aop 原理分析

發布時間:2024/3/13 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 史上最烂 spring aop 原理分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

盜引·中篇·spring aop

spring aop: jdk 動態代理和 cglib 動態代理的特點、區別、使用方式、原理及各自對反射的優化、二者在 spring 中的統一、通知順序、從 @Aspect 到 Advisior、靜態通知調用、動態通知調用。


版本

  • jdk:8
  • spring:5.3.20
  • spring boot:2.7.0

1 spring aop

1.1 aop

??AOP (Aspect Oriented Programming) 即面向切面編程,其同 OOP (Object Oriented Programming) 即面向對象編程一樣,是一種編程思想,其含義為通過預編譯方式和運行期間動態代理實現程序功能的統一維護。AOP 是 OOP 的延續,是對 OOP 的一種補充。

??aop 采取了橫向抽取機制,取代了傳統的縱向繼承機制,其可攔截指定的方法并對其功能性增強,且其是非侵入式,分離了業務代碼與非業務代碼。常見的 aop 應用場景有日志記錄、事務管理、權限認證、性能統計、異常處理等。

??aop 是一種編程思想,其典型的實現有 spring aop 和 AspectJ。二者最大的區別是 spring aop 使用動態代理,AspectJ 使用靜態代理。

??spring 中 aop 是基于動態代理實現的,即基于 jdk 動態代理和 cglib 動態代理。但其也整合了 AspectJ。spring 自己實現的 aop 可以通過 xml、接口實現來使用,但不支持注解,所以 spring aop 引入了 AspectJ。實際上 spring aop 只是整合了 AspectJ 中的注解使用方式,最終會將 AspectJ 注解相關解析成 spring aop 自己的實現,當然底層依然是基于動態代理。

1.2 spring aop

1.2.1 八大核心概念
  • Joinpoint(連接點):即類中可以被增強的方法,統稱為連接點。包括抽象方法、普通方法等。
  • Pointcut(切入點):又稱切點,即需要被攔截的連接點,或者理解為需要被增強的方法。連接點中包含了切入點。
  • **Advice(通知) **:即增強,即為需要被增強的方法添加的增強內容。
  • Aspect(切面):切面 = 切點 + 通知。
  • Introduction(引介):即一種特殊的通知,即在運行期間動態的擴展類。即在運行期間為類添加一些屬性和方法。
  • Target(目標):即要被增強的方法所在的類。其實例被稱為目標對象。
  • Weaving(織入):即將通知(增強內容)按照切入點添加到目標中的過程。
  • Proxy(代理):即目標類被織入通知后產生的類,其實例被稱為代理對象。
1.2.2 五種通知方式
  • before(前置通知):即通知內容在目標方法執行前執行。
  • after-returing(返回后通知):即通知內容在目標方法返回后執行。
  • after-throwing(拋出異常后通知):即通知內容在目標方法拋出異常后執行。
  • after(后置通知):即通知內容在目標方法執行后執行。
  • around(環繞通知):即通知內容在目標方法執行前后執行。
1.2.3 三種織入時期
  • 編譯期:即在類編譯期將通知內容織入到目標類中,AspectJ 就采用這種方式。實際上 AspectJ 的織入可細分為兩種方式,即編譯期織入和后編譯期織入,二者的區別是:編譯期織入是將通知內容在 .java 文件編譯時直接織入到其 .class 字節碼文件中;后編譯期織入是將已經織入通知內容的 .class 字節碼文件或整個 jar 包織入。
  • 類加載期:即在 jvm 加載類時將通知內容織入到目標類中,AspectJ 也可使用這種方式。
  • 運行期:即在程序運行期將通知內容織入到目標類中(實際上是生成了一份新的字節碼文件),動態代理就采用這種方式。

2 設計實現

??切面 = 切點 + 通知。spring aop 設計實現中,切面、切點、通知接口分別為 Advisor、Pointcut、Advice。其中針對五種不同的通知方式又擴展了五個通知接口,分別是 MethodBeforeAdvice(前置通知接口)、AfterReturningAdvice(返回后通知接口)、ThrowsAdvice(拋出異常后通知接口)、AfterAdvice(后置通知接口)、MethodInterceptor(環繞通知接口)。同時,為了集成 AspectJ aop 實現中的注解功能,又為 AspectJ 中切點、通知相關的注解提供了默認的實現了。 spring aop 的相關類圖如下:

  • Advisor:即切面接口,切面 = 切點 + 通知。Advisor 通過字接口 PointcutAdvisor 間接持有了一個 Pointcut(切點),又直接持有了一個 Advice(通知)。spring aop 中的所有不同通知方式的 aop 最后都會轉換為一個 Advisor 即切面去執行。
  • Pointcut:即切點接口。
  • ExpressionPointcut:即 SpEL 切點接口。
  • Advice:即通知接口。
  • MethodBeforeAdvice:即前置通知接口。
  • AfterReturningAdvice:即返回后置通知接口。
  • ThrowsAdvice:即拋出異常后通知接口。
  • AfterAdvice:即后置通知接口(finally 快執行完后)。
  • MethodInterceptor:即環繞通知接口。非環繞通知最終都會轉化為環繞通知執行。
  • AspectJExpressionPointcut:即為集成 AspectJ 的 @Pointcut 注解功能而提供的表達式切點實現類。亦可理解為由 @Pointcut 注解聲明的切點最終會被解析為 AspectJExpressionPointcut 的實例。
  • AspectJMethodBeforeAdvice:即為集成 AspectJ 的 @Before 注解功能而提供的前置通知實現類。亦可理解為由 @Before 注解聲明的通知最終都會被解析為 AspectJMethodBeforeAdvice 的實例。非環繞通知。
  • AspectJAfterReturningAdvice:即為集成 AspectJ 的 @AfterReturning 注解功能而提供的返回后通知實現類。亦可理解為由 @AfterReturning 注解聲明的通知最終都會被解析為 AspectJAfterReturningAdvice 的實例。非環繞通知。
  • AspectJAfterAdvice:即為集成 AspectJ 的 @After 注解功能而提供的后置通知實現類。亦可理解為由 @After 注解聲明的通知最終都會被解析為 AspectJAfterAdvice 的實例。實現了 MethodInterceptor 接口,所以其本質為環繞通知。
  • AspectJThrowingAdvice:即為集成 AspectJ 的 @AfterThrowing 注解功能而提供的拋出異常后通知實現類。亦可理解為由 @AfterThrowing 注解聲明的通知最終都會被解析為 AspectJThrowingAdvice 的實例。實現了 MethodInterceptor 接口,所以其本質為環繞通知。
  • AspectJAroundAdvice:即為集成 AspectJ 的 @Around 注解功能而提供的環繞通知實現類。亦可理解為由 @Around 注解聲明的通知最終都會被解析為 AspectJAroundAdvice 的實例。實現了 MethodInterceptor 接口,所以其本質為環繞通知。
  • MethodBeforeAdviceInterceptor:@Before 注解對應通知 AspectJMethodBeforeAdvice 對應的環繞通知。
  • AfterReturningAdviceInterceptor:@AfterReturning 注解對應通知 AspectJAfterReturningAdvice 對應的環繞通知。

2 使用方式

??spring aop 可以使用 xml、接口實現、注解 三種方式進行配置,其中前兩種為 spring aop 提供,第三種為 AspectJ 提供。

2.1 接口實現配置

??用接口實現的方式使用 aop,主要是實現切面、切點、通知相關的接口。如切面 Advisor;切點 Pointcut;通知 MethodBeforeAdvice、AfterReturningAdvice、AfterThrwosAdvice、AfterAdvice、MethodInterceptor。

// 目標類 @Component public class Zed {public void attack() {System.out.println("Zed attack()");}public void taunt() {System.out.println("Zed taunt()");} } @Configuration public class SpringAop {// 前置通知@Beanpublic MethodBeforeAdvice beforeAdvice() {return (method, args, target) -> {System.out.println("Spring aop 前置通知");};}// Zed attack() 方法的前置通知 切面@Beanpublic Advisor before(MethodBeforeAdvice beforeAdvice) {AspectJExpressionPointcut pointcut = new AspectJExpressionPointcut();pointcut.setExpression("execution(public * org.xgllhz.spring.aop.test.Zed.attack())");return new DefaultPointcutAdvisor(pointcut, beforeAdvice);}// 環繞通知@Beanpublic MethodInterceptor aroundAdvice() {return invocation -> {System.out.println("Spring aop 前環繞通知");Object result = invocation.proceed();System.out.println("Spring aop 后環繞通知");return result;};}// Zed taunt() 方法的環繞通知 切面@Beanpublic Advisor around(MethodInterceptor aroundAdvice) {AspectJExpressionPointcut pointcut = new AspectJExpressionPointcut();pointcut.setExpression("execution(public * org.xgllhz.spring.aop.test.Zed.taunt())");return new DefaultPointcutAdvisor(pointcut, aroundAdvice);} } // 測試結果 Spring aop 前置通知 Zed attack()Spring aop 前環繞通知 Zed taunt() Spring aop 后環繞通知

2.2 注解配置

??用注解方式使用 spring aop,主要是使用切點、通知相關的注解。如切點 @Pointcut;通知 @Before、@AfterReturning、@AfterThrows、@After、@Around。這些源自 AspectJ 實現的 aop 中,但 spring aop 適配了這些注解,使得可以在 spring aop 中使用這些注解來配置 aop。

// 目標類 @Component public class Fizz {public void attack() {System.out.println("Fizz attack()");}public void taunt() {System.out.println("Fizz taunt()");} } @Aspect @Component public class AspectJAop {// 切點@Pointcut("execution(public * org.xgllhz.spring.aop.test.Fizz.attack())")public void attackPointcut() {}// 前置通知@Before("attackPointcut()")public void beforeAdvice() {System.out.println("AspectJ 前置通知");}// 切點@Pointcut("execution(public * org.xgllhz.spring.aop.test.Fizz.taunt())")public void tauntPointcut() {}// 環繞通知@Around("tauntPointcut()")public Object aroundAdvice(ProceedingJoinPoint joinPoint) throws Throwable {System.out.println("AspectJ 前環繞通知");Object result = joinPoint.proceed();System.out.println("AspectJ 后環繞通知");return result;} } // 測試結果 AspectJ 前置通知 Fizz attack()AspectJ 前環繞通知 Fizz taunt() AspectJ 后環繞通知

3 jdk 與 cglib 動態代理

??spring aop 底層基于動態代理,即 jdk 動態代理和 cglib 動態代理。

3.1 jdk 動態代理

3.1.1 簡介

??jdk 動態代理即由 jdk 的 java.lang.reflect 包中的 Proxy、InvocationHandler、ProxyGenerator 等類提供的生成代理對象的功能。

??jdk 動態代理要求被代理的目標類必須實現一個或多個接口,這也是 jdk 動態代理的限制所在,即未實現接口的類無法被 jdk 動態代理。同時,jdk 動態代理是基于接口實現的(亦或是方法實現),所以目標類中的成員變量、static 方法、final 方法、private 方法均不能被其代理。也可以理解為 jdk 動態代理是基于方法實現的。

3.1.2 使用示例
// 接口 public interface Hero {void attack(); } // 目標類 public class Zed implements Hero {@Overridepublic void attack() {System.out.println("invoke target method");} } public class JdkProxyTest {public static void main(String[] args) {// 目標對象Hero target = new Zed();// 類加載器 負責在運行期間加載動態生成的代理類的字節碼文件ClassLoader classLoader = JdkProxyTest.class.getClassLoader();// 生成代理對象Hero proxyInstance = (Hero) Proxy.newProxyInstance(classLoader, new Class[]{ Hero.class }, (proxy, method, args1) -> {System.out.println("前置增強");// invoke() 方法的第一個參數是目標對象 第二個是目標對象的方法的參數Object result = method.invoke(target, args1);System.out.println("后置增強");return result;});proxyInstance.attack();} } // 測試結果 前置增強 invoke target method 后置增強

??如上述代碼所示,Hero 為目標類要實現的接口,Zed 為目標類,attack() 方法為要代理的方法。jdk 動態代理的核心是 Proxy 類和 InvocationHandler 接口,其中 Proxy 父類生成代理對象,InvocationHanlder 接口負責提供要增強的內容及目標方法的調用。獲取代理對象的方法為 Proxy 類的 newProxyInstance() 方法,為靜態方法,其需要三個參數,分別是 ClassLoader、Class<?>[]、InvocationHandler。其中 ClassLoader 負責在運行期間加載動態生成的代理類的字節碼文件(實際上是個 byte 數組);Class<? >[] 則為目標類實現的接口;InvocationHandler 則為增強內容。

??jdk 動態代理其核心為代理對象的創建,亦可為代理類的動態生成。代理類類對象由 Proxy 的內部類 ProxyBuilder 的靜態方法 defineProxyClass() 生成,在這里會按一定規則生成代理類的類名,然后調用 ProxyGenerator 的 generateProxyClass() 方法生成代理類的字節碼數組,接著調用 Unsafe 類的 defineClass() 方法生成代理類的類對象。

// 獲取代理對象 public static Object newProxyInstance(ClassLoader loader, Class<?>[] interfaces, InvocationHandler h) {Objects.requireNonNull(h);final Class<?> caller = System.getSecurityManager() == null? null: Reflection.getCallerClass();// 查找或生成指定代理類的構造器Constructor<?> cons = getProxyConstructor(caller, loader, interfaces);// 根據代理類構造器及 InvocationHanlder 生成代理對象return newProxyInstance(caller, cons, h); } // Proxy.ProxyBuilder 獲取代理類的類對象 private static Class<?> defineProxyClass(Module m, List<Class<?>> interfaces) {// 按照規則生成代理類類名 形如 $ProxyN 其中 N 代表第 N 次生成代理類long num = nextUniqueNumber.getAndIncrement();String proxyName = proxyPkg.isEmpty()? proxyClassNamePrefix + num: proxyPkg + "." + proxyClassNamePrefix + num;ClassLoader loader = getLoader(m);trace(proxyName, m, loader, interfaces);// 調用 ProxyGenerator.generateProxyClass 方法生成代理類的字節碼數組// 其接受三個參數 分別為代理類類名、要實現的接口名、訪問權限byte[] proxyClassFile = ProxyGenerator.generateProxyClass(proxyName, interfaces.toArray(EMPTY_CLASS_ARRAY), accessFlags);try {// 調用 UNSAFE.defineClass() 生成代理類對象Class<?> pc = UNSAFE.defineClass(proxyName, proxyClassFile,0, proxyClassFile.length,loader, null);reverseProxyCache.sub(pc).putIfAbsent(loader, Boolean.TRUE);return pc;} catch (ClassFormatError e) {throw new IllegalArgumentException(e.toString());} }
3.1.3 模擬實現

??模擬實現 jdk 動態代理,主要在于最后生成的代理類。

// 目標類要實現的接口 public interface Hero {Object attack(); } // 目標類 public class ZedHero implements Hero {@Overridepublic Object attack() {System.out.println("執行目標方法");return "zed";} } // 模仿 InvocationHandler 接口 public interface InvocationHandler {Object invoke(Object proxy, Method method, Object[] args) throws Throwable; } // 最終生成的代理類 public class $Proxy0 implements Hero {private InvocationHandler handler; // 所持有的調用處理器對象private static Method attack; // 被代理的 attack 方法對象// 在靜態代碼塊中通過反射從目標類實現的接口的獲取到要代理的方法對象static {try {attack = Hero.class.getDeclaredMethod("attack");} catch (NoSuchMethodException e) {throw new NoSuchMethodError(e.getMessage());}}// 有參構造 接受一個調用處理器對象參數public $Proxy0(InvocationHandler handler) {this.handler = handler;}// 最終被代理的 attack 方法@Overridepublic Object attack() {try {// 內部直接調用 InvocationHanlder 的 invoke() 發方法// 而 invoke() 方法內不僅會調用目標類的 attack() 方法 還會執行增強邏輯return this.handler.invoke(this,attack, null);} catch (RuntimeException | Error e) {throw e;} catch (Throwable e) {throw new UnsupportedOperationException(e);}} }
3.1.4 反射優化

??jdk 動態代理中是通過反射來調用目標對象的方法的。眾所周知,java 中反射是存在性能問題的,所以 jdk 對其作出了優化。即當反射調用某一個方法時,默認情況下前 15 次調用都是反射調用(實際上是通過 DelegatingMethodAccessorImpl/NativeMethodAccessorImpl 實例調用的),從第 16 次開始則會給反射調用的方法生成一個方法訪問類(即 GeneratedMethodAccessorXXX 類)(此處可理解為直接調用方法而非反射),再調用該方法時則會用該類實例以直接調用的方式調用。反射調用次數可通過 -Dsun.reflect.inflationThreshold=xxx 莫命令來指定,也可通過 -Dsun.reflect.noInflation=true 來忽略前十五次的反射調用,從直接調用開始(jdk 為什么不直接將其設置為 true,這樣就可以避免反射了么。而 jdk 沒有這么做的原因是 jdk 或其它 java 框架中多次使用了反射,若為 false,則會給每個反射調用的方法生成一個 GeneratedMethodAccessorXXX 類,這樣會使類爆炸,大量占用內存(僅個人理解))。

public class MethodInvokeTest {public static void attack(Integer i) {System.out.println("瞬獄影殺陣 " + i);}// 方法反射調用時 底層使用 MethodAccessor 實現類private static void show(int i, Method foo) throws Exception {Method getMethodAccessor = Method.class.getDeclaredMethod("getMethodAccessor");getMethodAccessor.setAccessible(true);Object invoke = getMethodAccessor.invoke(foo);if (invoke == null) {System.out.println(i + ":" + null);return;}Field delegate = Class.forName("jdk.internal.reflect.DelegatingMethodAccessorImpl").getDeclaredField("delegate");delegate.setAccessible(true);System.out.println(i + ":" + delegate.get(invoke));}public static void main(String[] args) throws Exception {Method attackMethod = MethodInvokeTest.class.getDeclaredMethod("attack", Integer.class);for (int i = 1; i <= 17; i++) {attackMethod.invoke(null, i);show(i, attackMethod);}} } // 測試結果 // 從結果可看出 前 15 次都是使用 NativeMethodAccessorImpl 實例反射調用 // 從第 16 次開始使用 GeneratedMethodAccessor1 實例 而 GeneratedMethodAccessor1 的調用方式為直接調用 // 注:該測試需要添加 jvm 參數 // --add-opens java.base/java.lang.reflect=ALL-UNNAMED --add-opens java.base/jdk.internal.reflect=ALL-UNNAMED 瞬獄影殺陣 1:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 2:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 3:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 4:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 5:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 6:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 7:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 8:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 9:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 10:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 11:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 12:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 13:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 14:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 15:jdk.internal.reflect.NativeMethodAccessorImpl@224edc67 瞬獄影殺陣 16:jdk.internal.reflect.GeneratedMethodAccessor1@6f7fd0e6 瞬獄影殺陣 17:jdk.internal.reflect.GeneratedMethodAccessor1@6f7fd0e6

3.2 cglib 動態代理

3.2.1 簡介

??cglib 是一個強大的高性能代碼生成包,它可以在運行期擴展 java 類或實現 java 接口,被廣泛應用于許多 aop 框架,如 spring aop、dynaop。其底層使用一個小而快的字節碼處理框架 asm,通過 asm 來轉換字節碼并生成類。

??cglib 動態代理是基于繼承實現的,即其是通過繼承目標類來生成一個代理類。所以目標類中的成員變量、static 方法、final 方法、private 方法是不能被其代理的。也可以理解為 cglib 動態代理是基于方法重寫的。

3.2.2 使用示例
// 目標類 public class Zed {public void attack() {System.out.println("Zed attack()")} } public class CglibProxyTest {public static void main(String[] args) {// 目標對象Zed target = new Zed();// 代理對象// create() 第一個參數是代理父類型 第二個參數是回調(這里使用一個回調接口的子接口)// 回調方法的第一個參數是代理對象 第二個參數是目標方法 第三個參數是目標方法入參 第四個參數是目標方法的代理方法對象Target proxyInstance = (Target) Enhancer.create(Zed.class, (MethodInterceptor) (proxy, method, objects, methodProxy) -> {System.out.println("前置增強");// 內部使用代理Object result1 = method.invoke(target, objects);// 內部未使用代理Object result2 = methodProxy.invoke(target, objects);// 內部未使用代理Object result3 = methodProxy.invokeSuper(proxy, objects);System.out.println("后置增強");return result1;});proxyInstance.attack();} } // 測試結果 前置增強 Zed attack() 后置增強

??如上述代碼所示,cglib 動態代理是通過 Enhancer 類的靜態方法 create() 來獲取代理對象的,該方法接受兩個參數,分別代表目標類、回調接口,其中目標類是作為父類在生成代理類時被用來繼承,而回調接口則是承載了增強代碼和目標方法的調用。

??與 jdk 動態代理的另一不同點在于目標方法的調用。jdk 動態代理中是直接通過反射來調用目標方法,而 cglib 則提供了三種目標方法的調用方式:

  • method.invoke(target, objects):其和 jdk 動態代理類似,直接在內部使用反射來調用目標方法。第一個參數為目標對象,第二個參數為目標方法的參數。
  • methodProxy.invoke(target, objects):其未使用反射,它會正常(間接)調用目標方法。第一個參數為目標對象,第二個參數為目標方法參數。spring 即采用這方方式。
  • methodProxy.invokeSuper(proxy, objects):其未使用反射,它會正常(間接)調用目標方法。第一個參數為代理對象,第二個參數為目標方法參數。其省略了目標對象。
3.2.3 模擬實現

??模擬 cglib 動態代理,重點在于最后生成的代理類。

// 目標類 public class Zed {public void attack() {System.out.println("影忍法·滅魂劫");}public void attack(Integer q) {System.out.println("影奧義·諸刃 " + q);} } // 模擬方法攔截器 即回調接口 public interface MethodInterceptor {// 代理方法 參數分別為:代理對象、目標方法、目標方法參數、目標方法代理對象Object intercept(Object proxy, Method method, Object[] args, MethodProxy methodProxy) throws Throwable;} // 最后生成的代理類 public class CglibProxy extends Zed {// 代理類內部持有方法攔截器的實例 通過其來調目標方法private MethodInterceptor methodInterceptor;public CglibProxy() {}// 代理類內部持有了目標方法的方法對象private static Method method0;private static Method method1;// 代理類在內部持有了目標方法的代理對象private static MethodProxy methodProxy0;private static MethodProxy methodProxy1;static {try {// 在靜態代碼塊中實例化目標方法對象method0 = Zed.class.getDeclaredMethod("attack");method1 = Zed.class.getDeclaredMethod("attack", Integer.class);// 在靜態代碼塊中實例化目標方法的代理對象 通過 MethodProxy 的靜態方法 create() 來獲得// create() 方法接受四個參數,分別是目標類、cglib代理類、目標方法參數及返回值描述、目標方法名稱,代理方法名稱// 其中目標方法參數及返回值描述 形如 '(Q)V'// 其通過 jvm 指令解析 形如 (Q)V 表示返回值為 void 入參只有一個(目前還沒深入研究)methodProxy0 = MethodProxy.create(Zed.class, CglibProxy.class, "()V", "attack", "attackSuper");methodProxy1 = MethodProxy.create(Zed.class, CglibProxy.class, "(Q)V", "attack", "attackSuper");} catch (NoSuchMethodException e) {throw new NoSuchMethodError(e.getMessage());}}public void setMethodInterceptor(MethodInterceptor methodInterceptor) {this.methodInterceptor = methodInterceptor;}// 以下這兩個方法是為反射優化準備的public void attackSuper() {super.attack();}public void attackSuper(Integer q) {super.attack(q);}// 重寫了目標類的目標方法 并在其內部通過方法攔截器來間接調用目標方法@Overridepublic void attack() {try {this.methodInterceptor.intercept(this, method0, new Object[0], methodProxy0);} catch (Throwable e) {throw new UndeclaredThrowableException(e);}}@Overridepublic void attack(Integer q) {try {this.methodInterceptor.intercept(this, method1, new Object[]{q}, methodProxy1);} catch (Throwable e) {throw new UndeclaredThrowableException(e);}} }
3.2.4 反射優化

??與 jdk 動態代理一樣,cglib 動態代理中也使用了反射來調用目標對象的方法,所以其也會存在反射性能的問題。

??首先,cglib 調用目標方法有三種方式:

  • method.invoke(target, objects):使用反射調用,調用足夠多的次數才會進行優化。
  • methodProxy.invoke(target, objects):未使用反射,間接調用。結合目標對象使用。spring 采用這種調用方式。
  • methodProxy.invokeSuper(proxy, objects):未使用反射,間接調用。結合代理對象使用。

而 cglib 不同于 jdk 的反射優化方式就在于后兩種調用方式,即結合目標對象調用和結合代理對象調用。其優化思想是為目標方法額外生成代理類。即當調用 MethodProxy 的 invoke() 或 invokeSuper() 方法是會額外生成兩個代理類(可以稱之為方法代理類),分別是 TargetFastClassProxy 和 ProxyFastCassProxy。其中 TargetFastClassProxy 方法代理類是直接為目標類生成的方法代理類,而 ProxyFastClassProxy 則是為目標類的代理類的方法(具體是代理類中的后綴為 Super 的方法)生成的方法代理類。二者思想大同小異,都是通過代理類在代理類內部直接調用目標類的方法。

??所以,對于 cglib 動態代理,則可能會生成三個代理類,分別是目標類的代理類、目標方法的代理類、目標類的代理類的目標方法的代理類。

??就上述實例代碼而言,其最終生成的 TargetFastClassProxy 類和 ProxyFastClassProxy 類如下:

public class TargetFastClassProxy {// 記錄了目標類的目標方法的簽名static Signature signature0 = new Signature("attack", "()V");static Signature signature1 = new Signature("attack", "(Q)V");// 通過方法簽名來獲取方法編號(此處方法編號是固定的)public int getIndex(Signature signature) {if (signature0.equals(signature)) {return 0;} else if (signature1.equals(signature)) {return 1;} else {return -1;}}// 通過方法編號來調用對應的目標方法public Object invoke(int index, Object target, Object[] args) {if (0 == index) {// 此處是直接使用目標對象來調用目標方法 而非反射的方式((Zed) target).attack();return null;} else if (1 == index) {((Zed) target).attack((Integer) args[0]);return null;} else {throw new RuntimeException("Method doest not exist");}}// 測試public static void main(String[] args) {TargetFastClassProxy targetFastClassProxy = new TargetFastClassProxy();int index = targetFastClassProxy.getIndex(new Signature("attack", "()V"));targetFastClassProxy.invoke(index, new Target(), null);} } public class ProxyFastClassProxy {// 記錄了目標類的代理類的目標方法的簽名// 仔細回憶下 在 3.2.2 使用示例中是不是有個類叫 CglibProxy 它里面是不是有兩個方法分別是 attackSuper() 和 attackSuper()// 這兩個方法就是被這個代理類代理的方法static Signature signature0 = new Signature("attackSuper", "()V");static Signature signature1 = new Signature("attackSuper", "(Q)V");// 通過方法簽名獲取方法編號public int getIndex(Signature signature) {if (signature0.equals(signature)) {return 0;} else if (signature1.equals(signature)) {return 1;} else {return -1;}}// 通過方法編號來調用指定方法public Object invoke(int index, Object proxy, Object[] args) {if (0 == index) {// 這里是直接使用代理對象來調用// 而 CglibProxy 的 attackSuper() 方法內部則是直接使用目標對象調用了目標方法 整個流程也是非反射的((CglibProxy) proxy).attackSuper();return null;} else if (1 == index) {((CglibProxy) proxy).attackSuper((Integer) args[0]);return null;} else {throw new RuntimeException("Method doest not exist");}}// 測試public static void main(String[] args) {ProxyFastClassProxy proxyFastClassProxy = new ProxyFastClassProxy();int index = proxyFastClassProxy.getIndex(new Signature("attackSuper", "()V"));proxyFastClassProxy.invoke(index, new CglibProxy(), null);} }

3.3 jdk 與 cglib 反射優化

??通過上述案例,則可知 jdk 與 cglib 在針對反射性能問題上的優化的異同點:

  • 相同點
    • 1、二者都是通過生成額外的代理類實現的(即方法代理類)。
    • 2、二者的優化手段都是通過直接調用目標對象的方法。
  • 不同點
    • 1、jdk 是在目標方法被調用了 15 后才生成額外的代理類的,而 cglib 則是在第一次調用目標方法時就生成了額外的代理類(即 TargetFastClassProxy 或 ProxyFastClassProxy)。
    • 2、jdk 會為每一個目標方法都生成額外的代理類,而 cglib 則會為目標類的所有目標方法或代理類所有目標方法只生成一個額外的代理類。

4 spring aop 與動態代理

??spring aop 底層基于 jdk 動態代理和 cglib 動態代理,其是通過一系列的配置和接口以及實現類來統一了 jdk 和 cglib 的動態代理實現。

  • ProxyConfig

    即代理配置類,亦是代理配置的父類,即允許其它配置類對其進行繼承擴展,如許多 ProxyCreator 代理創建器類都會根據自身實際使用場景對其進行自定義配置。其主要成員變量如下:

    // 表示是否基于完整的類創建代理 即為 true 時使用 cglib 為 false 時使用 jdk 默認為 false private boolean proxyTargetClass = false;// 表示是否對代理進行優化 為 true 時表示優化 默認為 false(但具體怎么優化 從哪里優化沒研究過) private boolean optimize = false;// 表示是否應該凍結代理配置 代理配置被凍結后將不能再進行修改 即為 true 時將凍結 默認為 false private boolean forzen = false;// 表示生成的代理對象是否可以強轉為 Advised 實例 即為 true 時不可以 為 false 時可以 默認為 false 強轉為 Advised 實例后可獲取一些代理相關的信息 boolean opaque = false;// 表示生成的代理對象是否可以被 aop 的 AopContext 的 ThreadLocal 線程局部變量共享出去(共享的目的是為了目標對象能夠訪問) 即為 true 時將共享 默認為 false boolean exposeProxy = false;
  • Advised

    即切面接口。實際上它和切面關系不大,更像是一個綜合性功能的接口,聲明了許多功能性的方法,可通過此接口來獲取代理配置、代理對象的相關信息。且當 ProxyConfig 的 opaque 配置為 true 時,凡是通過 spring aop 生成的代理對象都可強轉為 Advised 類型。

    // 獲取代理配置是否被凍結 boolean isFrozen();// 獲取代理是否基于完整的類而不是接口 boolean isProxyTargetClass();// 獲取代理是否將被暴露 boolean isExposeProxy();// 獲取被代理的所有接口類型(即目標類實現的接口)(不包括被代理的類類型) Class<?>[] getProxiedInterfaces();// 判斷一個指定的類型是否為被代理的接口類型 boolean isInterfaceProxied(Class<?> intf);// 獲取代理對象的目標類 TargetSource getTargetSource();// 獲取 aop 中所有的切面(切面 = 切點 + 通知) Advisor[] getAdvisors();// 向 aop 上下文中添加一個切面 void addAdvisor(Advisor advisor) throws AopConfigException;
  • AdvisedSupport

    即 Advised 接口的實現類,其除了實現 Advised 接口聲明的方法外,還維護了三個重要的成員變量,如下所示:

    // 目標類 默認為空 TargetSource = targetSource = EmptyTargetSource.INSTANCE;// 目標類所實現的接口類型集合 private List<Class<?>> interfaces = new ArrayList<>();// 從目標類中解析出來的切面集合 目標類中配置的所有通知最終會被解析成單個的 Advisor 切面并被維護在該集合中 private List<Advisor> advisors = new ArrayList<>();
  • ProxyCreatorSupport

    其繼承自 AdvisedSupport,除了擁有父類的相關功能外,其最重要的一點是持有一個 AopProxyFactory 成員變量,并對外提供了該變量相關的方法。該成員變量意為 aop 代理工廠,即提供一個創建代理的工廠。

    // AopProxyFactory aop 代理工廠 private AopProxyFactory aopProxyFactory;
  • ProxyFactory

    即代理工廠,其繼承自 ProxyCreatorSupport,其最重要的功能配置特定的代理工廠并使用工廠獲取代理對象。

    // 先通過 AopProxyFactory 的 createAopProxy() 方法獲取具體的動態代理實現(即 AopProxy 的實例) // 然后再通過 AopProxy 的 getProxy() 方法創建代理對象 public Object getProxy() {return createAopProxy().getProxy(); }// 基于 jdk 動態代理獲取代理對象 public static <T> T getProxy(Class<T> proxyInterface, TargetSource targetSource) {return (T) new ProxyFactory(proxyInterface, targetSource).getProxy(); }// 基于 cglib 動態代理獲取代理對象 public static Object getProxy(TargetSource targetSource) {ProxyFactory proxyFactory = new ProxyFactory();proxyFactory.setTargetSource(targetSource);proxyFactory.setProxyTargetClass(true);return proxyFactory.getProxy(); }
  • AopProxyFactory

    即 aop 代理工廠接口,主要功能是獲取一個 aop 代理實現。注意 AopProxyFactory 和 ProxyFactory 的區別,AopProxyFactory 工廠是用來生產一個 aop 代理實現的,如 jdk 動態代理、cglib 動態代理;而 ProxyFactory 工廠是用來生產代理對象的。AopProxyFactory 接口只有一個功能,如下:

    // 根據傳入的代理配置獲取一個 aop 代理實現 如 jdk 動態代理、cglib 動態代理 AopProxy createAopProxy(AdvisedSupport config) throws AopConfigException;
  • DefaultAopProxyFactory

    即 AopProxyFactory 接口的默認實現類,其主要實現了接口中的 createAopProxy() 方法。因此此處是決定 sping aop 最終使用那種動態代理實現的關鍵。

    // 根據指定的配置獲取創建一個 aop 代理實現 @Override public AopProxy createAopProxy(AdvisedSupport config) throws AopConfigException {if (!NativeDetector.inNativeImage() &&(config.isOptimize() || config.isProxyTargetClass() || hasNoUserSuppliedProxyInterfaces(config))) {Class<?> targetClass = config.getTargetClass();if (targetClass == null) {throw new AopConfigException("");}if (targetClass.isInterface() || Proxy.isProxyClass(targetClass) || ClassUtils.isLambdaClass(targetClass)) {// 若目標類是個接口、代理類、lambda 表達式 則返回 jdk 動態代理實現return new JdkDynamicAopProxy(config);}// 若代理需要被優化、基于完整的類創建代理、代理配置未基于接口 則返回 cglib 動態代理實現return new ObjenesisCglibAopProxy(config);}else {// 若代理不需要被優化、不是基于完整類創建代理、代理配置基于接口 則返回 jdk 動態代理實現return new JdkDynamicAopProxy(config);} }
  • AopProxy

    即 aop 代理接口,該接口定義了實際獲取代理對象的功能。且 spring 提供了兩個實現類,分別是 JdkDynamicAopProxy 和 CglibAopProxy,即分別代表 jdk 動態代理和 cglib 動態代理。

    public interface AopProxy {Object getProxy();Object getProxy(@Nullable ClassLoader classLoader); }
  • JdkDynamicAopProxy

    即 spring aop 實現的 jdk 動態代理。該類實現類 AopProxy 接口,用來創建代理對象;同時實現了 InvocationHandler 接口,用來回調目標方法,其中目標方法是以反射的方式調用。

    final class JdkDynamicAopProxy implements AopProxy, InvocationHandler, Serializable {// 構造方法 實例化了 Advised 實例和目標類所實現的接口public JdkDynamicAopProxy(AdvisedSupport config) throws AopConfigException {this.advised = config;this.proxiedInterfaces = AopProxyUtils.completeProxiedInterfaces(this.advised, true);findDefinedEqualsAndHashCodeMethods(this.proxiedInterfaces);}@Overridepublic Object getProxy() {return getProxy(ClassUtils.getDefaultClassLoader());}@Overridepublic Object getProxy(@Nullable ClassLoader classLoader) {// 使用 Proxy 類的靜態方法 newProxyInstance() 創建代理對象return Proxy.newProxyInstance(classLoader, this.proxiedInterfaces, this);}// 回調方法 內部以反射的方式調用了目標方法@Override@Nullablepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {..} }
  • CglibAopProxy

    即 spring aop 實現的 cglib 動態代理類,該類實現了 AopProxy 接口。內部通過 Enhancer 的 create() 方法來創建代理對象。同時定義了內部類 DynamicAdvisedInterceptor,其實現了 MethodInterceptor 接口,來作為回調接口的實現,內部通過 MethodProxy#invoke(Object Target, Object[] objects) 方法來以非反射的方式調用目標方法。

    class CglibAopProxy implements AopProxy, Serializable {public CglibAopProxy(AdvisedSupport config) throws AopConfigException {this.advised = config;this.advisedDispatcher = new AdvisedDispatcher(this.advised);}@Overridepublic Object getProxy() {return getProxy(null);}@Overridepublic Object getProxy(@Nullable ClassLoader classLoader) {...// 配置 cglib EnhancerEnhancer enhancer = createEnhancer();enhancer.setSuperclass(proxySuperClass);enhancer.setInterfaces(AopProxyUtils.completeProxiedInterfaces(this.advised));enhancer.setNamingPolicy(SpringNamingPolicy.INSTANCE);enhancer.setStrategy(new ClassLoaderAwareGeneratorStrategy(classLoader));// 獲取回調(其定義了多個回調內部實現類 如 equals() 的、hashCode() 的、動態代理的)Callback[] callbacks = getCallbacks(rootClass);enhancer.setCallbackTypes(types);// 創建代理類和代理對象return createProxyClassAndInstance(enhancer, callbacks);}protected Object createProxyClassAndInstance(Enhancer enhancer, Callback[] callbacks) {enhancer.setInterceptDuringConstruction(false);enhancer.setCallbacks(callbacks);return (this.constructorArgs != null && this.constructorArgTypes != null ?enhancer.create(this.constructorArgTypes, this.constructorArgs) :enhancer.create());}// 在回調接口的內部實現類中調用了此靜態方法 在此方法內調用了方法代理類的 invoke() 方法(該方法是以非反射的方式調用目標方法)@Nullableprivate static Object invokeMethod(@Nullable Object target, Method method, Object[] args, MethodProxy methodProxy)throws Throwable {return methodProxy.invoke(target, args);} }

5 從 @Aspect 到 Advisor

??前文中提到了 spring aop 的使用方式,即接口實現配置和注解配置。其中接口實現配置是通過直接實現 spring aop 提供的相關切點、通知、切面接口來使用 aop 的;而注解配置則是使用了 spring aop 集成自 AspectJ 框架的相關注解來使用 aop 的。

??這兩者之間是存在緊密聯系的,即 spring aop 會將通過注解配置的切面轉換成相關接口實例。具體則是 @Aspect 到 Advisor 的過程。這里我們可以將通過注解配置的切面稱之為高級切面,將通過實現接口配置的切面稱之為低級切面。而這個轉換工作則是由 AnnotationAwareAspectJAutoProxyCreator BPP 來完成的。

??AnnotationAwareAspectJAutoProxyCreator BPP 主要有兩個功能:

  • 切面轉換

    即將 @AspectJ 高級切面轉換為 Advisor 低級切面,由 findEligibleAdvisors() 方法來完成。該方法會找到兩種切面,一種是通過直接實現 Advisor 接口實現的低級切面,一種是通過解析 @AspectJ 高級切面得到的低級切面 Advisor。最終返回一個 List< Advisor> 集合。

  • 創建代理

    即創建代理對象。由 wrapIfNecessary() 方法完成。該方法會先通過調用 findEligibleAdvisors() 方法獲得所有的低級切面,然后為其創建代理。創建代理的時機在 spring bean 生命周期中表現為:實例化 -> (1) 屬性設置 -> 初始化 (2),即創建代理的時機為:當發生循環依賴時在屬性設置(依賴注入)前創建代理;當未發生循環依賴時在初始化后創建代理。

6 通知順序

??通知順序由具體的切面使用決定,分為兩種,即低級切面和高級切面。具體順序如下:

  • 低級切面

    低級切面的通知順序需要借助 @Order 注解來設置,其值越小通知越早。注:該注解只能作用于類,作用于方法無效。

  • 高級切面

    高級切面由具體的通知注解決定,即 @Around before、@Before、@AfterThrowing、@AfterReturning、@After、@Around after。分別表示為:前環繞通知、前置通知、異常后通知、返回后通知、后置通知、后環繞通知。

7 靜態通知調用與動態通知調用

??所謂靜態通知調用指的時目標方法與通知方法之間不存在參數傳遞的情況,而動態通知調用則指的是目標方法與通知方法之間存在參數傳遞的情況。這里的參數傳遞是指將目標方法的參數綁定到通知方法上。

7.1 靜態通知調用

??靜態通知調用的流程為(以 jdk 動態代理為例):

  • a 切面轉換

    即將 @Aspect 注解標注的高級切面轉換成 Advisor 低級切面。

    • @Around 切面通知被解析為 Advisor 的子實現類 AspectJAroundAdvice。
    • @Before 切面通知被解析為 Advisor 的子實現類 AspectJMethodBeforeAdvice。
    • @AfterThrowing 切面通知被解析為 Advisor 的子實現類 AspectJAfterThrowingAdvice。
    • @AfterReturning 切面通知被解析為 Advisor 的子實現類 AspectJAfterReturningAdvice。
    • @After 切面通知被解析為 Advisor 的子實現類 AspectJAfterAdvice。
  • b 通知轉換

    即將非環繞通知轉換為環繞通知。這里的環繞通知是指 MethodInterceptor 類型(org.aopalliance.intercept.MethodInterceptor)。

    ProxyFactory 會將非環繞通知轉換為環繞通知,且通知調用時會以 MethodInterceptor 類型調用。

    而通過 @Aspect 注解配置的切面中的部分通知不是環繞通知,如 @Before、@AfterReturning。所以此處 spring aop 運用適配器模式將非環繞通知轉換成了環繞通知。

    • MethodBeforeAdviceAdapter 將 @Before 對應的通知 AspectJMethodBeforeAdvice 適配為 MethodBeforfeAdviceInterceptor。
    • AfterReturningAdviceAdapter 將 @AfterReturning 對應的通知 AspectJAfterReturningAdvice 適配為 AfterReturningAdviceInterceptor。
  • c 通知調用

    由 MethodInvocation 接口調用通知。因為方法存在嵌套情況,通知又基于方法,所以通知也存在嵌套情況,故此處使用責任鏈模式來調用。即調用順序為 由外而內 -> 目標方法 -> 由內而外。

7.2 動態通知調用

??動態通知調用即目標方法與通知方法之間存在參數傳遞的情況(將目標方法的參數綁定到通知方法上)。調用流程與靜態通知調用的區別在于通知轉換上,即其在通過代理工廠將非環繞通知轉換到環繞通知時(ProxyFactory.getInterceptorsAndDynamicInterceptionAdvice()),將動態通知轉化成了 InterceptorAndDynamicMethodMatcher 類型。該類型中維護了環繞通知和切點成員變量,即 MethodInterceptor 和 MethodMatcher。其中 MethodMatcher 是表達式切點 AspectJExpressionPointcut 的父接口。從而實現了動態通知調用。

??注:動態通知調用需要再次解析切點以便為通知方法綁定參數,故其復雜度較高,較靜態通知調用而言性能較差。

8 通知調用 MethodInvocation

??在 spring aop 中,以 jdk 動態代理為例,通知調用采用了責任鏈設計模式,其中每一個通知(MethodInterceptor)都代表一個職責,所有的通知會組成一個通知鏈(MethodInvocation),且在最中間調用了目標方法。

??責任鏈設計模式在 java 和 spring 框架中有很多的引用,常用在過濾器、攔截器中。如 servlet 中的過濾器,主要體現在 FilterChain 與 Filter 中;spring security 中的 SpringSecurityChain 與 Filter;spring aop 中的 MethodInvocation 與 MethodInterceptor 等。

??以下將模擬實現 spring aop 通知調用的工作流程:由外而內 -> 目標方法 -> 由內而外。

// 目標類 public class Zed {// 目標方法public void attack() {System.out.println("禁奧義·瞬獄影殺陣");} } // 通知一 public class OneAdvice implements MethodInterceptor {@Overridepublic Object invoke(MethodInvocation invocation) throws Throwable {System.out.println("OneAdvice 環繞前通知");Object result = invocation.proceed();System.out.println("OneAdvice 環繞后通知");return result;} }// 通知二 public class TwoAdvice implements MethodInterceptor {@Overridepublic Object invoke(MethodInvocation invocation) throws Throwable {System.out.println("TwoAdvice 環繞前通知");Object result = invocation.proceed();System.out.println("TwoAdvice 環繞后通知");return result;} }// 通知三 public class ThreeAdvice implements MethodInterceptor {@Overridepublic Object invoke(MethodInvocation invocation) throws Throwable {System.out.println("ThreeAdvice 環繞前通知");Object result = invocation.proceed();System.out.println("ThreeAdvice 環繞后通知");return result;} } // 自定義實現 MethodInvocation(這個可以理解為 通知鏈) public class MyMethodInvocation implements MethodInvocation {private Object target; // 目標對象private Method method; // 目標方法private Object[] args; // 目標方法參數private List<MethodInterceptor> methodInterceptors; // 通知集合(環繞通知集合)private int count = 1; // 通知調用次數 因為中間會調用一次目標方法 調用目標方法時不會調用通知 所在其初始值為 1public MyMethodInvocation(Object target, Method method, Object[] args, List<MethodInterceptor> methodInterceptors) {this.target = target;this.method = method;this.args = args;this.methodInterceptors = methodInterceptors;}@Overridepublic Method getMethod() {return this.method;}@Overridepublic Object[] getArguments() {return this.args;}@Overridepublic Object proceed() throws Throwable {// 若調用次數大于通知數量 則說明通知鏈中每個通知都已調用完畢(遞歸到最底層) 此時應該調用目標方法if (this.count > this.methodInterceptors.size()) {return this.method.invoke(this.target, this.args);}// 獲取通知鏈中下一個通知 然后調用MethodInterceptor interceptor = this.methodInterceptors.get(this.count++ - 1);return interceptor.invoke(this);}@Overridepublic Object getThis() {return this.target;}@Overridepublic AccessibleObject getStaticPart() {return this.method;} } // 測試 public class MethodInvocationTest {public static void main(String[] args) throws Throwable {// 構建一個通知鏈List<MethodInterceptor> methodInterceptors = List.of(new OneAdvice(), new TwoAdvice(), new ThreeAdvice());// 在目標對象的目標方法上調用通知鏈MyMethodInvocation methodInvocation = new MyMethodInvocation(new Zed(), Zed.class.getMethod("attack"),new Object[0], methodInterceptors);methodInvocation.proceed();} } // 測試結果 由結果可見 通知調用為 由外而內 -> 目標方法 -> 由內而外 OneAdvice 環繞前通知 TwoAdvice 環繞前通知 ThreeAdvice 環繞前通知 禁奧義·瞬獄影殺陣 ThreeAdvice 環繞后通知 TwoAdvice 環繞后通知 OneAdvice 環繞后通知

??難得 可以同座 何以 要忌諱赤裸

總結

以上是生活随笔為你收集整理的史上最烂 spring aop 原理分析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

女人被爽到呻吟gif动态图视看 | 久久精品国产99精品亚洲 | 国产亚洲日韩欧美另类第八页 | 欧美精品在线观看 | 午夜不卡av免费 一本久久a久久精品vr综合 | 午夜无码人妻av大片色欲 | 久激情内射婷内射蜜桃人妖 | 鲁鲁鲁爽爽爽在线视频观看 | 久久久久亚洲精品男人的天堂 | 国产在线一区二区三区四区五区 | 亚洲日韩av一区二区三区中文 | 亚洲国产综合无码一区 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲另类伦春色综合小说 | 丰满人妻精品国产99aⅴ | 国产内射爽爽大片视频社区在线 | 日韩欧美群交p片內射中文 | 丰满诱人的人妻3 | 亚洲色欲久久久综合网东京热 | 玩弄人妻少妇500系列视频 | 欧美色就是色 | 国产农村乱对白刺激视频 | 狂野欧美性猛xxxx乱大交 | 成熟妇人a片免费看网站 | 久热国产vs视频在线观看 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲精品一区国产 | 国产情侣作爱视频免费观看 | 国产片av国语在线观看 | 伊在人天堂亚洲香蕉精品区 | 人人妻人人澡人人爽欧美一区 | 午夜福利一区二区三区在线观看 | 国产精品多人p群无码 | 国产肉丝袜在线观看 | 午夜无码人妻av大片色欲 | 无码播放一区二区三区 | 日产国产精品亚洲系列 | 国产人妻人伦精品1国产丝袜 | 男女爱爱好爽视频免费看 | 中文字幕无码视频专区 | 99视频精品全部免费免费观看 | 樱花草在线社区www | 精品一区二区三区波多野结衣 | 亚洲日韩精品欧美一区二区 | 亚洲国产精品美女久久久久 | 国产精品久久久久久亚洲影视内衣 | 国产成人精品必看 | 国产情侣作爱视频免费观看 | 小sao货水好多真紧h无码视频 | 俺去俺来也在线www色官网 | 国产精品无码久久av | 国内丰满熟女出轨videos | 亚洲国产午夜精品理论片 | 天天燥日日燥 | 久久综合久久自在自线精品自 | 国产三级久久久精品麻豆三级 | 性欧美熟妇videofreesex | 国产av久久久久精东av | 国产绳艺sm调教室论坛 | 丝袜 中出 制服 人妻 美腿 | 欧美日韩色另类综合 | 久青草影院在线观看国产 | 丁香啪啪综合成人亚洲 | 日韩人妻无码中文字幕视频 | 久青草影院在线观看国产 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 少妇性l交大片 | 欧美性生交xxxxx久久久 | 日韩少妇内射免费播放 | 亚洲乱码中文字幕在线 | 久久久久久av无码免费看大片 | 成 人 网 站国产免费观看 | 日本熟妇人妻xxxxx人hd | 内射欧美老妇wbb | 色综合天天综合狠狠爱 | 清纯唯美经典一区二区 | 天堂久久天堂av色综合 | 丰满肥臀大屁股熟妇激情视频 | 扒开双腿疯狂进出爽爽爽视频 | 装睡被陌生人摸出水好爽 | 中文字幕精品av一区二区五区 | 成人免费视频视频在线观看 免费 | 欧美日韩视频无码一区二区三 | 清纯唯美经典一区二区 | 老头边吃奶边弄进去呻吟 | 色婷婷香蕉在线一区二区 | 性欧美疯狂xxxxbbbb | 中文字幕精品av一区二区五区 | 7777奇米四色成人眼影 | 激情爆乳一区二区三区 | 最新国产麻豆aⅴ精品无码 | 麻豆精产国品 | 天下第一社区视频www日本 | 一个人看的视频www在线 | 在线观看国产一区二区三区 | 国产一区二区三区影院 | 国产亚洲精品精品国产亚洲综合 | www成人国产高清内射 | 学生妹亚洲一区二区 | 国产麻豆精品精东影业av网站 | 国产sm调教视频在线观看 | 国产成人无码一二三区视频 | av无码久久久久不卡免费网站 | 中文字幕乱码中文乱码51精品 | 国产色精品久久人妻 | 美女扒开屁股让男人桶 | 日本www一道久久久免费榴莲 | 狠狠色丁香久久婷婷综合五月 | 亚洲男人av香蕉爽爽爽爽 | 婷婷综合久久中文字幕蜜桃三电影 | 男人的天堂av网站 | 日韩av无码中文无码电影 | 在线精品亚洲一区二区 | 思思久久99热只有频精品66 | 午夜精品久久久内射近拍高清 | 国产精品福利视频导航 | 国产区女主播在线观看 | 欧美丰满少妇xxxx性 | 无码福利日韩神码福利片 | 亚洲日韩乱码中文无码蜜桃臀网站 | 一本色道久久综合亚洲精品不卡 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲人交乣女bbw | 性欧美疯狂xxxxbbbb | 性欧美videos高清精品 | 久久综合狠狠综合久久综合88 | 牲欲强的熟妇农村老妇女 | 又大又硬又黄的免费视频 | 在线成人www免费观看视频 | 最新国产乱人伦偷精品免费网站 | 香港三级日本三级妇三级 | 日日麻批免费40分钟无码 | 国产亚洲精品久久久久久久久动漫 | 国产肉丝袜在线观看 | 一本色道久久综合狠狠躁 | 无套内谢老熟女 | 久久久婷婷五月亚洲97号色 | 国产小呦泬泬99精品 | 99久久婷婷国产综合精品青草免费 | 亚洲热妇无码av在线播放 | 熟女体下毛毛黑森林 | 人妻人人添人妻人人爱 | 中文精品无码中文字幕无码专区 | 蜜桃视频韩日免费播放 | 欧美猛少妇色xxxxx | 精品成在人线av无码免费看 | 精品国产精品久久一区免费式 | 亚洲男人av天堂午夜在 | 午夜福利一区二区三区在线观看 | 九九久久精品国产免费看小说 | 日欧一片内射va在线影院 | 亚洲成av人片在线观看无码不卡 | 一个人免费观看的www视频 | 欧美自拍另类欧美综合图片区 | 人人澡人人妻人人爽人人蜜桃 | 久久久久人妻一区精品色欧美 | 国产精品人人爽人人做我的可爱 | 麻豆成人精品国产免费 | 亚洲精品国产精品乱码不卡 | 国产午夜亚洲精品不卡 | 欧美成人高清在线播放 | 天堂一区人妻无码 | 丰满妇女强制高潮18xxxx | 亚洲国产精品无码一区二区三区 | 又紧又大又爽精品一区二区 | 日本一区二区三区免费高清 | 台湾无码一区二区 | 精品人人妻人人澡人人爽人人 | 学生妹亚洲一区二区 | 精品国产福利一区二区 | 狠狠色噜噜狠狠狠7777奇米 | 欧美人与禽zoz0性伦交 | 女高中生第一次破苞av | 亚洲码国产精品高潮在线 | 无码成人精品区在线观看 | 亚洲一区二区三区国产精华液 | 粉嫩少妇内射浓精videos | 久久婷婷五月综合色国产香蕉 | 午夜福利一区二区三区在线观看 | 熟妇人妻无码xxx视频 | 成人三级无码视频在线观看 | 中国女人内谢69xxxxxa片 | 国产亚洲精品久久久久久 | 日本一卡2卡3卡四卡精品网站 | 初尝人妻少妇中文字幕 | 东京热无码av男人的天堂 | 色诱久久久久综合网ywww | 成人综合网亚洲伊人 | 欧美freesex黑人又粗又大 | 国产精品怡红院永久免费 | 日韩视频 中文字幕 视频一区 | 日韩在线不卡免费视频一区 | 欧美亚洲日韩国产人成在线播放 | 国产精品久久久av久久久 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲狠狠色丁香婷婷综合 | 天堂无码人妻精品一区二区三区 | 人妻aⅴ无码一区二区三区 | 高潮毛片无遮挡高清免费视频 | 日韩精品久久久肉伦网站 | 国产区女主播在线观看 | 成人aaa片一区国产精品 | 纯爱无遮挡h肉动漫在线播放 | 亚洲性无码av中文字幕 | 久久国产36精品色熟妇 | 国产精品多人p群无码 | 亚洲日韩乱码中文无码蜜桃臀网站 | 日本大乳高潮视频在线观看 | 老司机亚洲精品影院 | 国产亚洲日韩欧美另类第八页 | 国产高清不卡无码视频 | 国产三级精品三级男人的天堂 | 国产精品久免费的黄网站 | 亚洲精品国偷拍自产在线观看蜜桃 | 色欲av亚洲一区无码少妇 | 人人妻在人人 | 又粗又大又硬又长又爽 | 曰本女人与公拘交酡免费视频 | 久久无码中文字幕免费影院蜜桃 | 成人毛片一区二区 | 极品尤物被啪到呻吟喷水 | 久久久久久久人妻无码中文字幕爆 | 久久精品中文闷骚内射 | 日韩少妇白浆无码系列 | 伊人久久婷婷五月综合97色 | 狠狠色丁香久久婷婷综合五月 | 无码av岛国片在线播放 | 人妻无码αv中文字幕久久琪琪布 | 无码午夜成人1000部免费视频 | 国产亚洲视频中文字幕97精品 | 国产精品99久久精品爆乳 | 一本无码人妻在中文字幕免费 | 少妇邻居内射在线 | 无码纯肉视频在线观看 | 成人试看120秒体验区 | 国产综合色产在线精品 | 国语自产偷拍精品视频偷 | 国产精品18久久久久久麻辣 | 特大黑人娇小亚洲女 | 亚洲人成网站免费播放 | 免费人成网站视频在线观看 | 国产va免费精品观看 | 亚洲欧洲中文日韩av乱码 | 亚洲日韩中文字幕在线播放 | 国产真人无遮挡作爱免费视频 | 丰满少妇弄高潮了www | 日本饥渴人妻欲求不满 | 亚洲娇小与黑人巨大交 | 亚洲男女内射在线播放 | 国产真实乱对白精彩久久 | 亚洲 欧美 激情 小说 另类 | 国产精品久久久 | 国产小呦泬泬99精品 | 国产av一区二区精品久久凹凸 | 夜精品a片一区二区三区无码白浆 | 精品无人国产偷自产在线 | 无码精品人妻一区二区三区av | 成熟妇人a片免费看网站 | 波多野结衣av在线观看 | 玩弄人妻少妇500系列视频 | ass日本丰满熟妇pics | 久久精品女人天堂av免费观看 | 婷婷六月久久综合丁香 | 成人动漫在线观看 | 无码人妻精品一区二区三区下载 | 色五月五月丁香亚洲综合网 | 亚洲乱码中文字幕在线 | 真人与拘做受免费视频一 | 67194成是人免费无码 | 国产另类ts人妖一区二区 | 国产内射爽爽大片视频社区在线 | 中文字幕+乱码+中文字幕一区 | 内射后入在线观看一区 | 国产精品高潮呻吟av久久4虎 | 国产亚洲精品久久久久久 | 国产真实乱对白精彩久久 | 高清无码午夜福利视频 | 欧洲极品少妇 | 青春草在线视频免费观看 | 一本久久a久久精品vr综合 | 天天躁日日躁狠狠躁免费麻豆 | 最近免费中文字幕中文高清百度 | 亚洲aⅴ无码成人网站国产app | 欧美人与禽zoz0性伦交 | 18禁止看的免费污网站 | 天天拍夜夜添久久精品 | 日韩无码专区 | 亚洲中文字幕av在天堂 | 麻豆md0077饥渴少妇 | www国产亚洲精品久久网站 | 老子影院午夜精品无码 | 国产精品自产拍在线观看 | 亚洲人成网站免费播放 | 妺妺窝人体色www婷婷 | 在教室伦流澡到高潮hnp视频 | 双乳奶水饱满少妇呻吟 | 欧洲美熟女乱又伦 | 2020久久香蕉国产线看观看 | av人摸人人人澡人人超碰下载 | 亚洲色无码一区二区三区 | 久久久久99精品国产片 | 亚洲日韩一区二区三区 | 成人免费视频在线观看 | 亚洲精品一区二区三区在线观看 | 亚洲国产高清在线观看视频 | 男女爱爱好爽视频免费看 | 女人被男人爽到呻吟的视频 | 欧洲vodafone精品性 | а√天堂www在线天堂小说 | 狠狠综合久久久久综合网 | 天堂亚洲2017在线观看 | 国产亚洲日韩欧美另类第八页 | 日韩欧美中文字幕公布 | 色欲综合久久中文字幕网 | 国产综合久久久久鬼色 | 荡女精品导航 | 成年美女黄网站色大免费视频 | 亚洲成a人片在线观看无码 | 国产成人一区二区三区别 | 亚洲欧洲日本无在线码 | 国产精品亚洲а∨无码播放麻豆 | 噜噜噜亚洲色成人网站 | 久久久久久九九精品久 | 天下第一社区视频www日本 | 国产精品久久久久久久9999 | 久久综合久久自在自线精品自 | av香港经典三级级 在线 | 久久国产精品精品国产色婷婷 | 亚洲成a人一区二区三区 | 欧美一区二区三区视频在线观看 | 宝宝好涨水快流出来免费视频 | 中文精品久久久久人妻不卡 | 无码av免费一区二区三区试看 | 免费乱码人妻系列无码专区 | 日韩少妇白浆无码系列 | 亚洲成在人网站无码天堂 | 国产真实乱对白精彩久久 | 亚洲精品国产精品乱码视色 | 欧美人妻一区二区三区 | 亚洲人亚洲人成电影网站色 | 国产黄在线观看免费观看不卡 | 精品aⅴ一区二区三区 | 国产成人无码av一区二区 | 露脸叫床粗话东北少妇 | 波多野结衣高清一区二区三区 | 精品亚洲成av人在线观看 | 欧美黑人巨大xxxxx | 久久久久久久人妻无码中文字幕爆 | 亚洲精品久久久久avwww潮水 | 激情综合激情五月俺也去 | 国产亚洲视频中文字幕97精品 | 亚洲国产精品美女久久久久 | 国产超碰人人爽人人做人人添 | 樱花草在线播放免费中文 | 久久综合香蕉国产蜜臀av | 少妇无码吹潮 | 成人片黄网站色大片免费观看 | 亚洲色大成网站www | 狠狠色欧美亚洲狠狠色www | 伊人久久大香线蕉亚洲 | 免费播放一区二区三区 | 成人影院yy111111在线观看 | 亚洲小说春色综合另类 | 欧美日韩综合一区二区三区 | 熟妇人妻激情偷爽文 | 久久人妻内射无码一区三区 | 亚洲乱码日产精品bd | 啦啦啦www在线观看免费视频 | 中文字幕无码av波多野吉衣 | 国产成人综合在线女婷五月99播放 | 亚洲男人av香蕉爽爽爽爽 | 国产成人一区二区三区在线观看 | 中文字幕乱码人妻二区三区 | 亚洲熟妇色xxxxx欧美老妇y | 狂野欧美性猛交免费视频 | 亚洲色欲久久久综合网东京热 | 国产精品久久久久影院嫩草 | 国产超碰人人爽人人做人人添 | 日韩精品乱码av一区二区 | 国产精品久免费的黄网站 | 国产精品怡红院永久免费 | 久久精品中文字幕大胸 | 久久精品成人欧美大片 | 中文字幕av日韩精品一区二区 | 久久天天躁夜夜躁狠狠 | 俄罗斯老熟妇色xxxx | 黑人粗大猛烈进出高潮视频 | 精品国产精品久久一区免费式 | 久久午夜无码鲁丝片午夜精品 | 久久综合香蕉国产蜜臀av | 国产精品久久久 | 国产无遮挡吃胸膜奶免费看 | 乱中年女人伦av三区 | 无码av免费一区二区三区试看 | 无码吃奶揉捏奶头高潮视频 | 亚洲精品欧美二区三区中文字幕 | 欧美阿v高清资源不卡在线播放 | 领导边摸边吃奶边做爽在线观看 | 九九热爱视频精品 | 又大又黄又粗又爽的免费视频 | 老熟妇乱子伦牲交视频 | 夜夜高潮次次欢爽av女 | 无码国产色欲xxxxx视频 | a片在线免费观看 | 色偷偷人人澡人人爽人人模 | v一区无码内射国产 | 久久 国产 尿 小便 嘘嘘 | 中文久久乱码一区二区 | 国产亚洲精品久久久久久久久动漫 | 国产精品亚洲一区二区三区喷水 | 一本无码人妻在中文字幕免费 | 国产精品第一区揄拍无码 | 香蕉久久久久久av成人 | 极品嫩模高潮叫床 | 亚洲娇小与黑人巨大交 | 国产莉萝无码av在线播放 | 久精品国产欧美亚洲色aⅴ大片 | 久久久久成人片免费观看蜜芽 | 国产精品免费大片 | 成在人线av无码免费 | 色一情一乱一伦一区二区三欧美 | 精品欧美一区二区三区久久久 | 国产猛烈高潮尖叫视频免费 | 日韩精品无码一区二区中文字幕 | 一区二区三区高清视频一 | 国产精品久久久久久亚洲影视内衣 | 国产乱人伦偷精品视频 | 日本精品人妻无码77777 天堂一区人妻无码 | 正在播放东北夫妻内射 | 国产精华av午夜在线观看 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 久久国产精品偷任你爽任你 | 亚洲aⅴ无码成人网站国产app | 久久午夜无码鲁丝片午夜精品 | 精品无码国产一区二区三区av | 国产成人无码区免费内射一片色欲 | 国产午夜亚洲精品不卡 | 国产精品沙发午睡系列 | 亚洲中文字幕在线无码一区二区 | 国精产品一品二品国精品69xx | 久久午夜无码鲁丝片秋霞 | 色综合久久久久综合一本到桃花网 | 狠狠色欧美亚洲狠狠色www | 激情爆乳一区二区三区 | 国产成人无码午夜视频在线观看 | 自拍偷自拍亚洲精品被多人伦好爽 | 日本免费一区二区三区最新 | 天天做天天爱天天爽综合网 | 成人aaa片一区国产精品 | 欧美黑人性暴力猛交喷水 | 精品乱码久久久久久久 | 青青久在线视频免费观看 | 国模大胆一区二区三区 | 精品欧美一区二区三区久久久 | 乱人伦人妻中文字幕无码 | 亚洲精品久久久久久一区二区 | 免费网站看v片在线18禁无码 | 一区二区三区乱码在线 | 欧洲 | 性色欲情网站iwww九文堂 | 精品一二三区久久aaa片 | 99久久人妻精品免费二区 | 性色av无码免费一区二区三区 | 在线欧美精品一区二区三区 | 欧美 丝袜 自拍 制服 另类 | 波多野结衣乳巨码无在线观看 | 中文字幕日产无线码一区 | 日本一卡二卡不卡视频查询 | 2019午夜福利不卡片在线 | 亚洲中文字幕在线观看 | 漂亮人妻洗澡被公强 日日躁 | 成人性做爰aaa片免费看 | 国产无套粉嫩白浆在线 | 国产又爽又猛又粗的视频a片 | 日韩 欧美 动漫 国产 制服 | 图片小说视频一区二区 | 色欲综合久久中文字幕网 | 国产精品欧美成人 | 免费乱码人妻系列无码专区 | 久久精品女人天堂av免费观看 | 内射巨臀欧美在线视频 | 伦伦影院午夜理论片 | 性做久久久久久久久 | 97夜夜澡人人双人人人喊 | 色婷婷久久一区二区三区麻豆 | 久久久久久亚洲精品a片成人 | 性色欲网站人妻丰满中文久久不卡 | 久久久久久久人妻无码中文字幕爆 | 国产人妻精品一区二区三区不卡 | 99视频精品全部免费免费观看 | 图片区 小说区 区 亚洲五月 | 亚洲狠狠色丁香婷婷综合 | 欧美人与牲动交xxxx | 亚洲综合在线一区二区三区 | 日本丰满熟妇videos | 亚洲人成影院在线无码按摩店 | 国产精品a成v人在线播放 | 国产精品亚洲五月天高清 | 国产人妻人伦精品 | 亚洲精品国产a久久久久久 | 天堂亚洲2017在线观看 | 亚洲国产精品毛片av不卡在线 | 双乳奶水饱满少妇呻吟 | 国产精品成人av在线观看 | 丝袜足控一区二区三区 | аⅴ资源天堂资源库在线 | 久久99精品久久久久婷婷 | 亚洲人成人无码网www国产 | ass日本丰满熟妇pics | 无码国产激情在线观看 | 久久久久久亚洲精品a片成人 | 爱做久久久久久 | 伊人久久大香线蕉午夜 | 久久久久国色av免费观看性色 | 国内老熟妇对白xxxxhd | 欧美熟妇另类久久久久久不卡 | 日日麻批免费40分钟无码 | 丰满人妻精品国产99aⅴ | 十八禁真人啪啪免费网站 | 欧美大屁股xxxxhd黑色 | 日本欧美一区二区三区乱码 | 东北女人啪啪对白 | 99精品国产综合久久久久五月天 | 日本va欧美va欧美va精品 | 亚洲日本va午夜在线电影 | 亚洲精品成a人在线观看 | 国产又粗又硬又大爽黄老大爷视 | 欧美阿v高清资源不卡在线播放 | 中文字幕人妻无码一夲道 | 无码人妻久久一区二区三区不卡 | 中文字幕人成乱码熟女app | 人妻少妇精品无码专区动漫 | 乱中年女人伦av三区 | a国产一区二区免费入口 | 全黄性性激高免费视频 | 亚洲熟妇色xxxxx欧美老妇y | 天堂а√在线地址中文在线 | 久久久久久久人妻无码中文字幕爆 | 日本乱偷人妻中文字幕 | 亚洲性无码av中文字幕 | 人妻aⅴ无码一区二区三区 | 永久免费观看国产裸体美女 | 色综合久久88色综合天天 | 欧美日韩人成综合在线播放 | 亚洲一区二区三区含羞草 | 人妻天天爽夜夜爽一区二区 | 亚洲欧美综合区丁香五月小说 | 久久久久se色偷偷亚洲精品av | 丰满少妇人妻久久久久久 | 中文字幕av伊人av无码av | 亚洲国产综合无码一区 | 国产莉萝无码av在线播放 | 成人亚洲精品久久久久 | 亚洲日本va午夜在线电影 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲精品成人福利网站 | 国产精品多人p群无码 | 亚洲 高清 成人 动漫 | 无码av免费一区二区三区试看 | 西西人体www44rt大胆高清 | 人妻无码αv中文字幕久久琪琪布 | 性欧美疯狂xxxxbbbb | 国产精品亚洲综合色区韩国 | 国产午夜视频在线观看 | 成人av无码一区二区三区 | 欧美人与物videos另类 | 久久精品国产日本波多野结衣 | 国产9 9在线 | 中文 | 精品国产精品久久一区免费式 | 国产色精品久久人妻 | 四虎影视成人永久免费观看视频 | 国产成人久久精品流白浆 | 中文字幕日产无线码一区 | 日韩av无码中文无码电影 | 免费看少妇作爱视频 | 欧美 亚洲 国产 另类 | 久久综合给久久狠狠97色 | 亚洲成熟女人毛毛耸耸多 | 国产精品高潮呻吟av久久4虎 | 日韩欧美中文字幕公布 | 日本熟妇人妻xxxxx人hd | 曰韩无码二三区中文字幕 | a在线观看免费网站大全 | 国产内射老熟女aaaa | 国内综合精品午夜久久资源 | 日韩精品无码一本二本三本色 | 人人妻人人澡人人爽欧美一区九九 | 中文字幕av伊人av无码av | 精品偷自拍另类在线观看 | 亚洲天堂2017无码中文 | 免费人成在线观看网站 | 亚洲色成人中文字幕网站 | 少妇性l交大片欧洲热妇乱xxx | 亚洲欧美日韩国产精品一区二区 | 亚洲七七久久桃花影院 | 久久久久av无码免费网 | 欧美35页视频在线观看 | а√资源新版在线天堂 | 精品久久久无码人妻字幂 | 性色av无码免费一区二区三区 | 亚洲人交乣女bbw | 亚洲成熟女人毛毛耸耸多 | 女人和拘做爰正片视频 | 中文字幕av日韩精品一区二区 | 日日橹狠狠爱欧美视频 | 日本一区二区三区免费高清 | 国产成人综合色在线观看网站 | 无码国内精品人妻少妇 | 久久久国产一区二区三区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产无遮挡吃胸膜奶免费看 | 欧洲熟妇精品视频 | 在线观看国产午夜福利片 | 国产激情艳情在线看视频 | 精品久久综合1区2区3区激情 | 亚洲 欧美 激情 小说 另类 | 欧美 亚洲 国产 另类 | 日本一卡2卡3卡四卡精品网站 | 久久精品国产一区二区三区 | 99er热精品视频 | 亚洲男人av香蕉爽爽爽爽 | 欧美日韩人成综合在线播放 | 久久亚洲精品成人无码 | 97精品人妻一区二区三区香蕉 | 无遮挡国产高潮视频免费观看 | 日日摸日日碰夜夜爽av | 免费观看的无遮挡av | 小泽玛莉亚一区二区视频在线 | 成人无码视频在线观看网站 | 日本乱人伦片中文三区 | 无码国产色欲xxxxx视频 | 亚洲va中文字幕无码久久不卡 | 日日摸夜夜摸狠狠摸婷婷 | 捆绑白丝粉色jk震动捧喷白浆 | 午夜精品一区二区三区的区别 | 亚洲区欧美区综合区自拍区 | 国产精品久久久久久久影院 | 中文字幕无码热在线视频 | 午夜丰满少妇性开放视频 | 亚洲中文字幕在线无码一区二区 | 国产suv精品一区二区五 | 久久人人爽人人爽人人片av高清 | 国产三级久久久精品麻豆三级 | 性生交大片免费看女人按摩摩 | 日日橹狠狠爱欧美视频 | 无码人妻久久一区二区三区不卡 | 久久精品国产日本波多野结衣 | 人人妻人人澡人人爽欧美一区九九 | 男女下面进入的视频免费午夜 | 天天摸天天透天天添 | 国产午夜福利亚洲第一 | a国产一区二区免费入口 | 女人和拘做爰正片视频 | 精品一区二区三区无码免费视频 | 一本久久a久久精品亚洲 | 久久天天躁狠狠躁夜夜免费观看 | 久久综合香蕉国产蜜臀av | 大色综合色综合网站 | 亚洲国产精品美女久久久久 | 久久人人爽人人爽人人片av高清 | 久久久国产一区二区三区 | 久久国产劲爆∧v内射 | 永久免费精品精品永久-夜色 | 国产办公室秘书无码精品99 | 欧美xxxx黑人又粗又长 | 日日鲁鲁鲁夜夜爽爽狠狠 | 九月婷婷人人澡人人添人人爽 | 国产网红无码精品视频 | 国产精品久久国产精品99 | 又粗又大又硬毛片免费看 | 亚洲欧美日韩成人高清在线一区 | 国产成人精品三级麻豆 | 奇米影视7777久久精品 | 欧美人与牲动交xxxx | 永久免费观看美女裸体的网站 | 亚洲人亚洲人成电影网站色 | 成人无码精品1区2区3区免费看 | 精品人妻人人做人人爽夜夜爽 | 伊在人天堂亚洲香蕉精品区 | 夜夜影院未满十八勿进 | 亚洲乱码中文字幕在线 | 国产成人综合在线女婷五月99播放 | 国产精品久久久 | 熟女少妇人妻中文字幕 | 国产小呦泬泬99精品 | 国产精品亚洲五月天高清 | 丝袜人妻一区二区三区 | 一个人看的视频www在线 | 成人亚洲精品久久久久 | av无码不卡在线观看免费 | 麻豆av传媒蜜桃天美传媒 | 久久午夜无码鲁丝片秋霞 | 人妻少妇精品无码专区二区 | 国产xxx69麻豆国语对白 | 亚洲自偷精品视频自拍 | 国产激情无码一区二区 | 亚洲精品一区二区三区在线 | 黑森林福利视频导航 | 两性色午夜视频免费播放 | 秋霞特色aa大片 | 国内少妇偷人精品视频免费 | 色一情一乱一伦一区二区三欧美 | 波多野结衣 黑人 | 免费看男女做好爽好硬视频 | 强奷人妻日本中文字幕 | 无码精品国产va在线观看dvd | 日本在线高清不卡免费播放 | 亚洲va欧美va天堂v国产综合 | 在线成人www免费观看视频 | 久久久久99精品成人片 | 久久久国产一区二区三区 | 成人无码视频免费播放 | 无套内谢老熟女 | 国产欧美熟妇另类久久久 | 精品无码国产一区二区三区av | 无码av中文字幕免费放 | 88国产精品欧美一区二区三区 | 俄罗斯老熟妇色xxxx | 国产精品va在线播放 | 国产精品鲁鲁鲁 | 精品国产一区二区三区四区 | 久久精品无码一区二区三区 | 欧美人妻一区二区三区 | 国产凸凹视频一区二区 | 亚洲 另类 在线 欧美 制服 | 国产女主播喷水视频在线观看 | 人妻少妇精品久久 | 亚洲第一网站男人都懂 | 黄网在线观看免费网站 | 国精产品一品二品国精品69xx | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 久久久久久久人妻无码中文字幕爆 | 99久久婷婷国产综合精品青草免费 | 中文字幕乱码人妻无码久久 | 色婷婷香蕉在线一区二区 | 国产精品久久久av久久久 | 精品成在人线av无码免费看 | 人人澡人人透人人爽 | 中文字幕无码av波多野吉衣 | 88国产精品欧美一区二区三区 | 女人被爽到呻吟gif动态图视看 | 人人爽人人澡人人人妻 | 天天摸天天碰天天添 | 国产av一区二区三区最新精品 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产麻豆精品一区二区三区v视界 | 久久久无码中文字幕久... | 精品久久久无码中文字幕 | 最新国产乱人伦偷精品免费网站 | 久久97精品久久久久久久不卡 | 四虎永久在线精品免费网址 | а√资源新版在线天堂 | 偷窥村妇洗澡毛毛多 | 中国女人内谢69xxxxxa片 | 亚洲无人区一区二区三区 | 久久久中文久久久无码 | 国产精品久久久久无码av色戒 | 国产午夜手机精彩视频 | 亚洲自偷自拍另类第1页 | 熟妇人妻无乱码中文字幕 | 午夜福利试看120秒体验区 | 精品国产aⅴ无码一区二区 | 性开放的女人aaa片 | 亚洲一区二区三区国产精华液 | 伦伦影院午夜理论片 | 国产办公室秘书无码精品99 | 伊人久久大香线焦av综合影院 | 久久国产自偷自偷免费一区调 | 中文无码成人免费视频在线观看 | 又色又爽又黄的美女裸体网站 | 对白脏话肉麻粗话av | 久久无码人妻影院 | 国产亚洲精品久久久久久久久动漫 | 在线观看免费人成视频 | 大肉大捧一进一出视频出来呀 | 少妇性荡欲午夜性开放视频剧场 | 欧美人与牲动交xxxx | 高潮喷水的毛片 | 无码任你躁久久久久久久 | v一区无码内射国产 | 成人一区二区免费视频 | 国产av人人夜夜澡人人爽麻豆 | 中文精品久久久久人妻不卡 | 国产成人无码区免费内射一片色欲 | 少妇无码av无码专区在线观看 | 婷婷五月综合缴情在线视频 | 中文字幕无码免费久久9一区9 | 九月婷婷人人澡人人添人人爽 | 精品国精品国产自在久国产87 | 亚洲综合在线一区二区三区 | 强奷人妻日本中文字幕 | 国产精品久久久一区二区三区 | 国产亚洲精品久久久久久久 | 大肉大捧一进一出视频出来呀 | 丰满少妇人妻久久久久久 | 成人无码精品1区2区3区免费看 | 欧美怡红院免费全部视频 | 国产一区二区三区日韩精品 | 无码人妻精品一区二区三区下载 | 亚洲精品www久久久 | a在线亚洲男人的天堂 | 亚洲熟熟妇xxxx | 国产精品欧美成人 | 亚洲成av人在线观看网址 | 中文字幕人妻丝袜二区 | 中文字幕无码乱人伦 | 日本精品久久久久中文字幕 | 亚洲午夜福利在线观看 | 三上悠亚人妻中文字幕在线 | 青青草原综合久久大伊人精品 | 亚洲精品午夜无码电影网 | 无码人妻久久一区二区三区不卡 | 国产精品久久久久久亚洲毛片 | 中文字幕无码日韩欧毛 | 久久久无码中文字幕久... | 久久无码专区国产精品s | 亚洲国产精品无码一区二区三区 | 久久精品国产大片免费观看 | 未满成年国产在线观看 | 丰满肥臀大屁股熟妇激情视频 | 无码人妻黑人中文字幕 | 国产精品久久国产三级国 | 日本xxxx色视频在线观看免费 | av无码久久久久不卡免费网站 | 亚洲男人av香蕉爽爽爽爽 | 东北女人啪啪对白 | 丰满人妻被黑人猛烈进入 | 少妇性l交大片 | 日本免费一区二区三区最新 | 久久久久人妻一区精品色欧美 | 成人无码影片精品久久久 | 亚洲欧美日韩成人高清在线一区 | 国产情侣作爱视频免费观看 | 婷婷综合久久中文字幕蜜桃三电影 | 久久精品中文字幕一区 | 国产免费久久久久久无码 | 人妻少妇被猛烈进入中文字幕 | 内射白嫩少妇超碰 | 双乳奶水饱满少妇呻吟 | 国产绳艺sm调教室论坛 | 一本无码人妻在中文字幕免费 | 久久婷婷五月综合色国产香蕉 | 大屁股大乳丰满人妻 | 免费乱码人妻系列无码专区 | 亚洲成a人片在线观看无码3d | 最近中文2019字幕第二页 | 老子影院午夜精品无码 | 性做久久久久久久免费看 | 亚洲 激情 小说 另类 欧美 | 久久视频在线观看精品 | 伊人久久大香线蕉av一区二区 | 狠狠色欧美亚洲狠狠色www | 免费无码一区二区三区蜜桃大 | 久久伊人色av天堂九九小黄鸭 | 色老头在线一区二区三区 | 日本丰满护士爆乳xxxx | 欧美日韩一区二区综合 | 久久99精品久久久久婷婷 | 国产精品美女久久久久av爽李琼 | 日本熟妇人妻xxxxx人hd | 国产精品自产拍在线观看 | 蜜臀aⅴ国产精品久久久国产老师 | аⅴ资源天堂资源库在线 | 成人一区二区免费视频 | 秋霞成人午夜鲁丝一区二区三区 | 无码人妻丰满熟妇区毛片18 | 无码成人精品区在线观看 | 久久精品国产一区二区三区肥胖 | 樱花草在线播放免费中文 | 国产欧美精品一区二区三区 | 国内精品人妻无码久久久影院蜜桃 | 欧美精品在线观看 | 欧美丰满熟妇xxxx | 亚洲综合伊人久久大杳蕉 | 亚洲国产高清在线观看视频 | 无码精品人妻一区二区三区av | 国产婷婷色一区二区三区在线 | 亚洲天堂2017无码 | 成熟人妻av无码专区 | 国产舌乚八伦偷品w中 | 波多野结衣av一区二区全免费观看 | 国内揄拍国内精品人妻 | 国产精品-区区久久久狼 | 中文字幕乱码亚洲无线三区 | 亚洲aⅴ无码成人网站国产app | 午夜理论片yy44880影院 | 丰腴饱满的极品熟妇 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲精品一区三区三区在线观看 | 好屌草这里只有精品 | 无码成人精品区在线观看 | 亚洲精品一区国产 | 日韩少妇内射免费播放 | 国产农村妇女高潮大叫 | 欧美黑人巨大xxxxx | 国产精品成人av在线观看 | 成年美女黄网站色大免费视频 | 亚洲成在人网站无码天堂 | 六月丁香婷婷色狠狠久久 | 无码午夜成人1000部免费视频 | 久久综合色之久久综合 | 任你躁在线精品免费 | 乱码av麻豆丝袜熟女系列 | 日韩人妻无码中文字幕视频 | 超碰97人人做人人爱少妇 | 乌克兰少妇性做爰 | 成人无码视频在线观看网站 | 亚洲精品成人福利网站 | 在线天堂新版最新版在线8 | 日本精品人妻无码免费大全 | 国产无遮挡又黄又爽免费视频 | 成年女人永久免费看片 | 国产激情精品一区二区三区 | 小sao货水好多真紧h无码视频 | 无码人妻少妇伦在线电影 | 亚洲日韩av一区二区三区四区 | 成人无码视频免费播放 | 欧美精品在线观看 | 久久精品国产日本波多野结衣 | 国产女主播喷水视频在线观看 | 漂亮人妻洗澡被公强 日日躁 | 18禁黄网站男男禁片免费观看 | 亚洲欧美中文字幕5发布 | 乱码av麻豆丝袜熟女系列 | 自拍偷自拍亚洲精品10p | 成人毛片一区二区 | 蜜桃无码一区二区三区 | 蜜桃臀无码内射一区二区三区 | 欧美国产日韩亚洲中文 | 在线欧美精品一区二区三区 | 男女作爱免费网站 | 国产极品视觉盛宴 | 日产国产精品亚洲系列 | 国产日产欧产精品精品app | 日韩精品无码一区二区中文字幕 | 全黄性性激高免费视频 | 丰满少妇女裸体bbw | 久久午夜无码鲁丝片 | 亚洲综合无码一区二区三区 | 欧美激情综合亚洲一二区 | 最新国产麻豆aⅴ精品无码 | 一个人看的www免费视频在线观看 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产亚洲欧美在线专区 | 狠狠色色综合网站 | 精品偷拍一区二区三区在线看 | 男人的天堂av网站 | 一本久久伊人热热精品中文字幕 | 中文字幕色婷婷在线视频 | 国产99久久精品一区二区 | 中文精品久久久久人妻不卡 | 欧美日韩人成综合在线播放 | 色欲人妻aaaaaaa无码 | 天堂а√在线地址中文在线 | 美女极度色诱视频国产 | 亚洲成av人综合在线观看 | 亚洲精品一区二区三区在线 | 国产精品亚洲五月天高清 | 人妻有码中文字幕在线 | 双乳奶水饱满少妇呻吟 | 日本精品久久久久中文字幕 | 一本久道高清无码视频 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产成人无码区免费内射一片色欲 | 亚洲另类伦春色综合小说 | 99国产精品白浆在线观看免费 | 在线播放无码字幕亚洲 | 国产麻豆精品精东影业av网站 | 少妇人妻大乳在线视频 | 国产国语老龄妇女a片 | 中文字幕av伊人av无码av | 久久亚洲精品成人无码 | 亚洲精品国偷拍自产在线麻豆 | 欧洲精品码一区二区三区免费看 | 麻豆人妻少妇精品无码专区 | 日韩在线不卡免费视频一区 | 性开放的女人aaa片 | 东京无码熟妇人妻av在线网址 | 嫩b人妻精品一区二区三区 | 亚洲欧美日韩综合久久久 | 性欧美牲交xxxxx视频 | 麻豆av传媒蜜桃天美传媒 | 全黄性性激高免费视频 | 131美女爱做视频 | 无码人妻久久一区二区三区不卡 | 精品偷自拍另类在线观看 | 激情内射亚州一区二区三区爱妻 | 精品国产成人一区二区三区 | 精品成人av一区二区三区 | 2020最新国产自产精品 | 欧美性猛交xxxx富婆 | 在线观看国产午夜福利片 | 国产精品毛多多水多 | 成人动漫在线观看 | 性欧美熟妇videofreesex | 国产av无码专区亚洲awww | 少妇被黑人到高潮喷出白浆 | 宝宝好涨水快流出来免费视频 | 日本精品人妻无码免费大全 | 牛和人交xxxx欧美 | 久久精品无码一区二区三区 | 欧美精品国产综合久久 | 精品一区二区三区无码免费视频 | 夜先锋av资源网站 | 日韩精品久久久肉伦网站 | 亚洲色欲色欲天天天www | 中文无码伦av中文字幕 | 色综合视频一区二区三区 | 久久www免费人成人片 | 欧美人与动性行为视频 | 亚洲国产精品一区二区第一页 | 青青久在线视频免费观看 | 欧美日韩色另类综合 | 国产亚洲精品久久久久久久 | a在线观看免费网站大全 | 两性色午夜免费视频 | ass日本丰满熟妇pics | 色狠狠av一区二区三区 | 久久久久成人片免费观看蜜芽 | 国产舌乚八伦偷品w中 | 亚洲精品综合一区二区三区在线 | 黑人巨大精品欧美黑寡妇 | 丁香花在线影院观看在线播放 | 一本色道久久综合狠狠躁 | 国产又粗又硬又大爽黄老大爷视 | 无码人妻精品一区二区三区下载 | 久久综合网欧美色妞网 | 水蜜桃亚洲一二三四在线 | 天堂а√在线地址中文在线 | 日韩人妻系列无码专区 | 麻豆人妻少妇精品无码专区 | 国产无遮挡又黄又爽免费视频 | 久精品国产欧美亚洲色aⅴ大片 | 久久午夜无码鲁丝片秋霞 | a在线亚洲男人的天堂 | 色欲久久久天天天综合网精品 | 高潮毛片无遮挡高清免费视频 | 玩弄人妻少妇500系列视频 | 日日摸夜夜摸狠狠摸婷婷 | 国产乡下妇女做爰 | 欧洲极品少妇 | 欧美 日韩 人妻 高清 中文 | 少妇的肉体aa片免费 | 久久久久亚洲精品男人的天堂 | 亚洲精品综合一区二区三区在线 | 久久综合给久久狠狠97色 | 国产亚洲欧美在线专区 | 强开小婷嫩苞又嫩又紧视频 | 久久久精品456亚洲影院 | 国产成人人人97超碰超爽8 | 久久久久成人精品免费播放动漫 | 高清无码午夜福利视频 | 无码人妻久久一区二区三区不卡 | 伊人久久大香线蕉午夜 | 中文精品无码中文字幕无码专区 | 国产美女极度色诱视频www | 国产欧美亚洲精品a | 午夜男女很黄的视频 | 天天躁夜夜躁狠狠是什么心态 | 亚洲va中文字幕无码久久不卡 | 青青久在线视频免费观看 | av无码不卡在线观看免费 | 精品国产成人一区二区三区 | 国产成人精品必看 | 老司机亚洲精品影院 | 成人无码影片精品久久久 | 国产成人无码a区在线观看视频app | 正在播放老肥熟妇露脸 | 亚洲人成无码网www | 精品水蜜桃久久久久久久 | 在线精品国产一区二区三区 | 国产精品自产拍在线观看 | 亚洲精品一区二区三区婷婷月 | 东京一本一道一二三区 | 欧美日本免费一区二区三区 | 亚洲另类伦春色综合小说 | 免费看男女做好爽好硬视频 | 精品少妇爆乳无码av无码专区 | 久久久精品人妻久久影视 | 一本久久a久久精品亚洲 | 中文字幕av无码一区二区三区电影 | 亚洲欧美国产精品专区久久 | 国产国产精品人在线视 | 亚洲阿v天堂在线 | 中文字幕 人妻熟女 | 1000部啪啪未满十八勿入下载 | 少妇厨房愉情理9仑片视频 | 欧美国产日产一区二区 | 无套内谢的新婚少妇国语播放 | 99久久人妻精品免费一区 | 狂野欧美性猛xxxx乱大交 | 久久无码专区国产精品s | 丰满少妇人妻久久久久久 | 亚洲精品无码国产 | 日韩av无码中文无码电影 | 一个人看的视频www在线 | yw尤物av无码国产在线观看 | 欧美人与禽zoz0性伦交 | 亚洲人成人无码网www国产 | 欧美黑人性暴力猛交喷水 | 成人一在线视频日韩国产 | 国产精品爱久久久久久久 | 日韩在线不卡免费视频一区 | 5858s亚洲色大成网站www | 伦伦影院午夜理论片 | 中文字幕人妻丝袜二区 | 性欧美videos高清精品 | 亚拍精品一区二区三区探花 | 亚洲色在线无码国产精品不卡 | 久久久久久久女国产乱让韩 | 久久久久久亚洲精品a片成人 | 在线精品亚洲一区二区 | 国产乱人偷精品人妻a片 | 亚洲精品一区二区三区在线 | 亚洲日韩av一区二区三区中文 | 亚洲午夜无码久久 | 天下第一社区视频www日本 | 亚洲精品国产品国语在线观看 | 国产精品手机免费 | a在线亚洲男人的天堂 | aⅴ亚洲 日韩 色 图网站 播放 | 天天燥日日燥 | 图片区 小说区 区 亚洲五月 | 高潮毛片无遮挡高清免费视频 | 国产艳妇av在线观看果冻传媒 | 国产办公室秘书无码精品99 | 久久精品人妻少妇一区二区三区 | 无码人妻av免费一区二区三区 | 丝袜足控一区二区三区 | 日日麻批免费40分钟无码 | 国产精品毛多多水多 | 久久综合狠狠综合久久综合88 | 麻豆果冻传媒2021精品传媒一区下载 | 2020久久超碰国产精品最新 | 荫蒂被男人添的好舒服爽免费视频 | 人妻互换免费中文字幕 | 天天综合网天天综合色 | 亚洲国产精品毛片av不卡在线 | 一本色道久久综合狠狠躁 | 精品久久久中文字幕人妻 | 老熟女乱子伦 | 午夜精品久久久久久久 | 亚洲精品午夜无码电影网 | 国产亚洲人成在线播放 | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲精品美女久久久久久久 | 亚洲精品中文字幕久久久久 | 1000部夫妻午夜免费 | 国产无套内射久久久国产 | 久久人人97超碰a片精品 | 免费国产成人高清在线观看网站 | 国产黑色丝袜在线播放 | 黑人玩弄人妻中文在线 | 亚洲色欲色欲天天天www | 亚洲欧洲日本无在线码 | 欧美喷潮久久久xxxxx | 人人妻人人澡人人爽人人精品浪潮 | 国产无遮挡又黄又爽又色 | 国产成人av免费观看 | 国产精品久久久久久无码 | 无码人妻精品一区二区三区下载 | 强伦人妻一区二区三区视频18 | 国产sm调教视频在线观看 | 性欧美大战久久久久久久 | 国产精品无码永久免费888 | 国产精品久久久久久无码 | 色一情一乱一伦一视频免费看 | 午夜男女很黄的视频 | 日韩在线不卡免费视频一区 | 色欲av亚洲一区无码少妇 | 色欲综合久久中文字幕网 | 性欧美疯狂xxxxbbbb | 精品久久久久久人妻无码中文字幕 | 午夜精品一区二区三区在线观看 | 国产日产欧产精品精品app | 亚洲精品中文字幕 | 国产人妻精品午夜福利免费 | 国产成人午夜福利在线播放 | 国产午夜视频在线观看 | 免费乱码人妻系列无码专区 | 国产又粗又硬又大爽黄老大爷视 | 麻花豆传媒剧国产免费mv在线 | 色综合久久久久综合一本到桃花网 | 亚洲の无码国产の无码影院 | 人妻少妇精品无码专区二区 | 理论片87福利理论电影 | 久久综合久久自在自线精品自 | 国产成人无码a区在线观看视频app | 精品偷拍一区二区三区在线看 | 国产成人精品必看 | 精品一区二区三区无码免费视频 | 色偷偷人人澡人人爽人人模 | 正在播放老肥熟妇露脸 | 国产午夜亚洲精品不卡 | 国产精品亚洲专区无码不卡 | 国精产品一区二区三区 | 初尝人妻少妇中文字幕 | 少妇久久久久久人妻无码 | 特黄特色大片免费播放器图片 | 成人免费视频视频在线观看 免费 | 久久亚洲精品成人无码 | 97人妻精品一区二区三区 | 亚洲男人av天堂午夜在 | 丰满少妇弄高潮了www | 欧美日本免费一区二区三区 | 国产亚洲视频中文字幕97精品 | 无码国内精品人妻少妇 | 午夜无码区在线观看 | 日韩精品久久久肉伦网站 | 丰满少妇人妻久久久久久 | 久久久www成人免费毛片 | 色一情一乱一伦一区二区三欧美 | 人人爽人人澡人人人妻 | 久久午夜无码鲁丝片午夜精品 | 在线欧美精品一区二区三区 | 亲嘴扒胸摸屁股激烈网站 | 欧洲vodafone精品性 | 精品无人区无码乱码毛片国产 | 欧美黑人乱大交 | 亚洲日本一区二区三区在线 | 免费视频欧美无人区码 | 亚洲码国产精品高潮在线 | 欧美精品国产综合久久 | 国产av无码专区亚洲awww | 水蜜桃亚洲一二三四在线 | 国产真实夫妇视频 | 国产成人一区二区三区在线观看 | 天堂亚洲2017在线观看 | 性色欲情网站iwww九文堂 | 免费人成在线视频无码 | 精品国产麻豆免费人成网站 | 国产免费久久久久久无码 | 性生交片免费无码看人 | 美女扒开屁股让男人桶 | 红桃av一区二区三区在线无码av | 黑森林福利视频导航 | 亚洲色欲色欲天天天www | 精品水蜜桃久久久久久久 | 扒开双腿疯狂进出爽爽爽视频 | 久久亚洲国产成人精品性色 | 精品国产乱码久久久久乱码 | 日本爽爽爽爽爽爽在线观看免 | 久久久久人妻一区精品色欧美 | 内射欧美老妇wbb | 日韩欧美中文字幕在线三区 | 久久亚洲a片com人成 | 精品久久久久久亚洲精品 | 久久久婷婷五月亚洲97号色 | 欧美 日韩 人妻 高清 中文 | 久久精品中文字幕大胸 | 在线精品亚洲一区二区 | 一本精品99久久精品77 | av无码不卡在线观看免费 | 狠狠色欧美亚洲狠狠色www | 亚洲啪av永久无码精品放毛片 | 国产肉丝袜在线观看 | 免费观看的无遮挡av | 四虎影视成人永久免费观看视频 | 国产精品免费大片 | 97夜夜澡人人爽人人喊中国片 | 又紧又大又爽精品一区二区 | 国内揄拍国内精品少妇国语 | 性欧美大战久久久久久久 | 国产精品人妻一区二区三区四 | 精品欧洲av无码一区二区三区 | 婷婷六月久久综合丁香 | 中文字幕av伊人av无码av | 乌克兰少妇性做爰 | 色情久久久av熟女人妻网站 | 红桃av一区二区三区在线无码av | 国产午夜福利亚洲第一 | 蜜臀av在线播放 久久综合激激的五月天 | 久久天天躁夜夜躁狠狠 | 欧美兽交xxxx×视频 | 久久久成人毛片无码 | 白嫩日本少妇做爰 | 97久久精品无码一区二区 | aⅴ在线视频男人的天堂 | 欧美日本精品一区二区三区 | 国产成人久久精品流白浆 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲国产欧美在线成人 | 精品偷自拍另类在线观看 | 55夜色66夜色国产精品视频 | 精品人妻中文字幕有码在线 | 久久久久久av无码免费看大片 | 久久精品无码一区二区三区 | yw尤物av无码国产在线观看 | 日本爽爽爽爽爽爽在线观看免 | 四虎影视成人永久免费观看视频 | 麻花豆传媒剧国产免费mv在线 | 人人妻人人澡人人爽人人精品浪潮 | 无码中文字幕色专区 | 人妻与老人中文字幕 | 人人妻人人澡人人爽人人精品浪潮 | 领导边摸边吃奶边做爽在线观看 | 一本久道久久综合婷婷五月 | aⅴ在线视频男人的天堂 | 人人澡人摸人人添 | 一本久久伊人热热精品中文字幕 | 成年美女黄网站色大免费全看 | 亚洲乱码中文字幕在线 | 水蜜桃亚洲一二三四在线 | 黑人玩弄人妻中文在线 | 在线精品亚洲一区二区 | 国产无套粉嫩白浆在线 | 亚洲精品久久久久久久久久久 | 四虎影视成人永久免费观看视频 | 久久这里只有精品视频9 | 日韩精品久久久肉伦网站 | 少妇被粗大的猛进出69影院 | 最近的中文字幕在线看视频 | 男女性色大片免费网站 | 牛和人交xxxx欧美 | 青青久在线视频免费观看 | 中文字幕乱码亚洲无线三区 | 毛片内射-百度 | 国产精品人人爽人人做我的可爱 | 亚洲精品久久久久avwww潮水 | 青青青爽视频在线观看 | 人妻体内射精一区二区三四 | 无码人妻av免费一区二区三区 | 精品久久久无码人妻字幂 | a国产一区二区免费入口 | 亚洲小说图区综合在线 | 免费无码av一区二区 | 老熟女乱子伦 | 亚洲精品国偷拍自产在线观看蜜桃 | 对白脏话肉麻粗话av | 亚洲国产av精品一区二区蜜芽 | 久久综合色之久久综合 | 夜夜夜高潮夜夜爽夜夜爰爰 | 大屁股大乳丰满人妻 | 欧美freesex黑人又粗又大 | 久久精品中文字幕一区 | 亚洲国产精华液网站w | 全黄性性激高免费视频 | 亚洲一区二区观看播放 | 亚洲综合另类小说色区 | 午夜精品一区二区三区在线观看 | 久久久久久久人妻无码中文字幕爆 | 亚欧洲精品在线视频免费观看 | 免费看少妇作爱视频 | 午夜福利一区二区三区在线观看 | 夫妻免费无码v看片 | 亚洲va欧美va天堂v国产综合 | 国产艳妇av在线观看果冻传媒 | 亚洲中文字幕成人无码 | 丰满妇女强制高潮18xxxx | 亚洲国产av美女网站 | 玩弄少妇高潮ⅹxxxyw | 学生妹亚洲一区二区 | 无码国产色欲xxxxx视频 | 欧美zoozzooz性欧美 | 无码人妻久久一区二区三区不卡 | 暴力强奷在线播放无码 | 欧美亚洲日韩国产人成在线播放 | 亚洲人成影院在线观看 | 国产va免费精品观看 | 日韩av无码一区二区三区 | 无码国产色欲xxxxx视频 | 18禁止看的免费污网站 | 丰满少妇人妻久久久久久 | 麻豆国产97在线 | 欧洲 | 欧美亚洲国产一区二区三区 | 又粗又大又硬毛片免费看 | 亚洲精品一区二区三区四区五区 | 精品亚洲韩国一区二区三区 | 日韩人妻无码中文字幕视频 | 国产成人精品视频ⅴa片软件竹菊 | 久久午夜无码鲁丝片午夜精品 | 麻花豆传媒剧国产免费mv在线 | 女人色极品影院 | 欧美 丝袜 自拍 制服 另类 | 亚洲精品一区二区三区在线观看 | 国内老熟妇对白xxxxhd | 国产在线aaa片一区二区99 | 男女猛烈xx00免费视频试看 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 天干天干啦夜天干天2017 | 欧美性猛交内射兽交老熟妇 | 一本久道高清无码视频 | 亚洲乱码中文字幕在线 | 一本一道久久综合久久 | 日本在线高清不卡免费播放 | 国产在线一区二区三区四区五区 | 精品国产一区二区三区av 性色 | 精品一区二区不卡无码av | 日本欧美一区二区三区乱码 | 欧美野外疯狂做受xxxx高潮 | 国产精品无码久久av | 日日橹狠狠爱欧美视频 | 76少妇精品导航 | 亚洲欧美日韩成人高清在线一区 | 少妇性荡欲午夜性开放视频剧场 | 性色av无码免费一区二区三区 | 亚洲 欧美 激情 小说 另类 | 日韩无套无码精品 | 99久久无码一区人妻 | 熟妇女人妻丰满少妇中文字幕 | 免费乱码人妻系列无码专区 | 欧美日韩在线亚洲综合国产人 | 久久亚洲精品中文字幕无男同 | 久久国产劲爆∧v内射 | 丰满少妇女裸体bbw | 国产精品-区区久久久狼 | 伊人久久大香线焦av综合影院 | 九九久久精品国产免费看小说 | yw尤物av无码国产在线观看 | 欧美亚洲日韩国产人成在线播放 | 野外少妇愉情中文字幕 | 色妞www精品免费视频 | 免费无码一区二区三区蜜桃大 | 无码人妻av免费一区二区三区 | 性欧美疯狂xxxxbbbb | 沈阳熟女露脸对白视频 | 一本一道久久综合久久 | 一区二区三区高清视频一 | 中文字幕无码人妻少妇免费 | 在线精品亚洲一区二区 | 亚洲熟妇色xxxxx欧美老妇 | 四虎国产精品一区二区 | 国产农村妇女高潮大叫 | 国产精品a成v人在线播放 | 久久久久久亚洲精品a片成人 | 亚洲国产精品久久久久久 | 久久精品人人做人人综合试看 | 日日摸夜夜摸狠狠摸婷婷 | 色婷婷综合激情综在线播放 | 久久精品国产一区二区三区 | 精品乱码久久久久久久 | 色情久久久av熟女人妻网站 | 牛和人交xxxx欧美 | 国产精品理论片在线观看 | а天堂中文在线官网 | 精品国产成人一区二区三区 | 中文字幕久久久久人妻 | 亚洲经典千人经典日产 | 精品一区二区三区无码免费视频 | 日日碰狠狠躁久久躁蜜桃 | 在线播放无码字幕亚洲 | 亚洲国产精品无码一区二区三区 | 人妻人人添人妻人人爱 | 国产做国产爱免费视频 | 欧美人与禽zoz0性伦交 | 亚洲一区二区观看播放 | 日日摸天天摸爽爽狠狠97 | 国产熟女一区二区三区四区五区 | 中文字幕人妻无码一夲道 | 欧美老妇交乱视频在线观看 | 国产成人午夜福利在线播放 | 男女爱爱好爽视频免费看 | 色欲人妻aaaaaaa无码 | 亚洲日韩一区二区三区 | 日日摸天天摸爽爽狠狠97 | 无码精品国产va在线观看dvd | 国产三级久久久精品麻豆三级 | 高清无码午夜福利视频 | 牲欲强的熟妇农村老妇女 | 亚洲色欲色欲天天天www | 精品国产一区二区三区av 性色 | 无码免费一区二区三区 | 日本精品人妻无码免费大全 | 少女韩国电视剧在线观看完整 | а天堂中文在线官网 | 久久人人爽人人爽人人片av高清 | 波多野结衣av一区二区全免费观看 | 人妻人人添人妻人人爱 | 天天摸天天透天天添 | 丰满护士巨好爽好大乳 | 18禁黄网站男男禁片免费观看 | 性欧美牲交xxxxx视频 | 国产精品a成v人在线播放 | 中文字幕 人妻熟女 | 精品国产av色一区二区深夜久久 | 亚洲经典千人经典日产 | 国产亚洲精品久久久久久久久动漫 | 在线观看欧美一区二区三区 | 天天躁夜夜躁狠狠是什么心态 | 国产三级久久久精品麻豆三级 | 午夜成人1000部免费视频 | 中文精品无码中文字幕无码专区 | 国产亚洲视频中文字幕97精品 | 久久天天躁夜夜躁狠狠 | 久久久久久久女国产乱让韩 | 欧美人妻一区二区三区 | 国产成人精品必看 | 红桃av一区二区三区在线无码av | 久久综合给久久狠狠97色 | 久久综合给合久久狠狠狠97色 | 国产网红无码精品视频 | 乱人伦中文视频在线观看 | 人妻天天爽夜夜爽一区二区 | 国产亚洲人成在线播放 | 免费视频欧美无人区码 | 一本久久伊人热热精品中文字幕 | 丰满人妻翻云覆雨呻吟视频 | 免费看少妇作爱视频 | 日产精品高潮呻吟av久久 | 亚洲精品午夜无码电影网 | 99精品无人区乱码1区2区3区 | 3d动漫精品啪啪一区二区中 | 久久精品国产一区二区三区肥胖 | 国产无av码在线观看 | 97色伦图片97综合影院 | 黄网在线观看免费网站 | 久久综合九色综合欧美狠狠 | 亚洲成av人影院在线观看 | 日韩人妻无码中文字幕视频 | 丰满少妇女裸体bbw | 国产亚洲精品精品国产亚洲综合 | 女人色极品影院 | 又色又爽又黄的美女裸体网站 | 久久久精品456亚洲影院 | 永久免费观看国产裸体美女 | 中文字幕人妻无码一区二区三区 | 亚洲男人av香蕉爽爽爽爽 | 亚洲国产精品久久久久久 | 国产综合色产在线精品 | 日本精品少妇一区二区三区 | 精品无码一区二区三区的天堂 | 久久午夜夜伦鲁鲁片无码免费 | 久久五月精品中文字幕 | 欧美野外疯狂做受xxxx高潮 | 亚洲欧美综合区丁香五月小说 | 麻花豆传媒剧国产免费mv在线 | 正在播放老肥熟妇露脸 | 综合人妻久久一区二区精品 | 激情五月综合色婷婷一区二区 | 三上悠亚人妻中文字幕在线 | 内射巨臀欧美在线视频 | 人人妻人人澡人人爽人人精品 | 午夜精品一区二区三区的区别 | 日本大乳高潮视频在线观看 | 装睡被陌生人摸出水好爽 | 国产特级毛片aaaaaaa高清 | 久久久国产一区二区三区 | 一本久久a久久精品亚洲 | 免费观看激色视频网站 | 久久精品中文字幕大胸 | 欧美丰满少妇xxxx性 | 国产精品二区一区二区aⅴ污介绍 | 又粗又大又硬又长又爽 | 伊人久久大香线蕉av一区二区 | 成人性做爰aaa片免费看不忠 | 国产成人综合在线女婷五月99播放 | 精品国产一区二区三区av 性色 | 东京热一精品无码av | 黑人巨大精品欧美一区二区 | 国产极品美女高潮无套在线观看 | 蜜桃无码一区二区三区 | 日韩无套无码精品 | 欧美freesex黑人又粗又大 | 国产做国产爱免费视频 | 成人三级无码视频在线观看 | 国产一区二区三区影院 | 99re在线播放 | 免费男性肉肉影院 | 无码人妻精品一区二区三区下载 | 午夜熟女插插xx免费视频 | 国产av一区二区精品久久凹凸 | 又湿又紧又大又爽a视频国产 | 国产真实乱对白精彩久久 | 亚洲色大成网站www国产 | 国产三级精品三级男人的天堂 | 亚洲综合无码一区二区三区 | 人妻天天爽夜夜爽一区二区 | 中文字幕日产无线码一区 | 丰满少妇熟乱xxxxx视频 | 国产精品久久久久9999小说 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 亚洲国产成人a精品不卡在线 | 成人av无码一区二区三区 | 亚洲精品美女久久久久久久 | 天下第一社区视频www日本 | 国产亚洲欧美在线专区 | 久久精品中文字幕大胸 | 999久久久国产精品消防器材 | 欧美丰满熟妇xxxx | 精品夜夜澡人妻无码av蜜桃 | 内射白嫩少妇超碰 | 天干天干啦夜天干天2017 | 久久国产精品_国产精品 | 免费视频欧美无人区码 | 免费网站看v片在线18禁无码 | 伊人久久婷婷五月综合97色 | 丰满人妻精品国产99aⅴ | 精品亚洲韩国一区二区三区 | 欧美喷潮久久久xxxxx | 午夜时刻免费入口 | 国产精品久久精品三级 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲人成影院在线观看 | 色 综合 欧美 亚洲 国产 | 国产av剧情md精品麻豆 | 澳门永久av免费网站 | 久久久国产精品无码免费专区 | 波多野结衣乳巨码无在线观看 | 中文字幕色婷婷在线视频 | 最新国产麻豆aⅴ精品无码 | 亚洲日本va午夜在线电影 | 亚洲色大成网站www | 欧美自拍另类欧美综合图片区 | 国产猛烈高潮尖叫视频免费 | 久久综合九色综合欧美狠狠 | 中文字幕无码日韩欧毛 | 精品国产国产综合精品 | 久久久久se色偷偷亚洲精品av | 亚洲经典千人经典日产 | 一本色道婷婷久久欧美 | 精品久久8x国产免费观看 | 日本护士毛茸茸高潮 | 亚洲综合无码久久精品综合 | 亚洲色欲色欲天天天www | 九九综合va免费看 | av无码电影一区二区三区 | 欧美人与禽zoz0性伦交 | 久久久久av无码免费网 | av人摸人人人澡人人超碰下载 | 99久久久无码国产aaa精品 | 精品久久久无码人妻字幂 | 成人片黄网站色大片免费观看 | 亚洲国产欧美日韩精品一区二区三区 | 爆乳一区二区三区无码 | 亚洲精品成人福利网站 | 国产av一区二区三区最新精品 | 精品偷自拍另类在线观看 | 老熟女重囗味hdxx69 | 亚洲国精产品一二二线 | 夜夜影院未满十八勿进 | 亚洲另类伦春色综合小说 | 一二三四在线观看免费视频 | 免费网站看v片在线18禁无码 | 国产精品va在线观看无码 | 亚洲熟妇色xxxxx欧美老妇 | 国产做国产爱免费视频 | 大肉大捧一进一出好爽视频 | 高潮毛片无遮挡高清免费 | 精品国产乱码久久久久乱码 | 亚洲熟妇自偷自拍另类 | 亚洲区欧美区综合区自拍区 | 女人被爽到呻吟gif动态图视看 | 久久久婷婷五月亚洲97号色 | 亚洲a无码综合a国产av中文 | 国产精品欧美成人 | 色窝窝无码一区二区三区色欲 | 午夜成人1000部免费视频 | 中文字幕av无码一区二区三区电影 | 亚洲狠狠婷婷综合久久 | 无码av中文字幕免费放 | 国产一区二区不卡老阿姨 | 亚洲精品一区二区三区婷婷月 | 国产极品美女高潮无套在线观看 | 精品无码一区二区三区的天堂 | 亚洲精品久久久久中文第一幕 | 久久精品国产一区二区三区肥胖 | 午夜精品久久久内射近拍高清 | 高清不卡一区二区三区 | 国产精品国产三级国产专播 | 中文字幕人妻无码一夲道 | 少妇激情av一区二区 | 欧美成人午夜精品久久久 | 亚洲乱码国产乱码精品精 | 东京热无码av男人的天堂 | 国产精品毛多多水多 | 少妇被黑人到高潮喷出白浆 | 性开放的女人aaa片 | 老熟妇仑乱视频一区二区 | 一本大道久久东京热无码av | 久久无码专区国产精品s | 无码成人精品区在线观看 | 国产午夜精品一区二区三区嫩草 | 人妻无码久久精品人妻 | 亚洲国精产品一二二线 | 丰满少妇熟乱xxxxx视频 | 日日摸天天摸爽爽狠狠97 |