日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

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

编程问答

肝一波 ~ 手写一个简易版的Mybatis,带你深入领略它的魅力!

發(fā)布時間:2025/3/21 编程问答 59 豆豆
生活随笔 收集整理的這篇文章主要介紹了 肝一波 ~ 手写一个简易版的Mybatis,带你深入领略它的魅力! 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

零、準備工作

<dependencies><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.20</version></dependency><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.5</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.12</version><scope>provided</scope></dependency> </dependencies>

一、JDBC的復雜

1、概述

惡心的一批,缺點賊多

  • 我就是為了執(zhí)行一個SQL,結果需要寫一堆亂七八糟的垃圾玩意,比如?Class.forName、DriverManager.getConnection、connection.createStatement?等,惡心不?

  • 執(zhí)行完SQL,我們需要resultSet.getXxx(int num)來手動封裝到我們的entity對象里,惡心不?

  • SQL直接強耦合到業(yè)務代碼里,修改和閱讀都極其惡心。

2、代碼

來一段JDBC代碼看看。

package?com.chentongwei.study.jdbc;import?com.chentongwei.study.entity.User;import?java.sql.*; import?java.util.ArrayList; import?java.util.List;/***?真~~惡心!!!*/ public?class?JdbcDemo?{public?static?void?main(?String[]?args?)?{try?{Class.forName("com.mysql.cj.jdbc.Driver");}?catch?(ClassNotFoundException?e)?{e.printStackTrace();}Connection?connection?=?null;Statement?statement?=?null;ResultSet?resultSet?=?null;try?{connection?=?DriverManager.getConnection("xxx");statement?=?connection.createStatement();//?只有這一句是重點,其他都是垃圾!!!//?只有這一句是重點,其他都是垃圾!!!//?只有這一句是重點,其他都是垃圾!!!resultSet?=?statement.executeQuery("SELECT?*?FROM?user");List<User>?userList?=?new?ArrayList<>();while?(resultSet.next())?{int?id?=?resultSet.getInt(1);String?name?=?resultSet.getString(2);int?age?=?resultSet.getInt(3);userList.add(new?User(id,?name,?age));}}?catch?(SQLException?e)?{e.printStackTrace();}?finally?{if?(null?!=?resultSet)?{try?{resultSet.close();}?catch?(SQLException?e)?{e.printStackTrace();}}if?(null?!=?statement)?{try?{statement.close();}?catch?(SQLException?e)?{e.printStackTrace();}}if?(null?!=?connection)?{try?{connection.close();}?catch?(SQLException?e)?{e.printStackTrace();}}}} } /***?Description:*?<p>*?Project?mybatis-source-study**?@author?TongWei.Chen?2020-06-06?17:12:07*/ @Data @NoArgsConstructor @AllArgsConstructor public?class?User?{private?Integer?id;private?String?name;private?Integer?age; }

二、Mybatis的威力

1、概述

他是一個半ORM的框架,為什么是半?因為它支持你直接用它封裝好的selectOne等這些玩意,它也支持手寫SQL,比Hibernate的絕大優(yōu)勢就是上手簡單、半ORM,沒錯,這種半ORM卻成為了它的優(yōu)點之一。

這樣我們手寫的SQL想怎么優(yōu)化就怎么優(yōu)化,不香嗎?

mybatis優(yōu)勢(其實也是大多數(shù)ORM框架的優(yōu)勢)

  • 你寫你的SQL就完事了,什么?Class.forName?等垃圾代碼都沒了,但是會額外增加其他幾段代碼,但是如果你用了Spring-Mybatis的話那你直接寫你的SQL就完事了,沒其他花里胡哨的東西,都給你封裝了。

  • 沒有?resultSet.getXxx(int num)?這種惡心的代碼,他自動給我們映射了,可以猜測到他內(nèi)部有組件為我們將返回的ResultSet封裝到了對應的entity里。

  • SQL寫到mapper或者接口的方法注解上,不會摻雜到業(yè)務代碼里。

2、手寫一個Mybatis

2.1說明

為了更好的表達Mybatis的底層原理,這里手寫一個簡易版的mybatis來證明它的核心源碼。這里只演示注解式的(比如@Select),不寫mapper文件了。

2.2、思路

  • 得有個interface(也就是Mapper/DAO接口層)

  • jdk動態(tài)代理為interface產(chǎn)生具體實現(xiàn)

  • 具體實現(xiàn)里肯定要獲取@Select注解里的SQL

  • 然后獲取方法參數(shù)值

  • SQL里的參數(shù)都是?#{xxx}?格式,所以我們要有解析方法參數(shù)的方法,比如找到?#{?和?}?的位置,然后把這段內(nèi)容替換成具體的參數(shù)值

  • 得到完整的SQL(拼好參數(shù)值的)

  • 執(zhí)行SQL

  • 解析結果集到entity上

2.3、實現(xiàn)

2.3.1、interface

package?com.chentongwei.mybatis;import?com.chentongwei.study.entity.User; import?org.apache.ibatis.annotations.Param; import?org.apache.ibatis.annotations.Select;import?java.util.List;/***?Description:*?<p>*?Project?mybatis-source-study**?@author?TongWei.Chen?2020-06-06?17:32:52*/ public?interface?UserMapper?{@Select("SELECT?*?FROM?user?WHERE?id?=?#{id}?AND?name?=?#{name}")List<User>?listUser(@Param("id")?Integer?id,?@Param("name")?String?name); }

2.3.2、jdk動態(tài)代理

public?static?void?main(String[]?args)?{//?jdk動態(tài)代理,代理UserMapper接口UserMapper?userMapper?=?(UserMapper)?Proxy.newProxyInstance(MybatisDemo.class.getClassLoader(),?new?Class[]{UserMapper.class},?new?InvocationHandler()?{@Overridepublic?Object?invoke(Object?proxy,?Method?method,?Object[]?args)?throws?Throwable?{//?獲取@Select注解,Select?annotation?=?method.getAnnotation(Select.class);//?獲取參數(shù),以key-value的形式放到map里,比如map.put("id",?1);?map.put("name",?"test");Map<String,?Object>?argsMap?=?buildMethodArgsMap(method,?args);if?(null?!=?annotation)?{//?獲取SQL:SELECT * FROM user WHERE id =?#{id} AND name =?#{name}String[]?values?=?annotation.value();//?1個select注解只能有一個sql,所以直-接values[0]String?sql?=?values[0];//?sql:?SELECT?*?FROM?user?WHERE?id?=?#{id}?AND?name?=?#{name}System.out.println("sql:?"? ?sql);//?將SQL的#{xxx}部分替換成真實的value得到完整的SQL語句sql?=?parseSQL(sql,?argsMap);System.out.println("parseSQL:?"? ?sql);//?如下部分省略了,SQL都得到了,下面就jdbc執(zhí)行,封裝就完事了。//?jdbc執(zhí)行//?ResultSet得到結果集反射到entity里,反射有方法可以得到返回值類型和返回值泛型的,比如List、泛型是User?}return?null;}});userMapper.listUser(1,?"test"); }

這個方法是描述了所有流程:

1.動態(tài)代理UserMapper接口

2.代理類執(zhí)行l(wèi)istUser方法,參數(shù)是1,test

3.獲取listUser方法上的@Select注解

4.獲取@Select注解上的值,也就是SQL語句

5.獲取listUser方法的兩個參數(shù)值,1和test,且存到map里,格式是

?Map<String,?Object>?argsMap?=?new?HashMap<>();argsMap.put("id",?1);argsMap.put("name",?"test");

6.將SQL的#{xxx}部分替換成真實的value得到完整的SQL語句

SELECT?*?FROM?user?WHERE?id?=?1?AND?name?=?test`

7.jdbc執(zhí)行SQL

8.ResultSet得到結果集反射到entity里

2.3.3、buildMethodArgsMap

public?static?Map<String,?Object>?buildMethodArgsMap(Method?method,?Object[]?args)?{//?最終參數(shù)-參數(shù)值都放到這里Map<String,?Object>?argsMap?=?new?HashMap<>();//?獲取listUser的所有參數(shù)Parameter[]?parameters?=?method.getParameters();if?(parameters.length?!=?args.length)?{throw?new?RuntimeException("參數(shù)個數(shù)不一致呀,兄弟");}//?別問我為什么這么寫,因為java8的foreach語法要求內(nèi)部用外部的變量必須final類型,final就沒法 ?操作,所以用數(shù)組來玩騷套路int[]?index?=?{0};Arrays.asList(parameters).forEach(parameter?->?{//?獲取每一個參數(shù)的@Param注解,里面的值就是參數(shù)keyParam?paramAnno?=?parameter.getAnnotation(Param.class);//?獲取參數(shù)值:id和nameString?name?=?paramAnno.value();System.out.println(name);//?將參數(shù)值放到最終的map里。id:1、name:testargsMap.put(name,?args[index[0]]);index[0]? ?;});return?argsMap; }

最終目的就是返回參數(shù)map。

1.獲取listUser方法的所有參數(shù)

2.獲取每個參數(shù)的@Param注解的值,這個值就是map里的key

3.獲取傳進來的args[i]作為value

4.將key-value放到map

2.3.4、parseSQL

/*** sql:SELECT * FROM user WHERE id =?#{id} AND name =?#{name}* argsMap:Map<String,?Object>?argsMap?=?new?HashMap<>();argsMap.put("id",?1);argsMap.put("name",?"test");*/ public?static?String?parseSQL(String?sql,?Map<String,?Object>?argsMap)?{StringBuilder?sqlBuilder?=?new?StringBuilder();//?遍歷sql的每一個字母,判斷是不是#開頭,是的話找到#{,然后請求parseSQLArg方法填充參數(shù)值(1,test)for?(int?i?=?0;?i?<?sql.length();?i ?)?{char?c?=?sql.charAt(i);if?(c?==?'#')?{//?找到#的下一個位置,判斷是不是{int?nextIndex?=?i? ?1;char?nextChar?=?sql.charAt(nextIndex);//?如果#后面不是{,則語法報錯if?(nextChar?!=?'{')?{throw?new?RuntimeException(String.format("這里應該是#{\nsql:%s\nindex:%d",?sqlBuilder.toString(),?nextIndex));}StringBuilder?argsStringBuilder?=?new?StringBuilder();//?將#{xxx}換成具體的參數(shù)值,找到}的位置,且將xxx放到argsStringBuilder里i?=?parseSQLArg(argsStringBuilder,?sql,?nextIndex);String?argName?=?argsStringBuilder.toString();//?獲取xxx對應的value,填充到SQL里。Object?argValue?=?argsMap.get(argName);if?(null?==?argValue)?{throw?new?RuntimeException(String.format("找不到參數(shù)值:%s",?argName));}//?將參數(shù)值放到SQL對應的#{xxx}里sqlBuilder.append(argValue.toString());continue;}sqlBuilder.append(c);}return?sqlBuilder.toString(); }

主要就干了下面這件事:

將SELECT * FROM user WHERE id = #{id} AND name = #{name}換成

SELECT * FROM user WHERE id = 1 AND name = test

但是需要下面的parseSQLArg來進行解析參數(shù),找到#{xxx}中}的位置。

2.3.5、parseSQLArg

/*** argsStringBuilder:放的是key值,比如"id"、"name"* sql:SELECT * FROM user WHERE id =?#{id} AND name =?#{name}* nextIndex:目前位置是"#{"這個位置。*/ private?static?int?parseSQLArg(StringBuilder?argsStringBuilder,?String?sql,?int?nextIndex)?{//?為啥 ?一次,因為現(xiàn)在nextIndex指向的是{,所以要 1找到{的下一位nextIndex? ?;//?逐個解析SQL的每個字母,判斷是不是"}"for?(;?nextIndex?<?sql.length();?nextIndex? ?)?{char?c?=?sql.charAt(nextIndex);//?如果不是},那么放到argsStringBuilder里,argsStringBuilder放的是key值,比如"id"、"name"if?(c?!=?'}')?{argsStringBuilder.append(c);continue;}//?如果找到了}的位置,則代表argsStringBuilder里已經(jīng)有完整的key了,比如id或者name。因為}是在key后面的。則返回}的位置if?(c?==?'}')?{return?nextIndex;}}//?如果都沒找到"}",那明顯語法錯誤,因為這個方法的調(diào)用者是有“#{”開頭的,然后你這里沒結束“}”,exception就完事了throw?new?RuntimeException(String.format("語法不對,缺少右括號('{')\nindex:%d",?nextIndex)); }

找到參數(shù)key值放到argsStringBuilder里且找到}的位置inextIndex并返回。

解析SQL里的每個char字母,不是}的話就放到argsStringBuilder里,比如現(xiàn)在位置是{,那么nextIndex ?就是id的i,然后append到argsStringBuilder里,continue,在for,這時候id的d,再append到argsStringBuilder里,以此類推,找到}后就return位置。

2.3.6、完整代碼

package?com.chentongwei.mybatis;import?org.apache.ibatis.annotations.Param; import?org.apache.ibatis.annotations.Select;import?java.lang.reflect.InvocationHandler; import?java.lang.reflect.Method; import?java.lang.reflect.Parameter; import?java.lang.reflect.Proxy; import?java.util.Arrays; import?java.util.HashMap; import?java.util.Map;/***?Description:*?<p>*?Project?mybatis-source-study**?@author?TongWei.Chen?2020-06-06?17:33:01*/ public?class?MybatisDemo?{public?static?void?main(String[]?args)?{UserMapper?userMapper?=?(UserMapper)?Proxy.newProxyInstance(MybatisDemo.class.getClassLoader(),?new?Class[]{UserMapper.class},?new?InvocationHandler()?{@Overridepublic?Object?invoke(Object?proxy,?Method?method,?Object[]?args)?throws?Throwable?{System.out.println("代理類生效了,方法名:"? ?method.getName()? ?", 參數(shù)是:"? ?Arrays.toString(args));Select?annotation?=?method.getAnnotation(Select.class);Map<String,?Object>?argsMap?=?buildMethodArgsMap(method,?args);if?(null?!=?annotation)?{String[]?values?=?annotation.value();//?1個select注解只能有一個sql,所以直接values[0]String?sql?=?values[0];System.out.println("sql:?"? ?sql);sql?=?parseSQL(sql,?argsMap);System.out.println("parseSQL:?"? ?sql);}return?null;}});userMapper.listUser(1,?"test");}public?static?String?parseSQL(String?sql,?Map<String,?Object>?argsMap)?{StringBuilder?sqlBuilder?=?new?StringBuilder();for?(int?i?=?0;?i?<?sql.length();?i ?)?{char?c?=?sql.charAt(i);if?(c?==?'#')?{//?找到#的下一個位置,判斷是不是{int?nextIndex?=?i? ?1;char?nextChar?=?sql.charAt(nextIndex);if?(nextChar?!=?'{')?{throw?new?RuntimeException(String.format("這里應該是#{\nsql:%s\nindex:%d",?sqlBuilder.toString(),?nextIndex));}StringBuilder?argsStringBuilder?=?new?StringBuilder();i?=?parseSQLArg(argsStringBuilder,?sql,?nextIndex);String?argName?=?argsStringBuilder.toString();Object?argValue?=?argsMap.get(argName);if?(null?==?argValue)?{throw?new?RuntimeException(String.format("找不到參數(shù)值:%s",?argName));}sqlBuilder.append(argValue.toString());continue;}sqlBuilder.append(c);}return?sqlBuilder.toString();}private?static?int?parseSQLArg(StringBuilder?argsStringBuilder,?String?sql,?int?nextIndex)?{//?為啥 ?一次,因為現(xiàn)在nextIndex指向的是{,所以要 1找到{的下一位nextIndex? ?;for?(;?nextIndex?<?sql.length();?nextIndex? ?)?{char?c?=?sql.charAt(nextIndex);if?(c?!=?'}')?{argsStringBuilder.append(c);continue;}if?(c?==?'}')?{return?nextIndex;}}throw?new?RuntimeException(String.format("語法不對,缺少右括號('{')\nindex:%d",?nextIndex));}public?static?Map<String,?Object>?buildMethodArgsMap(Method?method,?Object[]?args)?{Map<String,?Object>?argsMap?=?new?HashMap<>();Parameter[]?parameters?=?method.getParameters();if?(parameters.length?!=?args.length)?{throw?new?RuntimeException("參數(shù)個數(shù)不一致呀,兄弟");}int[]?index?=?{0};Arrays.asList(parameters).forEach(parameter?->?{Param?paramAnno?=?parameter.getAnnotation(Param.class);String?name?=?paramAnno.value();System.out.println(name);argsMap.put(name,?args[index[0]]);index[0]? ?;});return?argsMap;} }

2.3.7、測試

上面完整代碼的測試結果如下:

代理類生效了,方法名:listUser, 參數(shù)是:[1,?test] id name sql:?SELECT?*?FROM?user?WHERE?id?=?#{id}?AND?name?=?#{name} parseSQL:?SELECT?*?FROM?user?WHERE?id?=?1?AND?name?=?test

很明顯發(fā)現(xiàn)我們完美的得到了想要的SQL,接下來jdbc,解析ResultSet就完事了。這里沒涉及。

我們故意寫錯SQL,去掉#后面的{,再看效果

修改UserMapper接口的listUser方法為如下

public?interface?UserMapper?{@Select("SELECT?*?FROM?user?WHERE?id?=?#id}?AND?name?=?#{name}")List<User>?listUser(@Param("id")?Integer?id,?@Param("name")?String?name); }

輸出結果直接報錯了

Exception?in?thread?"main"?java.lang.RuntimeException:?這里應該是#{ sql:SELECT?*?FROM?user?WHERE?id?=? index:31at?com.chentongwei.mybatis.MybatisDemo.parseSQL(MybatisDemo.java:54)at?com.chentongwei.mybatis.MybatisDemo$1.invoke(MybatisDemo.java:34)at?com.sun.proxy.$Proxy0.listUser(Unknown?Source)at?com.chentongwei.mybatis.MybatisDemo.main(MybatisDemo.java:41)

再次寫錯SQL,將@Param里的參數(shù)名和SQL的參數(shù)名寫的不一致,看效果:

public?interface?UserMapper?{@Select("SELECT?*?FROM?user?WHERE?id?=?#{id}?AND?name?=?#{name}")List<User>?listUser(@Param("id")?Integer?id,?@Param("name1")?String?name); } Exception?in?thread?"main"?java.lang.RuntimeException:?找不到參數(shù)值:nameat?com.chentongwei.mybatis.MybatisDemo.parseSQL(MybatisDemo.java:62)at?com.chentongwei.mybatis.MybatisDemo$1.invoke(MybatisDemo.java:34)at?com.sun.proxy.$Proxy0.listUser(Unknown?Source)at?com.chentongwei.mybatis.MybatisDemo.main(MybatisDemo.java:41)S

3、總結

  • mybatis底層源碼肯定比這優(yōu)化的很多,各種解析組件,不是for每個SQL的字符去拼接

  • 實際mybatis底層有自己封裝好的異常,而不是直接RuntimeException

  • 這里僅僅是為了演示原理,所以不涉及到JDBC執(zhí)行、映射ResultSet到entity等

?三、幾張圖

實際mybatis源碼寫的很棒,各個組件封裝的很好,也很清晰,代友攔截器功能使之可插拔。

下面這個是比較詳細的mybatis核心組件圖

mybatis源碼包也見名知意

《新程序員》:云原生和全面數(shù)字化實踐50位技術專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的肝一波 ~ 手写一个简易版的Mybatis,带你深入领略它的魅力!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

成片免费观看视频 | 69视频在线| 女人18毛片a级毛片一区二区 | 四虎国产视频 | 日韩一级黄色片 | 欧美日本高清视频 | 国产一级性生活 | 深夜福利视频在线观看 | 久久伊人综合 | 精品一区二区免费在线观看 | 亚洲日本激情 | 亚洲精品午夜国产va久久成人 | 岛国一区在线 | 69国产盗摄一区二区三区五区 | 五月天久久综合网 | 在线观看日本韩国电影 | 99色在线观看 | 久草电影网 | 国产精品一区久久久久 | 国产成人综合图片 | 国产亚洲欧美一区 | 91麻豆精品国产91久久久更新时间 | 色99在线 | 国产精品免费观看视频 | 91看片淫黄大片在线播放 | 久久午夜国产精品 | 国产福利精品一区二区 | 奇米影视四色8888 | 日韩首页 | 亚洲综合五月 | 国产在线精品播放 | 探花视频在线观看 | 成年人视频在线免费播放 | 精品一区二三区 | 日本婷婷色 | 欧美一区二区三区在线视频观看 | 成人超碰在线 | 国产九色视频在线观看 | 日韩精品在线免费观看 | 在线观看免费一级片 | 中文字幕 在线 一 二 | 国产日产精品一区二区三区四区的观看方式 | 日韩在线视频免费看 | 激情欧美一区二区三区 | 国产精品久久久久久婷婷天堂 | 久久婷亚洲五月一区天天躁 | 91亚色视频 | 九九热免费观看 | 色婷婷成人网 | 亚洲综合成人专区片 | 日韩色区 | 久久九九国产精品 | 狠狠色狠狠色综合系列 | 日日干精品 | 欧美极品少妇xbxb性爽爽视频 | 国产三级香港三韩国三级 | www.精选视频.com | 日韩高清在线观看 | 成人aaa毛片| 伊人中文在线 | 尤物九九久久国产精品的分类 | 国产资源在线视频 | 免费看国产视频 | 天天曰天天 | 日日夜夜操操操操 | 久草精品免费 | 在线观看视频在线观看 | 婷婷日 | 女人18毛片a级毛片一区二区 | 亚洲激情一区二区三区 | 午夜国产福利在线 | 亚洲成av人影院 | 天天色图 | 日韩a在线观看 | 久久国产色 | 色综合婷婷 | 欧洲成人av| 色99中文字幕 | 91久久在线观看 | 精品一区二区精品 | 色综合咪咪久久网 | 激情大尺度视频 | 91传媒免费观看 | 久草视频在线观 | 欧美成年网站 | 久久激情久久 | 黄色av成人在线 | 国产老妇av| 日韩中文字幕免费视频 | 999久久久久久久久 69av视频在线观看 | 日本在线观看一区二区三区 | 中文字幕在线观看免费高清完整版 | 亚洲综合色网站 | 一区二区三区www | 99人久久精品视频最新地址 | 99九九99九九九视频精品 | 欧美日韩视频在线观看一区二区 | 99久久久国产精品免费观看 | 欧美久久99| 日韩久久久久久 | 成人一区二区三区在线 | 国产香蕉97碰碰碰视频在线观看 | 草久视频在线 | 亚洲欧美在线视频免费 | 中文字幕人成乱码在线观看 | japanesexxx乱女另类 | 亚洲精品中文字幕视频 | 国产精品伦一区二区三区视频 | 亚洲精选视频免费看 | 91丨九色丨国产女 | 国产精品理论视频 | 91成人免费在线视频 | 一区二区三区久久精品 | av成人在线看 | 国产一级免费观看 | 狠狠综合网 | 黄色成人影视 | 黄色大片视频网站 | 国产伦理剧 | 久久久久久国产一区二区三区 | 亚洲在线高清 | 免费观看特级毛片 | 免费看日韩 | 四虎在线视频免费观看 | 欧美视频不卡 | 麻豆影视在线免费观看 | 久久久久网址 | 久艹视频在线免费观看 | 欧美日在线观看 | 久久久久 免费视频 | 激情五月五月婷婷 | 蜜桃麻豆www久久囤产精品 | 欧美日本不卡 | 免费观看91视频 | 国产护士在线 | 99国产一区| 国产午夜精品福利视频 | 涩涩网站在线播放 | 中文字幕av免费在线观看 | 久草在线观看视频免费 | 久久成人久久 | 国产精品久久久久久久久久久杏吧 | 国产日本在线 | 国产精品综合久久久久久 | 久久综合免费视频 | 一级一片免费视频 | 一区二区欧美日韩 | 日韩1级片 | 在线观看完整版 | 国产亚洲精品成人av久久影院 | 国产成人三级 | 丁香5月婷婷| 色视频网站在线观看一=区 a视频免费在线观看 | 国产精品2区 | 欧美日韩亚洲第一 | 丁香婷婷综合激情五月色 | 91香蕉视频 | 婷婷五综合| 国产精品国产三级国产专区53 | 色综合天天天天做夜夜夜夜做 | 国产人免费人成免费视频 | 久久综合成人 | 97超碰人人模人人人爽人人爱 | 午夜av在线免费 | 美女免费网视频 | 亚洲成人黄色 | av天天澡天天爽天天av | 在线观看视频免费大全 | 黄色一级性片 | 国产一级黄 | 久久社区视频 | 日韩电影在线观看一区二区三区 | 亚洲国产三级 | 黄色字幕网 | 日韩手机在线观看 | 色婷婷狠狠五月综合天色拍 | 天天插天天爱 | 亚洲精品女人久久久 | 亚洲免费av在线播放 | 精品伊人久久久 | 18岁免费看片 | 丁香色婷婷| av黄色免费看 | 日日夜夜狠狠干 | 亚洲女人天堂成人av在线 | 操操操夜夜操 | 美女视频黄是免费的 | 性色xxxxhd| 精品一区二区免费 | 久草在线观看资源 | 亚洲国产高清在线观看视频 | 中文字幕一区二区三区在线播放 | 亚洲精品 在线视频 | 香蕉视频免费在线播放 | 日日爱av | 黄色毛片网站在线观看 | 亚洲第一伊人 | 亚洲在线a | 久久综合影视 | 999视频在线播放 | 91.dizhi永久地址最新 | 五月天亚洲婷婷 | 午夜婷婷在线观看 | 人人操日日干 | 日韩有码专区 | 国产99在线免费 | 国产精品成人一区二区三区 | 色天天| 探花视频在线观看免费 | 精品欧美在线视频 | 中文字幕在线观看免费观看 | 成人一级视频在线观看 | 最近最新中文字幕 | 亚洲欧美日韩不卡 | 在线观看国产中文字幕 | 欧美一区中文字幕 | 国产在线视频资源 | 欧美高清成人 | 国产尤物在线 | 久久免费电影 | 免费日韩电影 | 美女视频黄的免费的 | 亚洲综合婷婷 | 中文字幕第一页在线视频 | 午夜精品99久久免费 | 国产精品综合久久久久 | 99热这里只有精品在线观看 | 深爱激情五月综合 | 玖玖综合网| av亚洲产国偷v产偷v自拍小说 | 欧美一区影院 | 久久国产免费视频 | 欧美一区日韩一区 | 成人av片免费观看app下载 | 欧美专区日韩专区 | 日本3级在线观看 | 综合色综合 | 国产精品第54页 | 婷婷色在线资源 | 美女国产在线 | 国产一级在线观看视频 | 久久国内免费视频 | 国产二区视频在线观看 | 成人国产精品久久久春色 | 九色精品免费永久在线 | 久久夜夜操| 久久丁香 | 中文一二区 | 亚洲aⅴ乱码精品成人区 | 精品视频国产一区 | 久久人人射 | 色综合网在线 | 91麻豆.com| 日本精品一区二区三区在线播放视频 | 国产短视频在线播放 | 精品产品国产在线不卡 | 欧美日韩18| 一级欧美黄 | 亚洲精选国产 | 天天操天天干天天操天天干 | 国产黄色免费观看 | 久久国产精品二国产精品中国洋人 | 久久精品观看 | 91香蕉嫩草 | 久久伊人五月天 | 伊人色综合久久天天网 | 在线视频日韩欧美 | 精品 一区 在线 | 久久天天躁狠狠躁亚洲综合公司 | 色综合久久综合中文综合网 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 97在线观看免费 | 天天综合网入口 | 欧美二区视频 | 国产一区二区高清 | 免费亚洲成人 | 91av手机在线观看 | 中文字幕电影网 | 五月开心激情网 | 婷婷六月天在线 | 在线观看 亚洲 | 99人久久精品视频最新地址 | 2023国产精品自产拍在线观看 | 九九九国产| 久久国产热视频 | .国产精品成人自产拍在线观看6 | 四虎影视成人精品国库在线观看 | 在线草 | 久久电影国产免费久久电影 | 国产精品黑丝在线观看 | 射久久久 | 亚洲六月丁香色婷婷综合久久 | 日韩一区二区三区高清免费看看 | 日韩av影视在线观看 | 在线播放一区二区三区 | 欧美中文字幕第一页 | 97日日碰人人模人人澡分享吧 | 日韩av免费在线电影 | 五月婷婷网站 | 欧美黑人性爽 | 开心色插 | 色视频网站免费观看 | 中文字幕第一页在线播放 | 欧美日韩一区三区 | 男女日麻批| 91九色视频网站 | 97视频久久久 | 日韩久久精品一区二区三区下载 | 日本高清中文字幕有码在线 | 国产涩涩在线观看 | 天天做天天射 | 五月天激情视频 | 亚洲人人av | 亚洲五月综合 | 久久精品视频在线 | 九九有精品 | 亚洲女同ⅹxx女同tv | www.com.日本一级| 黄色av免费电影 | 精品欧美一区二区在线观看 | 西西4444www大胆视频 | 久久人人爽人人爽 | 亚洲免费成人av电影 | 国产视频一区在线播放 | 97视频在线 | 91成人在线观看喷潮 | 在线成人欧美 | 在线观看免费高清视频大全追剧 | 三级av中文字幕 | 69久久久久久久 | 国产午夜在线 | 久草在线手机视频 | 日韩久久精品 | 久久99在线 | 91九色最新地址 | 手机色站 | 欧美性久久久久久 | 国产亚洲欧美精品久久久久久 | 91桃色在线观看视频 | 中文字幕一区av | 在线国产能看的 | 美女免费视频黄 | 人人草网站| 黄色亚洲大片免费在线观看 | 成年人免费电影在线观看 | 91精品专区 | 久久精品国产一区二区三区 | 中文字幕 国产视频 | 日日干夜夜爱 | 久久久久久黄色 | 久草国产精品 | 日韩亚洲国产中文字幕 | 欧美做受高潮电影o | 国产精品 日韩 | 国产高清专区 | 97人人模人人爽人人喊网 | 色综合色综合色综合 | 中文字幕成人在线观看 | 97在线观| 毛片网站观看 | 九九天堂 | 啪啪肉肉污av国网站 | 亚洲成人第一区 | 国产精品视频永久免费播放 | 一区二区三区在线看 | 视频国产一区二区三区 | 久久婷婷一区 | 成人亚洲精品国产www | 99久久久久免费精品国产 | a天堂最新版中文在线地址 久久99久久精品国产 | 免费网站看v片在线a | 99视频在线观看一区三区 | 国产精品h在线观看 | 国产一区高清在线观看 | 久久免费看av | 久久久精品福利视频 | 欧美资源在线观看 | 91大神免费在线观看 | 国产专区第一页 | 网站免费黄| 日韩丝袜 | 日韩在线视频国产 | 中文字幕一区在线观看视频 | 久久免费视频在线观看6 | 在线观看久草 | 在线观看国产v片 | 国产精品第一页在线 | 中文字幕2021| 日韩精品久久久久 | 国产亚洲精品久久久久动 | 国产黄色av| 日韩成人精品在线观看 | 国产亚洲91| 婷婷色在线视频 | 激情伊人 | 亚洲精品视频网站在线观看 | 97人人添人澡人人爽超碰动图 | 一级黄色av | 国产精品久久久久久久午夜 | 久久午夜电影 | 久久国产高清视频 | 日日干,天天干 | 草免费视频 | 成 人 黄 色 片 在线播放 | 又黄又爽又无遮挡的视频 | 久草在线观看视频免费 | 国产日产在线观看 | 欧美一区二区精品在线 | 成年免费在线视频 | 精品综合久久久 | 久久黄色小说视频 | 在线看国产精品 | 国产精品女同一区二区三区久久夜 | 国产视频一区在线播放 | 正在播放国产91 | 九九免费在线观看视频 | 久久国精品 | 精品久久久久久亚洲综合网站 | 亚洲在线视频免费 | 精壮的侍卫呻吟h | 91麻豆精品一区二区三区 | 五月婷婷在线视频观看 | 精品国产乱码久久久久久1区二区 | 亚洲精品婷婷 | 国产精成人品免费观看 | 亚洲免费精品视频 | va视频在线观看 | 91在线国产观看 | 91丨九色丨蝌蚪丨对白 | 综合婷婷 | 色综合久久88色综合天天 | 欧美日韩久久不卡 | 综合色爱 | 色在线高清 | 色综合久久88色综合天天免费 | 人人干狠狠操 | 国产成人一区二区三区 | 一区二区三区在线免费观看 | 成人免费视频视频在线观看 免费 | 日韩一级网站 | 久久av一区二区三区亚洲 | 中文字幕免费一区 | 久久精品亚洲精品国产欧美 | 精品久久久久国产免费第一页 | 欧美日韩不卡一区二区三区 | av片免费播放 | 久久成人欧美 | 久久福利国产 | 91丨九色丨蝌蚪丨对白 | 欧美午夜精品久久久久久孕妇 | 中文国产成人精品久久一 | 在线中文字幕视频 | 日韩精品资源 | 久精品视频在线 | 中文字幕国内精品 | 精品一区二区久久久久久久网站 | 黄色资源在线观看 | 波多野结衣在线视频免费观看 | 欧美a级免费视频 | 中文字幕精品一区久久久久 | 免费看特级毛片 | 丁香狠狠 | 在线播放 日韩专区 | 99久久精品免费看国产免费软件 | 五月天激情婷婷 | 东方av在 | 精品国产99| 美女黄频免费 | 久久婷婷一区二区三区 | 欧美日韩一区二区三区在线免费观看 | 久久久亚洲网站 | 香蕉影视在线观看 | 在线免费观看黄色 | 91视频在线观看大全 | 日韩av不卡在线 | 久久你懂得 | 97在线看片 | 在线电影 一区 | 亚洲综合在线五月 | 国产高清av免费在线观看 | 中文字幕视频免费观看 | 97超碰色 | 蜜臀av一区 | av黄色影院 | 日韩精品视频免费专区在线播放 | 日韩欧美第二页 | 久久久久9999亚洲精品 | 亚洲一级片 | 久久免费国产视频 | 国产高清在线免费视频 | 日韩a在线播放 | 亚洲精品久久久久久久不卡四虎 | 久久久香蕉视频 | 97免费在线观看视频 | 欧美不卡在线 | 亚洲不卡在线 | 黄在线| 色成人亚洲 | 成人黄色在线电影 | 国产精品久久久久久久午夜片 | 久久久久欠精品国产毛片国产毛生 | 青青草国产精品视频 | 9999免费视频 | 人人爽夜夜爽 | 久久久久久久久爱 | 中文字幕在线观看三区 | 亚洲精品女人久久久 | av网站大全免费 | 中文字幕丰满人伦在线 | 婷婷激情久久 | 色婷五月天 | 在线视频一区观看 | 亚洲免费精彩视频 | 欧美成人精品欧美一级乱黄 | 午夜精品视频福利 | 久久综合偷偷噜噜噜色 | 中文字幕中文字幕在线中文字幕三区 | 精品国产不卡 | 欧美日韩国产在线 | 欧美日韩三级 | 国产午夜精品久久久久久久久久 | 亚洲精品在线一区二区 | 久久69精品久久久久久久电影好 | 色网免费观看 | av在线网站观看 | www操操操 | 久草免费福利在线观看 | 国产69精品久久久久久 | 免费www视频 | 五月婷婷开心 | 中文字幕久久网 | 日日干干夜夜 | 久久高清av | 国产999| 人人爽人人爽人人爽人人爽 | 韩国一区二区三区在线观看 | 黄色大片视频网站 | 在线中文字幕一区二区 | 国产精品大片在线观看 | 国产精品久久影院 | 国产免费av一区二区三区 | 日韩 精品 一区 国产 麻豆 | 国产成人精品一区二区在线观看 | 日韩字幕在线观看 | 久久精品视频免费观看 | 精品视频在线观看 | 992tv在线观看网站 | 成人h电影在线观看 | 99精品国产福利在线观看免费 | 精品国产伦一区二区三区观看体验 | 免费成人在线观看视频 | 久久久久北条麻妃免费看 | 日韩在线视频在线观看 | 国产玖玖视频 | 精品毛片在线 | 国产国产人免费人成免费视频 | 国产高清视频在线 | 久久久91精品国产一区二区精品 | 久久久综合精品 | 三级视频片 | 91在线小视频 | 欧美专区日韩专区 | 国产日韩视频在线观看 | www.香蕉| 五月丁色 | 伊人丁香 | 国产精品毛片一区二区 | 91视频在线观看下载 | 国产91精品看黄网站在线观看动漫 | 国产精品久久久久久久久久直播 | freejavvideo日本免费 | 国产精品一区二区三区观看 | 在线观看视频国产 | 日日夜夜精品视频 | 久久久久综合精品福利啪啪 | 国际av在线| 国产精品乱码一区二区视频 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 国产精品一区二区三区电影 | 69国产精品视频 | 欧美日韩国产在线一区 | 天天干夜夜夜操天 | 不卡av免费在线观看 | 中文字幕免费观看 | 久久综合视频网 | 日日夜夜天天综合 | 天天夜夜亚洲 | 亚洲少妇自拍 | 亚洲激情p| 99国产视频在线 | 91av在线免费看 | 亚洲色图美腿丝袜 | a成人v在线 | 国产精品久久久久久久久久了 | 国产福利久久 | 黄色美女免费网站 | 国产黄色在线看 | 97超碰在线视 | 国产剧情av在线播放 | 国产精品色婷婷 | 天天色 天天 | 亚洲精品国产麻豆 | 成人 国产 在线 | 国产男男gay做爰 | 精品一二三区视频 | 97超碰成人在线 | 久久草网站 | 麻豆国产精品一区二区三区 | 亚洲一区欧美激情 | 久久99精品久久久久久秒播蜜臀 | 国产爽妇网 | 亚洲激情影院 | 狠狠干我 | 久久久精品国产一区二区三区 | 一区二区中文字幕在线播放 | 色爱成人网 | 成人国产在线 | 色综合天天做天天爱 | www91在线观看 | 97福利视频 | 在线免费国产视频 | 91高清免费看 | 午夜在线观看一区 | 久久爱www. | av久久在线| 中文字幕 国产专区 | 超级碰99| 丰满少妇高潮在线观看 | 天天操比 | www天天操 | 国内毛片毛片 | 在线视频 精品 | 美女久久久久久久久久久 | 天天色天天干天天色 | 国产精品二区三区 | 麻花传媒mv免费观看 | 黄色精品网站 | 久久论理 | 97视频免费在线 | 午夜视频在线观看一区二区 | 色综合 久久精品 | 色www.| 有码视频在线观看 | 9色在线视频 | 在线免费观看国产黄色 | 在线v| 成人av在线播放网站 | 亚洲涩涩涩 | 五月情婷婷 | 亚洲视频免费视频 | 日韩免费在线视频观看 | 欧美日韩在线播放一区 | 黄色影院在线免费观看 | 色香com. | 欧美性网站 | 深爱婷婷网 | 一本—道久久a久久精品蜜桃 | 五月婷婷在线播放 | 奇米影视8888 | 久久兔费看a级 | 日韩天堂在线观看 | 国产精品毛片一区二区 | 日韩一区正在播放 | 日韩av偷拍 | 精品1区2区3区 | 一区二区三区在线免费观看视频 | 免费观看午夜视频 | 国产精品美女久久久久久久久 | 色诱亚洲精品久久久久久 | 精品国产一区二区三区四 | 欧美成人精品欧美一级乱 | 国产精品免费看久久久8精臀av | 超碰在线人人 | 日日躁夜夜躁aaaaxxxx | 亚洲综合少妇 | 国产福利精品视频 | 国产免费观看久久 | 国产精品乱码一区二区视频 | 久久免费国产 | 一级黄网| 91网在线看 | 国产日韩欧美在线免费观看 | 欧美最猛性xxx | 国产精品69久久久久 | 精品国产乱码久久久久久1区二区 | 伊人婷婷在线 | 亚洲mv大片欧洲mv大片免费 | 91精品成人| 日韩精品五月天 | 中文字幕亚洲不卡 | 天天摸夜夜添 | 亚洲一区二区视频在线播放 | 色综合久久精品 | 天天色综合久久 | 国产精品第72页 | 日韩高清av在线 | 黄色av电影| a在线观看免费视频 | 亚洲电影久久 | 人人躁 | 久久激情视频免费观看 | 亚洲欧洲国产日韩精品 | 免费电影播放 | 中文字幕在线播放日韩 | 久久男女视频 | 在线观看涩涩 | 亚洲精品视频在线观看免费 | 97超碰色偷偷 | 欧美日韩国产伦理 | 久久久免费在线观看 | 国产成人黄色在线 | 婷婷www| 香蕉视频在线看 | 天天摸日日摸人人看 | 婷婷国产v亚洲v欧美久久 | 国产不卡高清 | 久久国产一区二区三区 | 亚洲综合导航 | 亚洲午夜精品电影 | 欧美日韩在线观看一区二区 | 99成人免费视频 | 国产精品乱码一区二三区 | 国产69久久精品成人看 | 日日夜夜操操操操 | 中文字幕精品一区 | 久久美女免费视频 | 99操视频 | 国产成人黄色片 | 欧美激情综合五月色丁香 | 探花国产在线 | 国产精品原创在线 | 日本黄色免费网站 | 在线只有精品 | 美女久久网站 | 国内久久精品视频 | 九七在线视频 | 欧美射射射 | 亚洲91中文字幕无线码三区 | 亚洲精品ww | 久久久三级视频 | 亚洲电影图片小说 | 伊人五月天婷婷 | 欧美成人亚洲成人 | 国产精品99在线播放 | 网站在线观看日韩 | 国产一区二区久久久久 | 2019中文字幕网站 | 亚洲最新合集 | 夜夜摸夜夜爽 | 美女国产免费 | 亚洲一区二区三区四区在线视频 | 亚洲国产一区在线观看 | 最近高清中文在线字幕在线观看 | 97精品国产97久久久久久免费 | 9992tv成人免费看片 | 99热手机在线观看 | 亚洲精品在线观看不卡 | 中文字幕日本电影 | 国产精品一区二区免费视频 | 日韩av中文字幕在线免费观看 | 99久久爱 | 国产精品日韩欧美一区二区 | 中文字幕欧美激情 | 日韩二区三区 | 国产第一二区 | 婷婷5月激情5月 | 黄色网址在线播放 | 99精品视频免费观看视频 | 国产第一福利网 | 激情av五月婷婷 | 99草视频 | 欧美日韩亚洲在线 | 91亚色视频在线观看 | 操一草| 91久草视频 | 天天翘av| 国产精品3 | 精品久久久久久久久久久院品网 | 精品视频免费播放 | 国产性天天综合网 | 久久96国产精品久久99漫画 | 日韩在线网 | 久草视频网 | 国产剧情在线一区 | 国产玖玖在线 | 99久久精品国产网站 | 99爱视频| 正在播放 国产精品 | 国产又粗又猛又黄视频 | 激情五月婷婷网 | 日韩电影精品一区 | 欧美日韩中文在线观看 | 五月天开心 | 911久久 | 黄网站大全 | 中文字幕中文字幕在线中文字幕三区 | 亚洲天堂色婷婷 | 日韩成人在线免费观看 | 亚洲五月婷婷 | 九九在线高清精品视频 | 欧美淫aaa免费观看 日韩激情免费视频 | 免费精品久久久 | 午夜精品三区 | 久久精品99国产精品日本 | 香蕉视频网址 | 青青河边草免费直播 | 婷婷伊人网 | 欧美激情精品久久久久久变态 | 91超碰在线播放 | av免费看在线 | 国产精品69久久久久 | 久久久久久久久久网 | 国产女人40精品一区毛片视频 | 国产精品久久久久久电影 | 中文字幕中文字幕中文字幕 | 精品国产成人在线影院 | 中文字幕一区二区三区在线视频 | 91香蕉视频黄色 | 探花视频免费观看高清视频 | 亚洲视频每日更新 | 久久99免费 | 奇米网8888 | 成年人免费在线 | 9ⅰ精品久久久久久久久中文字幕 | 婷婷 中文字幕 | 亚洲在线观看av | 欧美福利网址 | 欧美a级免费视频 | 黄av资源| av网在线观看 | 国产精品18久久久久vr手机版特色 | 国产精品一区二区三区观看 | 伊人久久国产精品 | 91在线精品观看 | 国产成年人av | 国产麻豆视频免费观看 | 免费在线一区二区 | 国产精品日韩欧美一区二区 | 亚洲精品视频在 | 日本久久成人中文字幕电影 | 日韩精品三区四区 | 美女国产在线 | 狠狠操夜夜 | 国产色婷婷精品综合在线手机播放 | 中文字幕 婷婷 | 欧美十八 | 91在线网址 | 91av原创 | 国产精品第7页 | 婷婷成人在线 | 五月天婷婷综合 | 九九热在线观看视频 | 人人玩人人添人人澡超碰 | 不卡的av电影在线观看 | 97人人澡人人爽人人模亚洲 | 中文字幕色网站 | 国产精品18久久久久白浆 | 日韩在线字幕 | 成x99人av在线www | 97在线视频免费观看 | 超碰97中文 | www.伊人网| 国产福利在线免费 | 麻豆果冻剧传媒在线播放 | 日韩va欧美va亚洲va久久 | 在线观看免费高清视频大全追剧 | 久久一精品 | 日韩动漫免费观看高清完整版在线观看 | 91黄视频在线观看 | 丁香花在线观看免费完整版视频 | 国产一区二区在线精品 | 91久久久久久国产精品 | 国产成年免费视频 | 国产精品亚洲视频 | 亚洲国产一区在线观看 | 亚洲欧美一区二区三区孕妇写真 | 国产精品 国产精品 | 国产精在线 | av网站免费线看精品 | 欧美人zozo | 欧美日韩xxxxx | 亚洲人人射| 99视频黄 | 亚洲欧美国产精品 | 久草热久草视频 | 免费观看mv大片高清 | 中午字幕在线观看 | 99久久久久成人国产免费 | 国产自在线观看 | 久久免费视频8 | 麻花豆传媒mv在线观看 | 三级黄色片在线观看 | 午夜 免费| 国产精品一区二区三区四 | 丁香婷婷综合激情 | 日韩在线观看一区二区三区 | 91高清免费观看 | 福利精品在线 | 最近日本mv字幕免费观看 | 伊人色综合久久天天网 | 精品亚洲国产视频 | 日韩欧美精品在线观看 | 国产香蕉97碰碰碰视频在线观看 | 成人在线视频你懂的 | 免费看黄色小说的网站 | 欧美一级片免费 | 成人宗合网 | 亚洲精品视频免费 | 操夜夜操| 伊人亚洲综合网 | 麻豆视频一区二区 | 在线导航福利 | 成 人 黄 色 片 在线播放 | 免费观看一级一片 | 日韩网 | 国产在线不卡 | 久久av免费| 日日夜夜天天综合 | 婷婷久久五月天 | 亚洲综合成人专区片 | 成 人 免费 黄 色 视频 | 黄色亚洲 | 久久久久久久久久久黄色 | 精品影院一区二区久久久 | 天天干 天天摸 天天操 | 成人一区影院 | www久久国产| 日本99热 | 久久这里只有精品9 | av手机在线播放 | 国产精品麻豆欧美日韩ww | 午夜精品一区二区三区视频免费看 | 成人午夜久久 | 97超碰成人| 91亚洲网站| 精品专区一区二区 | 久久综合色播五月 | 999国内精品永久免费视频 | 91色视频| 成人免费大片黄在线播放 | 欧洲av不卡 | 亚洲电影网站 | 色综合中文字幕 | 96香蕉视频 | 国产成年免费视频 | 91亚洲狠狠婷婷综合久久久 | 日韩电影久久久 | 国产+日韩欧美 | 97视频在线观看成人 | 欧亚日韩精品一区二区在线 | 亚洲久在线 | 超碰免费在线公开 | 91麻豆精品国产91久久久久 | 亚洲国产成人在线 | 最新午夜 | 日韩区在线观看 | 日韩电影一区二区三区在线观看 | 波多野结衣视频一区二区三区 | 亚洲国产精品日韩 | av黄色在线播放 | 日韩精品久久一区二区三区 | 欧美精品中文字幕亚洲专区 | 亚洲最新av网址 | 久久精品视频在线观看免费 | 91观看视频 | 亚洲日日射 | 欧美性粗大hdvideo | 亚洲欧美一区二区三区孕妇写真 | 国产大尺度视频 | 日韩精品免费一区二区在线观看 | 91自拍视频在线观看 | 久久久精品视频成人 | 日韩高清一 | 国产91精品一区二区麻豆亚洲 | 碰碰影院 | 久久免费视频这里只有精品 | 欧美黑人猛交 | av视屏在线| 婷婷激情网站 | 国产精品一区一区三区 | 99免费在线视频观看 | 在线观看中文字幕 | 国产精品综合在线 | 91香蕉视频污在线 | 一区二区三区四区在线 | 天天综合色网 | 日韩av影视 | 国产精品一区二区久久久 | 在线亚洲激情 | 欧美日韩国产精品久久 | 欧美在线观看视频一区二区 | 国产又粗又猛又黄又爽的视频 | 国产 在线 高清 精品 | mm1313亚洲精品国产 | 欧洲一区二区三区精品 | 日韩小视频 | 国产三级视频在线 | 色综合天天狠天天透天天伊人 |