精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一起聊聊引入 JaCoCo導致的類型轉換問題,你明白了嗎?

開發 前端
圖片 01 問題描述 理解,首先 MCube 會依據模板緩存狀態判斷是否需要網絡獲取最新模板,當獲取到模板后進行模板加載,加載階段會將產物轉換為視圖樹的結構,轉換完成后將通過表達式引擎解析表達式并取得正確的值,通過事件解析引擎解析用戶自定義事件并完成事件的綁定,完成解析賦值以及事件綁定后進行視圖的渲染,最終將 JaCoCo是一款被廣泛應用于公司內部的開源覆蓋率工具,將其引用至測

一、問題描述  

理解,首先 MCube 會依據模板緩存狀態判斷是否需要網絡獲取最新模板,當獲取到模板后進行模板加載,加載階段會將產物轉換為視圖樹的結構,轉換完成后將通過表達式引擎解析表達式并取得正確的值,通過事件解析引擎解析用戶自定義事件并完成事件的綁定,完成解析賦值以及事件綁定后進行視圖的渲染,最終將

JaCoCo是一款被廣泛應用于公司內部的開源覆蓋率工具,將其引用至測試環境后,機器啟動正常,但在操作下單時出現異常,阻塞下單流程。

去除JaCoCo配置、重新編譯和部署后下單功能恢復正常。堆棧信息顯示,問題源于系統對請求字段進行加密時出現異常,因為無法完成類型轉換拋出異常,“[Z cannot be cast to [Ljava.lang.Object”,從而阻塞下單流程。

以下為報錯堆棧信息:

java.lang.ClassCastException: [Z cannot be cast to [Ljava.lang.Object;
  at com.jd.**.TdeProxy.encryptObject(TdeProxy.java:93) 
  at com.jd.**.TdeProxy.encryptObject(TdeProxy.java:133) 
  at com.jd.**.TdeProxy.encryptObject(TdeProxy.java:90) 
  at com.jd.**.TdeProxy.encryptObject(TdeProxy.java:133) 
  at com.jd.**.TdeProxy.encryptObject(TdeProxy.java:90) 
  at com.jd.**.TdeProxy.encryptObject(TdeProxy.java:133) 
  at com.jd.**.TdeProxy.encryptObject(TdeProxy.java:133)
  at com.jd.**.TdeProxy.$$FastClassBySpringCGLIB$$4fa3c52.invoke(<generated>) 
  at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218) 
  at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:769) 
    ..省略

二、問題分析

理解,首先 MCube 會依據模板緩存狀態判斷是否需要網絡獲取最新模板,當獲取到模板后進行模板加載,加載階段會將產物轉換為視圖樹的結構,轉換完成后將通過表達式引擎解析表達式并取得正確的值,通過事件解析引擎解析用戶自定義事件并完成事件的綁定,完成解析賦值以及事件綁定后進行視圖的渲染,最終將

1.報錯代碼

定位報錯信息顯示的代碼位置,確認該部分代碼并沒有被修改過。報錯提示指出屬性應為數組類型,但在需要加密的類屬性中并沒有涉及數組類型的處理。那么“[Z”這個類型又是從何而來呢?這種情況下不禁讓人懷疑,在某個時刻類可能被修改過。

報錯信息中的"[Z"代表的是Java中的boolean類型數組。在Java中,基本數據類型的數組也會被表示為類似于"[Z"、"[B"、"[L"等形式的字符串,這可能是因為在程序運行過程中對類進行了動態修改或者反射操作導致的。

以下為報錯處的代碼片段,在將obj轉換為Object[]時出現異常,既然已經識別出是數組,但是又無法完成類型轉換,具體的原因需要進一步分析。

public void encryptObject(Object obj, String type) throws IllegalAccessException {
    /***省略***/
    if (Map.class.isAssignableFrom(clazz)) {
        /***省略***/
    } else if(Iterable.class.isAssignableFrom(clazz)) {
        /***省略***/
    } else if(clazz.isArray()) {
        /**********************報錯代碼行****************/
        for (Object o : (Object[]) obj) {
        /**********************報錯代碼行****************/
            this.encryptObject(o, type);
        }
    } else {
        Boolean encryptFlag = null;
        Field[] fields = this.getDeclaredFieldsAll(clazz);
        for (Field field : fields) {
            /***省略***/
        }
        /***省略***/
        for (Field field : fields) {
            Class fieldClazz = field.getType();
            if (fieldClazz == String.class) {
                /***省略***/
            } else {
                field.setAccessible(true);
                Object fieldValue = field.get(obj);
                this.encryptObject(fieldValue, type);
            }
        }
    }
}

2.分析路徑

閱讀代碼可以看出encryptObject方法是通過遞歸實現的,其主要功能是對有效集合進行遍歷,所以問題的重點不是遞歸的過程,而是推進遞歸過程的元素集合,集合中的元素無法正常進行類型轉換導致報錯,這就需要檢查getDeclaredFieldsAll方法,該方法在運行時返回的集合中可能包含意料之外的元素,以下為具體實現代碼:

public Field[] getDeclaredFieldsAll(Class clazz) {
    List<Field> fieldsList = new ArrayList<Field>();
    while (clazz != null) {
        Field[] declaredFields = clazz.getDeclaredFields();
        fieldsList.addAll(Arrays.asList(declaredFields));
        clazz = clazz.getSuperclass();
    }
    return fieldsList.toArray(new Field[fieldsList.size()]);
}

由于已確認引入JaCoCo后對類進行了修改,只需觸發任一流程以獲取類的所有屬性,通過設置斷點并觀察集合中的元素,即可查看具體修改情況。

圖片圖片

此時已經可以解釋為什么引入JaCoCo會導致異常。報錯中的類型“[Z”為合成的屬性,引入JaCoCo會給類添加一個名為$jacocoData的bool數組類型屬性,回到報錯代碼位置,出現報錯是因為在識別到一個數組類型時進行了類型轉換,在這里也找到了問題的答案。

涉及到合成屬性/方法和JaCoCo的實現原理,下面進行簡單的介紹。

3.追本溯源

(1)合成屬性和方法

合成屬性/方法是由Java編譯器在編譯過程中自動生成,并不是研發顯示編寫的,而是為了支持編譯器內部的實現細節而生成的,下面針對合成方法進行一個舉例說明。

public class Pack {
    public static void main(String[] args) {
        Pack.Goods goods = new Pack.Goods();
        System.out.println(goods.name);
    }
    private static class Goods {  
       private String name = "手機";
    }
}

將上面的代碼編譯一下,可以看到有三個文件,Pack$Goods.class、Pack.class、Pack$1.class,前兩個一個是內部類,一個是外部類,但是最后一個類并沒有被定義過,接下來分別將內部類和外部類進行反編譯:

import com.jd.ryan.test.Pack.1;
class Pack$Goods {
    private String name; 
    private Pack$Goods() {
        this.name = "手機";
    }
    Pack$Goods(1 x0) {
        this(); 
    }
    static String access$100(Pack$Goods x0) {
        return x0.name; 
    }
}

內部類被反編譯后,可以發現access$100的方法并沒有被定義,但是分析來看name是內部類Goods的私有屬性,但是外部類可以直接引用這個屬性,從語法結構上講這是被允許的,這就需要編譯器在編譯過程處理這種操作,在編譯器看來,外部類和內部類是兩個獨立的類,如果外部類想要訪問內部類的私有屬性,其實是與封裝原則相悖的。那接著看外部類的反編譯結果:

public class com.jd.ryan.test.Pack {
    public com.jd.ryan.test.Pack(); 
        Code:
            0: aload_0
            1: invokespecial #1 //Method java/lang/Object."<init>":()V
    public static void main(java.lang.String[]);
        Code:
            0: new #2           //class com/jd/ryan/test/Pack$Goods
            3: dup
            4: aconst_null
            5: invokespecial #3 //Method com/jd/ryan/test/Pack$Goods."<init>":(Lcom/jd/ryan/test/Pack$1;V
            8: astore_1
            9: getstatic #4     //Field java/lang/System.out:Ljava/io/Printstream;
            12: aload_1
            13: invokestatic #5 //Method com/jd/ryan/test/Pack$Goods.access$100:(Lcom/jd/ryan/test/Pack$Goods.access$100:(Lcom/jd/ryan/test/Pack$Goods;)Ljava/lang/String;
            16: invokevirtual #6//Method java/io/PrintStream.println:(Ljava/lang/String;)V
            19: return
}

在代碼實現中外部類直接打印內部類的name屬性值,來看這行指令:

“Method com/jd/ryan/test/Pack$Goods.access$100:(Lcom/jd/ryan/test/Pack$Goods.access$100:(Lcom/jd/ryan/test/Pack$Goods;)Ljava/lang/String;”

從字節碼中表明是通過調用了內部類的access$100方法,這個方法是一個靜態方法,它可以返回內部類的name屬性,是Goods的私有屬性,所以access$100就是編譯器用來做內部訪問生成的一個合成方法。

編譯器可以通過生成合成屬性和方法來實現一些內部優化或者內部實現,所以在使用反射機制實現一些工具時,在運行時拿到的類屬性信息還可能會有一些未知的屬性或者方法,這就需要工具類的代碼具備一定的健壯性,對獲取到的類屬性進行類型轉換時應該考慮到非業務字段的情況,并且能夠對運行時異常進行捕獲,讓工具聚焦在可以處理的范圍,不能影響正常的業務流程。

(2)JaCoCo原理簡述

JaCoCo利用ASM在字節碼中插入探針指針(Probe指針),每個探針都是一個布爾變量(true表示執行,false表示未執行)。程序運行時通過修改這些指針來檢測代碼的執行情況,而不會改變原始代碼的行為。提到的$jacocoData數組用于保存這些執行結果,JaCoCo根據控制流類型采用不同的探針插入策略,這些探針不會改變方法的行為,只是記錄它們已經執行的事實。

本文不再深入介紹JaCoCo的工作原理,感興趣的同學可以查閱資料。

三、解決方法

理解,首先 MCube 會依據模板緩存狀態判斷是否需要網絡獲取最新模板,當獲取到模板后進行模板加載,加載階段會將產物轉換為視圖樹的結構,轉換完成后將通過表達式引擎解析表達式并取得正確的值,通過事件解析引擎解析用戶自定義事件并完成事件的綁定,完成解析賦值以及事件綁定后進行視圖的渲染,最終將

通過問題分析已經確定是$jacocoData導致的,那就需要在獲取屬性集合的的時對這類屬性進行過濾,實現方法通過isSynthetic()方法區分field屬性類型,isSynthetic是Java中的一個修飾符,用于標記一個類、方法或字段是否由編譯器生成。

List<Field> fieldsList = Arrays.stream(declaredFields)
                               .filter(field -> !field.isSynthetic())
                               .collect(Collectors.toList());

代碼修改后,測試環境添加JaCoCo相關配置,編譯部署發布后可正常下單,從斷點信息來看,$jacocoData已經被過濾掉了。

圖片圖片

四、總結

理解,首先 MCube 會依據模板緩存狀態判斷是否需要網絡獲取最新模板,當獲取到模板后進行模板加載,加載階段會將產物轉換為視圖樹的結構,轉換完成后將通過表達式引擎解析表達式并取得正確的值,通過事件解析引擎解析用戶自定義事件并完成事件的綁定,完成解析賦值以及事件綁定后進行視圖的渲染,最終將

本文主要是記錄一次由于引入JaCoCo后產生運行異常的排查過程,希望會對已使用和準備使用JaCoCo的研發、測試同學有所幫助,同時也希望大家在開發過程中使用反射機制實現工具類或者注解的同學,一定要了解一些編譯器編譯原理,有助于提升代碼的健壯性。

責任編輯:武曉燕 來源: 京東技術
相關推薦

2022-06-15 08:00:50

磁盤RedisRocketMQ

2023-10-31 14:04:17

Rust類型編譯器

2023-11-13 18:36:04

知識抽取NER

2023-04-13 08:40:12

MySQL服務器SELECT

2023-06-07 14:07:00

架構

2024-08-12 08:50:17

2022-04-01 08:48:45

JavaPythonRuby

2022-10-19 08:19:32

動態基線預警

2022-05-31 07:32:19

JDK8API工具

2023-05-29 09:07:10

SQLpageSize主鍵

2023-10-26 08:38:43

SQL排名平分分區

2025-01-06 09:26:49

2023-06-14 08:15:34

算法合并操作Winner

2022-10-24 20:25:40

云原生SpringJava

2024-02-28 08:41:51

Maven沖突版本

2022-03-03 09:20:08

分布式數據庫場景

2022-07-27 08:31:28

SQL開發控制

2024-05-30 08:19:52

微服務架構大型應用

2021-09-16 21:34:52

5G專線

2023-04-04 08:42:30

IT成本技術堆
點贊
收藏

51CTO技術棧公眾號

波多野结衣家庭教师在线| 91久久大香伊蕉在人线| 国产aⅴ激情无码久久久无码| 欧美××××黑人××性爽| 国产精品乱码人人做人人爱| 91香蕉视频在线下载| 一级免费在线观看| 日韩久久精品网| 亚洲国产精品va在线| 日本男人操女人| a级在线观看| 久久久国产午夜精品| 亚洲综合最新在线| 精品黑人一区二区三区| 欧美精品91| 自拍偷拍亚洲一区| 91丝袜在线观看| av成人在线网站| 色综合久久久久综合体| 欧美做受777cos| 岛国大片在线观看| av在线播放一区二区三区| 国产日韩在线看片| 久久亚洲天堂网| 欧美婷婷在线| 操91在线视频| 午夜精品一区二区三级视频| 欧美男同视频网| 亚洲国产精品推荐| 韩国三级丰满少妇高潮| 黄色成人小视频| 91久久国产综合久久| 每日在线更新av| 男人添女人下部高潮视频在线观看 | 99热这里只有精品在线观看| 日韩黄色免费电影| 庆余年2免费日韩剧观看大牛| 精品少妇久久久| 综合视频在线| 精品久久久av| 午夜爽爽爽男女免费观看| 日韩国产一区| 色阁综合伊人av| 中国女人特级毛片| 精品国产一区二区三区久久久蜜臀 | 亚洲宅男天堂在线观看无病毒| 亚洲一二区在线| 黄色av网址在线免费观看| 99久久国产综合精品色伊| yellow视频在线观看一区二区| 国产一区二区三区在线观看| 麻豆精品一区二区av白丝在线| 国产精品日韩在线观看| 加勒比在线一区| 日韩电影在线观看电影| 国产精品国产自产拍高清av水多 | 老鸭窝毛片一区二区三区| 欧美一级大片在线免费观看| 影音先锋亚洲天堂| 亚洲一区一卡| 日本久久久久久久久| 波多野结衣一区二区三区在线| 日韩主播视频在线| 国产欧美精品va在线观看| 国产又大又长又粗| 国产精品18久久久久久久久| 亚洲自拍小视频| 黄色av网址在线| 91丨porny丨首页| 日本一区二区三不卡| av二区在线| 亚洲欧美欧美一区二区三区| 99国产精品白浆在线观看免费| sm在线播放| 91久久一区二区| 中文字幕日韩综合| 精品一区二区三区中文字幕在线| 精品国精品国产| 久久人人妻人人人人妻性色av| 国产传媒欧美日韩成人精品大片| xxxxxxxxx欧美| 国产精品111| 日韩电影在线免费看| 亚洲精品欧美日韩| 天堂成人在线| 中文字幕一区二区三区四区不卡| 国产爆乳无码一区二区麻豆| 午夜伦理福利在线| 欧美精品久久久久久久多人混战 | 青青草国产精品一区二区| 国产精品免费无遮挡无码永久视频| 久久激五月天综合精品| 国产精品三区四区| 91美女视频在线| 亚洲一区二区三区自拍| 国产福利一区视频| 亚洲综合色婷婷在线观看| 日韩精品中文字幕在线播放| 亚洲aaa视频| 激情婷婷久久| 爽好久久久欧美精品| 日韩一区二区免费电影| 亚洲熟妇无码av| 亚洲欧美在线专区| 日本人成精品视频在线| 国产女人爽到高潮a毛片| 99久久伊人精品| 综合视频免费看| 日韩成人av电影| 亚洲高清久久网| 男人与禽猛交狂配| 日韩av一二三| 久久婷婷开心| 里番在线播放| 欧美电影在线免费观看| 黄色aaa视频| 国产在线成人| 91久久精品视频| 91社区在线观看| 欧美性xxxx极品hd欧美风情| 国产精品19p| 欧美wwwww| 国产成人拍精品视频午夜网站| 性色av蜜臀av| 亚洲人妖av一区二区| 日本女优爱爱视频| 香蕉人人精品| …久久精品99久久香蕉国产| www.激情五月| 中文字幕亚洲精品在线观看| 日本女优爱爱视频| 国产一区二区区别| 5566日本婷婷色中文字幕97| 神马午夜在线观看| 亚洲国产视频直播| 成人做爰www看视频软件| 欧美在线免费| 亚洲在线免费视频| 成人在线播放免费观看| 欧美麻豆精品久久久久久| 精品一区二区三区蜜桃在线| 丝袜亚洲另类丝袜在线| 欧美午夜精品理论片a级大开眼界 欧美午夜精品久久久久免费视 | 亚洲国产欧美国产第一区| 日韩中文字幕免费| 国产精品免费无遮挡| 亚洲欧美综合另类在线卡通| 日本77777| 自拍偷拍欧美| 福利视频久久| av电影免费在线看| 亚洲福利视频二区| 国产 欧美 日韩 在线| 99久久久久久99| 欧美日韩中文在线视频| 亚洲精品动态| 国产精品第一页在线| av成人手机在线| 欧美一区二区三区视频在线观看| tube国产麻豆| 不卡的看片网站| 337p粉嫩大胆噜噜噜鲁| 视频一区欧美| 国产噜噜噜噜噜久久久久久久久| 超碰caoporn久久| 亚洲精品在线免费播放| 国产 日韩 欧美 在线| 91蝌蚪porny| 黄色在线视频网| 亚洲一区色图| 极品尤物一区二区三区| 国产亚洲一区二区手机在线观看| www.欧美三级电影.com| 亚洲av无码国产综合专区| 婷婷国产v国产偷v亚洲高清| 波多野吉衣中文字幕| 免费观看在线色综合| av中文字幕av| 欧美男男freegayvideosroom| 国产精品88a∨| 波多野结衣先锋影音| 高清不卡av| 日韩视频第一页| 天堂av中文字幕| 欧美网站一区二区| 久久久久久激情| 欧美激情一区二区三区蜜桃视频 | 国产日韩欧美精品一区| 国产乱码一区二区三区四区| 在线观看一区| 一区二区三区av在线| 成人动漫视频| 国产精品视频导航| √8天堂资源地址中文在线| 国产一区二区三区视频免费| 亚洲av无码一区二区三区性色| 91福利精品第一导航| 欧美三级小视频| 国产情人综合久久777777| 女同性αv亚洲女同志| 日韩精品一二三区| 国产亚洲黄色片| 99久久99久久精品国产片桃花| 精品国产区在线| 欧美久久亚洲| 91啦中文在线观看| 在线亚洲一区二区| 免费在线观看h片| 久久精品亚洲精品国产欧美| 波多野结衣三级视频| 免费一级片91| 日本www在线播放| 欧美三级不卡| aaa免费在线观看| 怕怕欧美视频免费大全| 波多野结衣精品久久| 久久免费资源| 国产成人亚洲综合| 久久青草伊人| 欧美精品电影在线| www.在线视频| 日韩专区在线观看| 国产一区电影| 亚洲欧美在线一区| 亚欧在线观看视频| 亚洲大胆人体av| jizz中国女人| 欧美一区二区视频在线观看| 中文字幕一区二区在线视频| 一本久道中文字幕精品亚洲嫩| 日操夜操天天操| 亚洲综合视频在线| 国产va在线播放| 亚洲乱码国产乱码精品精可以看| www.99re6| 国产精品黄色在线观看| 精品人妻中文无码av在线| 久久精品欧美一区二区三区不卡| 亚洲午夜福利在线观看| 91麻豆文化传媒在线观看| 亚洲av无码一区二区三区网址 | 国内一区在线| 国产精品videossex| 国产精品乱码视频| 99久久免费精品国产72精品九九| 97久久天天综合色天天综合色hd | 精品人人视频| 97在线视频精品| 电影一区二区三| 国产999在线| 欧美aaaaaaaa| 亚洲一区二区三区在线视频| 国产精品一区二区三区四区在线观看| 亚洲在线观看视频网站| 66精品视频在线观看| 国产乱码精品一区二区三区卡| 日韩精品导航| 欧美一区二区三区电影在线观看| 沈樵精品国产成av片| 亚洲精品电影在线一区| 综合一区av| 久久久久免费看黄a片app| 亚洲一区二区成人| 美女一区二区三区视频| 久久 天天综合| 亚洲乱妇老熟女爽到高潮的片| 成人免费高清视频| 亚欧洲乱码视频| 国产精品久久久久7777按摩| 免费国产羞羞网站美图| 自拍偷拍亚洲激情| 亚洲精品午夜久久久久久久| 欧美性高潮在线| 中文字幕在线观看精品| 日韩欧美一区在线| 天堂资源中文在线| 久久精品欧美视频| 97人人爽人人澡人人精品| 国产精品91久久久久久| 成人自拍视频| 久久国产日韩欧美| 色婷婷色综合| 少妇高潮毛片色欲ava片| 日韩影院免费视频| 欧美一级大片免费看| 久久综合色综合88| 污污的视频在线免费观看| 精品久久久久久中文字幕一区奶水| 最好看的日本字幕mv视频大全| 日韩一区二区在线播放| 久久久资源网| 欧美日韩国产成人| 亚洲伦理影院| 国产精品夜夜夜一区二区三区尤| 国产一区二区三区91| 成人黄色片免费| 美女看a上一区| 中文字幕av观看| 一区二区三区中文字幕在线观看| 国产伦精品一区二区三区视频我| 欧美一区二区日韩| 成年人视频网站在线| 久久久久国产精品免费网站| 成人黄色毛片| 欧美激情论坛| 一区在线观看| 亚洲制服中文字幕| 国产女人aaa级久久久级| 激情综合网五月婷婷| 91麻豆精品国产| 成年人视频在线免费观看| 国产69久久精品成人| xvideos.蜜桃一区二区| 在线日韩av永久免费观看| 久久久精品网| 欧美肉大捧一进一出免费视频| 亚洲免费观看高清完整版在线观看 | 丁香婷婷久久| 欧美日韩亚洲一区二区三区四区| 91久久在线| 日本一级大毛片a一| 中文字幕一区免费在线观看| 日韩黄色片网站| 亚洲欧美一区二区三区情侣bbw| 超碰在线网站| 国产v亚洲v天堂无码| 最新国产精品| 欧美日韩精品区别| 国产精品嫩草影院av蜜臀| 51国产偷自视频区视频| 亚洲精品理论电影| 漫画在线观看av| 精品视频免费观看| 亚洲少妇一区| jizz欧美性20| 色呦呦网站一区| 国产小视频福利在线| 国产精品成人国产乱一区 | 亚洲人成毛片在线播放| 牛牛精品一区二区| 欧美极品jizzhd欧美| 六月丁香综合| 99久久99久久精品免费看小说.| 欧美亚洲禁片免费| 日本三级视频在线观看| 国产日韩精品电影| 亚洲影视一区| 亚洲少妇中文字幕| 五月婷婷另类国产| 美女毛片在线看| 国产精品久久久久久久久久新婚| 欧美日韩一二| 中文字幕12页| 亚洲自拍偷拍九九九| 网站黄在线观看| 国产成人激情视频| av资源久久| 91精产国品一二三产区别沈先生| 一区二区三区在线视频播放| 韩国av电影在线观看| 1769国内精品视频在线播放| 国产一区二区三区探花| 欧美男女交配视频| 亚洲欧美二区三区| 少妇荡乳情欲办公室456视频| 欧美在线国产精品| 欧美限制电影| 国产91在线免费观看| 精品久久久在线观看| 国产精品免费观看| 91精品综合视频| 日韩视频二区| 日本在线观看网址| 日韩女优av电影在线观看| 忘忧草在线影院两性视频| 亚洲不卡一卡2卡三卡4卡5卡精品| 日韩成人av影视| 久久精品一级片| 亚洲人成电影在线观看天堂色| 韩国一区二区三区视频| 日本在线xxx| 国产精品嫩草影院com| 秋霞网一区二区| 国产精品无码专区在线观看| 欧美成人首页| a级片在线观看| 日韩三级高清在线| 蜜桃视频成人m3u8| 国产美女永久无遮挡| 欧美激情一区三区| 人人妻人人澡人人爽人人欧美一区| 欧洲一区二区视频| 欧美女激情福利| 超薄肉色丝袜一二三| 精品电影一区二区三区| 国产精品99久久久久久董美香 | 华人av在线| 小说区视频区图片区| 久久综合久久久久88| www.色视频|