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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

mybatis源码_MyBatis架构和源码

發布時間:2024/4/19 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybatis源码_MyBatis架构和源码 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Mybatis架構解讀

1. 架構圖

如題,這就是MyBatis的執行架構圖。解釋一下:我們在使用MyBatis的CRUD操作的時候,一般有兩種方式,一、直接調用sqlSession的crud方法;二、通過調用getMapper獲取到接口代理的實現類,然后在代理方法中調用了crud方法??梢钥吹?#xff0c;本質相同,最終調用的都是sqlSession的方法,上圖就是CRUD執行的流程

2. 執行流程圖

我們先來看一下我們執行一個MyBatis的查詢,需要做什么。

//加載一個配置文件 InputStream resourceAsStream = Resources.getResourceAsStream("main.xml"); SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder(); SqlSessionFactory build = sqlSessionFactoryBuilder.build(resourceAsStream); SqlSession sqlSession = build.openSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class);//代理模式創建了一個實現類 List<User> all = mapper.findAll(1); all.forEach(System.out::println);

這就是一個最簡單的查詢過程。下面我們來分析一下他們每一步做了什么事情。

2.1 Resources.getResourceAsSteam

很簡單,讀取了一個配置文件??赡苡械男』锇檫@個樣子干過,直接將通過本類的類加載器拿到資源路徑,然后直接獲取這個主配置文件,但提示未找到。

看一下他的源碼,他直接拿了一個系統類加載器。

public static InputStream getResourceAsStream(ClassLoader loader, String resource) throws IOException {InputStream in = classLoaderWrapper.getResourceAsStream(resource, loader);if (in == null) {throw new IOException("Could not find resource " + resource);}return in;}ClassLoaderWrapper() {try {systemClassLoader = ClassLoader.getSystemClassLoader();} catch (SecurityException ignored) {// AccessControlException on Google App Engine}}

這個時候,我們自己使用ClassLoader獲取系統類加載器加載資源, 這個時候也是可以成功獲取的。于是想到了一個方法我比較了一下本類類加載器和系統類加載的類別,發現都是通過ApplicationClassLoader加載的,但系統類加載器無法加載

后來了解到的原因就是由于Maven插件的原因,在插件的地方指定一個Resource的映射路徑即可,不過建議直接使用MyBatis的加載方式,簡單一點。

2.2 new SqlSessionFactoryBuilder.build

創建了一個SqlSessionFactoryBuilder構建者對象,構建者模式

然后通過build方法加載配置文件的資源。配置文件包括:主配置文件、Mapper文件或者注解。

來看一下我們的主配置文件

<configuration><typeAliases><package name="com.bywlstudio.bean"/></typeAliases><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="com.mysql.cj.jdbc.Driver"/><……………………></dataSource></environment></environments><mappers><mapper class="com.bywlstudio.mapper.UserMapper"></mapper></mappers> </configuration>

XML文件,MyBatis通過XPath語法進行解析,首先拿了一個Configuration節點,然后再解析內部的節點,每一個節點對應一個方法??匆幌略创a

private void parseConfiguration(XNode root) {try {//issue #117 read properties firstpropertiesElement(root.evalNode("properties"));Properties settings = settingsAsProperties(root.evalNode("settings"));loadCustomVfs(settings);loadCustomLogImpl(settings);typeAliasesElement(root.evalNode("typeAliases"));pluginElement(root.evalNode("plugins"));objectFactoryElement(root.evalNode("objectFactory"));objectWrapperFactoryElement(root.evalNode("objectWrapperFactory"));reflectorFactoryElement(root.evalNode("reflectorFactory"));settingsElement(settings);// read it after objectFactory and objectWrapperFactory issue #631environmentsElement(root.evalNode("environments"));databaseIdProviderElement(root.evalNode("databaseIdProvider"));typeHandlerElement(root.evalNode("typeHandlers"));mapperElement(root.evalNode("mappers"));} catch (Exception e) {throw new BuilderException("Error parsing SQL Mapper Configuration. Cause: " + e, e);}}

接下來要做的事情,就比較清晰了,解析每一個XML標簽中的節點、文本和屬性值,為對應的對象進行封裝

我們主要看一下environments解析做了什么。

要看他做了什么,得先看它有什么。

它內部有多個environment元素,還有最關鍵的信息,事務管理者和數據源

所以在這個方法中他封裝了一個Environment對象,內部存放了一個事務工廠和一個數據源對象??匆幌翬nvironment類信息

public final class Environment {private final String id;private final TransactionFactory transactionFactory;private final DataSource dataSource;

接下來再看重頭戲Mappers的解析

Mappers中可以存在四種映射方式:面試題

  • package。指定一個需要掃描的包
  • resource。指定一個本地的mapper映射文件
  • url。指定一個url可以為網絡的mapper映射文件
  • class。指定一個類作為一個需要被代理的mapper

接下來我們看一下他的處理方式:

private void mapperElement(XNode parent) throws Exception {if (parent != null) {for (XNode child : parent.getChildren()) {//子節點是否為packageif ("package".equals(child.getName())) {String mapperPackage = child.getStringAttribute("name");configuration.addMappers(mapperPackage);} else {String resource = child.getStringAttribute("resource");String url = child.getStringAttribute("url");String mapperClass = child.getStringAttribute("class");//屬性是否為resourceif (resource != null && url == null && mapperClass == null) {ErrorContext.instance().resource(resource);InputStream inputStream = Resources.getResourceAsStream(resource);XMLMapperBuilder mapperParser = new XMLMapperBuilder(inputStream, configuration, resource, configuration.getSqlFragments());//xml方式處理mapperParser.parse();//屬性是否為url} else if (resource == null && url != null && mapperClass == null) {ErrorContext.instance().resource(url);InputStream inputStream = Resources.getUrlAsStream(url);XMLMapperBuilder mapperParser = new XMLMapperBuilder(inputStream, configuration, url, configuration.getSqlFragments());mapperParser.parse();//屬性是否為class} else if (resource == null && url == null && mapperClass != null) {Class<?> mapperInterface = Resources.classForName(mapperClass);//注解的方式處理configuration.addMapper(mapperInterface);} else {throw new BuilderException("A mapper element may only specify a url, resource or class, but not more than one.");}}}}}

2.2.1 xml方式

先來聊一下xml的處理方式

首先拿到對應的mapper文件,之后創建了一個解析該資源的類XMLMapperBuilder。解析子標簽mapper等等屬性,邏輯和之前一樣,最后將所有的信息添加到了Configutation類中。

2.2.2 注解方式

一個核心方法org.apache.ibatis.binding.MapperRegistry#addMapper。有一個點,當你的Mapper不是一個接口的時候,他直接不處理了

public <T> void addMapper(Class<T> type) {//是否為接口if (type.isInterface()) {if (hasMapper(type)) {throw new BindingException("Type " + type + " is already known to the MapperRegistry.");}boolean loadCompleted = false;try {//將Mapper的信息,封裝到一個MapperProxyFactory工廠中knownMappers.put(type, new MapperProxyFactory<>(type));// It's important that the type is added before the parser is run// otherwise the binding may automatically be attempted by the// mapper parser. If the type is already known, it won't try.MapperAnnotationBuilder parser = new MapperAnnotationBuilder(config, type);//具體解析parser.parse();loadCompleted = true;} finally {if (!loadCompleted) {knownMappers.remove(type);}}}}

這個方法做的最重要的一件事情:

  • 將所有的mapper信息存放到了MapperRegistry#knownMappers集合中

具體的解析過程中,他還設置了StatementType=PREPARED;

后面解析的過程主要進行注解解析,判斷是否存在某某某注解,最后將所有的信息封裝到了一個Configuration中。

每一條SQL對應一個MappedStatement對象,該對象不可變

public final class MappedStatement {private String resource;private Configuration configuration;private String id;private Integer fetchSize;private Integer timeout;private StatementType statementType;private ResultSetType resultSetType;private SqlSource sqlSource;private Cache cache;private ParameterMap parameterMap;private List<ResultMap> resultMaps;private boolean flushCacheRequired;private boolean useCache;private boolean resultOrdered;private SqlCommandType sqlCommandType;private KeyGenerator keyGenerator;private String[] keyProperties;private String[] keyColumns;private boolean hasNestedResultMaps;private String databaseId;private Log statementLog;private LanguageDriver lang;private String[] resultSets;

2.3 openSession

本質上創建了一個DefalutSqlSession對象。創建了Executor

private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) {Transaction tx = null;try {final Environment environment = configuration.getEnvironment();//獲取之前的事務工廠final TransactionFactory transactionFactory = getTransactionFactoryFromEnvironment(environment);//創建一個事務tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit);//創建一個執行器final Executor executor = configuration.newExecutor(tx, execType);//創建了一個SQLSessionreturn new DefaultSqlSession(configuration, executor, autoCommit);} catch (Exception e) {closeTransaction(tx); // may have fetched a connection so lets call close()throw ExceptionFactory.wrapException("Error opening session. Cause: " + e, e);} finally {ErrorContext.instance().reset();}}

2.4 getMapper

還記得在build中,Mybatis將mapper信息封裝為一個MapperProxyFactory添加到了一個List中,而現在的GetMapper就從里面拿到對應的Mapper代理工廠信息,然后創建對應的Mapper代理對象,最后返回

public <T> T getMapper(Class<T> type, SqlSession sqlSession) {final MapperProxyFactory<T> mapperProxyFactory = (MapperProxyFactory<T>) knownMappers.get(type);if (mapperProxyFactory == null) {throw new BindingException("Type " + type + " is not known to the MapperRegistry.");}try {return mapperProxyFactory.newInstance(sqlSession);} catch (Exception e) {throw new BindingException("Error getting mapper instance. Cause: " + e, e);}}

我們來看一下我們的代理對象

@SuppressWarnings("unchecked")protected T newInstance(MapperProxy<T> mapperProxy) {return (T) Proxy.newProxyInstance(mapperInterface.getClassLoader(), new Class[] { mapperInterface }, mapperProxy);}public T newInstance(SqlSession sqlSession) {//這個就是我們的代理對象,也就是實現了代理接口的類final MapperProxy<T> mapperProxy = new MapperProxy<>(sqlSession, mapperInterface, methodCache);return newInstance(mapperProxy);}

看一下這個里面有什么

public class MapperProxy<T> implements InvocationHandler, Serializable {private static final long serialVersionUID = -6424540398559729838L;private final SqlSession sqlSession;private final Class<T> mapperInterface;private final Map<Method, MapperMethod> methodCache;//執行增強的具體的方法public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {

2.5 具體的CRUD

在getMapper中,我們知道了此時返回的是一個該接口的代理對象,當我們執行具體的方法的時候,就走了其代理方法。

主要執行邏輯是:判斷Sql的操作類型,然后執行對應的方法,如果是查詢,則從緩存中查詢,如果沒有,則查詢數據庫,查到以后,將查詢到的信息進行封裝,封裝以后,將這個信息添加的緩存中,然后返回。

他首先判斷了該方法的類信息是不是object,然后判斷是不是默認方法,如果是分別執行。最后他給本類的methodCache中添加了一個方法映射

@Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {try {if (Object.class.equals(method.getDeclaringClass())) {return method.invoke(this, args);} else if (isDefaultMethod(method)) {return invokeDefaultMethod(proxy, method, args);}} catch (Throwable t) {throw ExceptionUtil.unwrapThrowable(t);}final MapperMethod mapperMethod = cachedMapperMethod(method);return mapperMethod.execute(sqlSession, args);}

接下來再看一下具體的執行方法。

public Object execute(SqlSession sqlSession, Object[] args) {Object result;switch (command.getType()) {case INSERT: {Object param = method.convertArgsToSqlCommandParam(args);result = rowCountResult(sqlSession.insert(command.getName(), param));break;}case UPDATE: {Object param = method.convertArgsToSqlCommandParam(args);result = rowCountResult(sqlSession.update(command.getName(), param));break;}case DELETE: {Object param = method.convertArgsToSqlCommandParam(args);result = rowCountResult(sqlSession.delete(command.getName(), param));break;}case SELECT://返回值是否為nullif (method.returnsVoid() && method.hasResultHandler()) {executeWithResultHandler(sqlSession, args);result = null;//返回值是否為多個(List)} else if (method.returnsMany()) {result = executeForMany(sqlSession, args);} else if (method.returnsMap()) {//返回值是否為鍵值result = executeForMap(sqlSession, args);} else if (method.returnsCursor()) {result = executeForCursor(sqlSession, args);} else {//返回值為一個Object param = method.convertArgsToSqlCommandParam(args);result = sqlSession.selectOne(command.getName(), param);if (method.returnsOptional() &&(result == null || !method.getReturnType().equals(result.getClass()))) {result = Optional.ofNullable(result);}}break;case FLUSH:result = sqlSession.flushStatements();break;default:throw new BindingException("Unknown execution method for: " + command.getName());}return result;}

這個時候就回歸到了SqlSession的API調用了

2.6 SqlSession具體調用

拿Select為例

首先他生成了一個cacheKey,拿這個key從緩存中找,如果沒有查詢數據庫,查到以后將對應的結果放到緩存中,然后返回給用戶

//調用函數, executor.query(MappedStatement, parameter, RowBounds.DEFAULT, Executor.NO_RESULT_HANDLER);public <E> List<E> query(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, CacheKey key, BoundSql boundSql) throws SQLException { if (queryStack == 0 && ms.isFlushCacheRequired()) {clearLocalCache();}List<E> list;try {queryStack++;//查詢緩存list = resultHandler == null ? (List<E>) localCache.getObject(key) : null;if (list != null) {handleLocallyCachedOutputParameters(ms, key, parameter, boundSql);} else {list = queryFromDatabase(ms, parameter, rowBounds, resultHandler, key, boundSql);}} finally {queryStack--;}if (queryStack == 0) {for (DeferredLoad deferredLoad : deferredLoads) {deferredLoad.load();}// issue #601deferredLoads.clear();if (configuration.getLocalCacheScope() == LocalCacheScope.STATEMENT) {// issue #482clearLocalCache();}}return list;}
  • 查詢以后放置到緩存并且返回的操作
private <E> List<E> queryFromDatabase(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, CacheKey key, BoundSql boundSql) throws SQLException {List<E> list;localCache.putObject(key, EXECUTION_PLACEHOLDER);try {list = doQuery(ms, parameter, rowBounds, resultHandler, boundSql);} finally {localCache.removeObject(key);}//緩存添加localCache.putObject(key, list);if (ms.getStatementType() == StatementType.CALLABLE) {localOutputParameterCache.putObject(key, parameter);}//返回return list;}
  • 重頭戲來了,接下來將會創建架構圖里的第二個內容StatementHandler
@Overridepublic <E> List<E> doQuery(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) throws SQLException {Statement stmt = null;try {Configuration configuration = ms.getConfiguration();//創建了一個StatementHandlerStatementHandler handler = configuration.newStatementHandler(wrapper, ms, parameter, rowBounds, resultHandler, boundSql);stmt = prepareStatement(handler, ms.getStatementLog());return handler.query(stmt, resultHandler);} finally {closeStatement(stmt);}}

在創建的時候,他將所有的StatementHandler攔截器都執行了一遍。

public StatementHandler newStatementHandler(Executor executor, MappedStatement mappedStatement, Object parameterObject, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) {//創建了一個StatementHandlerStatementHandler statementHandler = new RoutingStatementHandler(executor, mappedStatement, parameterObject, rowBounds, resultHandler, boundSql);//執行所有的Statement攔截器(所有)statementHandler = (StatementHandler) interceptorChain.pluginAll(statementHandler);return statementHandler;}

還記得在build的時候,指定了一個StatementType.PREPARED類型嗎?這個時候這個東西就開始起作用了。在創建RoutingStatementHandler這個類的時候,他根據StatementType類型創建了一個子類,而現在創建的就是PreparedStatementHandler,而在這個類的父類里創建了ParameterHandler和ResultSetHandler。

public class RoutingStatementHandler implements StatementHandler {private final StatementHandler delegate;public RoutingStatementHandler(Executor executor, MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) {switch (ms.getStatementType()) {case STATEMENT:delegate = new SimpleStatementHandler(executor, ms, parameter, rowBounds, resultHandler, boundSql);break;case PREPARED:delegate = new PreparedStatementHandler(executor, ms, parameter, rowBounds, resultHandler, boundSql);break;case CALLABLE:delegate = new CallableStatementHandler(executor, ms, parameter, rowBounds, resultHandler, boundSql);break;default:throw new ExecutorException("Unknown statement type: " + ms.getStatementType());}}

他們在創建的時候又將對應的所有攔截器執行了一遍。

到了這里,架構圖里的東西已經全部出來了。

接下來就是執行SQL了

2.7 總結

我們來看一下Configuration類。一家人整整齊齊,圖上的東西都在這里了

整體執行邏輯就是:

  • 創建一個Executor對象,將事務和數據源放進去
  • 創建StatementHandler實現類,將其對應的攔截器執行了
  • 在創建實現類的時候又創建了ParameterHandler實現類,并且將其攔截器執行了
  • 同時也創建了ResultSetHandler,并且將其攔截器執行了
  • 之后通過這個結果集映射做了一次對象封裝,將數據存到緩存里,然后返回了。

3. 面試題

面試題整理自網絡,方便復習

3.1 #{}和${}的區別

  • ${}是Properties文件中的變量占位符,可以應用于標簽屬性值和SQL內部,屬于靜態替換
  • #{}是SQL參數占位符,MyBatis會將SQL中的#{}替換為?,在SQL執行前通過PreparedStatement的參數設置方法,設置具體的參數值。

3.2 XML映射文件中,除了select|insert|update|delete還有哪些標簽

答:

  • <resultMap>。自定義結果集映射
  • <cache>。定義當前命名空間中的緩存配置策略
  • <cache-ref>。引用其他命名空間的緩存配置
  • <sql>。定義一個SQL語句塊,可以被引用
  • 動態SQL
    • <include>引用一個SQL塊
    • <foreach>
    • <if>
    • <where>
    • <trim>

3.3 最佳實踐中,通常一個Xml映射文件,都會寫一個Dao接口與之對應,請問,這個Dao接口的工作原理是什么?Dao接口里的方法,參數不同時,方法能重載嗎?

答:在MyBaits中,每一個命名空間的方法都擁有一個唯一標識。接口全限定類名.方法名,所以參數不同不能重載。其工作原理是通過JDK動態代理實現的。真正執行的是MapperProxy

3.4 MyBatis是如何進行分頁的?分頁插件的原理是什么?

Mybatis使用RowBounds對象進行分頁,它是針對ResultSet結果集執行的內存分頁,而非物理分頁。可以在sql內直接書寫帶有物理分頁的參數來完成物理分頁功能,也可以使用分頁插件來完成物理分頁。

分頁插件的基本原理是使用Mybatis提供的插件接口,實現自定義插件,在插件的攔截方法內攔截待執行的sql,然后重寫sql

3.5 簡述Mybatis的插件運行原理,以及如何編寫一個插件。

答:Mybatis僅可以編寫針對ParameterHandler、ResultSetHandler、StatementHandler、Executor這4種接口的插件,Mybatis使用JDK的動態代理,為需要攔截的接口生成代理對象以實現接口方法攔截功能,每當執行這4種接口對象的方法時,就會進入攔截方法,具體就是InvocationHandler的invoke()方法,當然,只會攔截那些你指定需要攔截的方法。

實現Mybatis的Interceptor接口并重寫intercept()方法,然后在給插件編寫注解,指定要攔截哪一個接口的哪些方法即可,記住,別忘了在配置文件中配置你編寫的插件。

3.6 Mybatis是如何將sql執行結果封裝為目標對象并返回的?都有哪些映射形式?

答:第一種是使用<resultMap>標簽,逐一定義列名和對象屬性名之間的映射關系。第二種是使用sql列的別名功能,將列別名書寫為對象屬性名,比如T_NAME AS NAME,對象屬性名一般是name,小寫,但是列名不區分大小寫,Mybatis會忽略列名大小寫,智能找到與之對應對象屬性名,你甚至可以寫成T_NAME AS NaMe,Mybatis一樣可以正常工作。

有了列名與屬性名的映射關系后,Mybatis通過反射創建對象,同時使用反射給對象的屬性逐一賦值并返回,那些找不到映射關系的屬性,是無法完成賦值的。

3.7 Mybatis能執行一對一、一對多的關聯查詢嗎?都有哪些實現方式,以及它們之間的區別。

答:在Mybatis的ResultMap中可以通過Result標簽或者注解指定需要映射的表。通過內部的one和many實現具體的一對一或者一對多映射關系。

比如可以通過Result中的one實現一對一映射。內部的select指定另一個查詢語句,fetchType用于指定是否使用懶加載

@Results({@Result(id = true , column = "id" , property = "id"),@Result(column = "nickName" , property = "nickName"),@Result(column = "gender" , property = "gender"),@Result(column = "city" , property = "city"),@Result(column = "province" , property = "province"),@Result(column = "wid" , property = "wxuser" ,one = @One(select = "com.bywlstudio.dao.IWXUserDao.findWXUserById" ,fetchType = FetchType.EAGER)),})

3.8 懶加載實現原理

答:通過代理方法創建代理對象以后,在真正獲取數據的時候到達攔截器的方法之后,攔截器方法首先判斷當前值是否為null,如果為null,則通過預先的SQL查詢并且set,最后get查詢。

3.9 myBatis如何執行批處理

答:通過BatchExecutor完成批處理

3.10 MyBatis有哪些Executor執行,以及他們之間的區別

答:

  • SimpleExecutor,執行一次update或者select就開啟一個statement,用完立刻關閉
  • ReuseExecutor,執行update或者select,以SQL作為key查找Statement對象,存在就使用,不存在就創建,用完以后,添加到Map<String,Statement>中
  • BatchExecutor,執行update,將所有的Sql添加到批處理中,等待統一執行,緩存了多個Statement對象。

3.11 Mybatis中如何指定使用哪一種Executor執行器?

在Mybatis配置文件中,可以指定默認的ExecutorType執行器類型,也可以手動給DefaultSqlSessionFactory的創建SqlSession的方法傳遞ExecutorType類型參數。

3.12 Mybatis是否可以映射Enum枚舉類?

Mybatis可以映射枚舉類,不單可以映射枚舉類,Mybatis可以映射任何對象到表的一列上。映射方式為自定義一個TypeHandler,實現TypeHandler的setParameter()和getResult()接口方法。TypeHandler有兩個作用,一是完成從javaType至jdbcType的轉換,二是完成jdbcType至javaType的轉換,體現為setParameter()和getResult()兩個方法,分別代表設置sql問號占位符參數和獲取列查詢結果。

往期回顧

撩改JVM常見調優參數?mp.weixin.qq.com入門JVM?讀這一篇就夠了?mp.weixin.qq.com多線程知識點小結?mp.weixin.qq.comLock和Synchronized?mp.weixin.qq.com你了解線程池嗎??mp.weixin.qq.com

總結

以上是生活随笔為你收集整理的mybatis源码_MyBatis架构和源码的全部內容,希望文章能夠幫你解決所遇到的問題。

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

9999激情 | 麻豆久久久久久久 | av在线免费观看网站 | 国内外成人在线视频 | 中文字幕亚洲综合久久五月天色无吗'' | 高清av中文字幕 | 午夜电影中文字幕 | 亚洲成人av片在线观看 | 久久午夜电影网 | 日韩精品在线观看av | av在线电影播放 | 成人精品亚洲 | 国产一性一爱一乱一交 | 亚洲综合干 | 色婷婷综合激情 | 精品美女在线观看 | 亚洲欧美成人在线 | 在线观看av网 | 国产精品午夜免费福利视频 | 亚洲一级影院 | 成人免费视频网站在线观看 | 99热免费在线| 亚洲精品欧美视频 | 国产精品一区二区三区久久 | 91av在线免费播放 | 久久久久免费精品国产 | av超碰免费在线 | 亚洲91视频| 国产又粗又猛又黄视频 | 欧美一级高清片 | 国产成人一区二区三区 | 国产精品你懂的在线观看 | 久久国产网 | 国产精品剧情 | 激情五月婷婷综合网 | 亚洲精品久久久久中文字幕二区 | 人人爽人人看 | av电影在线免费观看 | 久草在线免费电影 | 日韩在线观看中文 | 日韩免费在线看 | 免费观看黄色12片一级视频 | 天天操天天摸天天射 | 亚洲爽爽网 | 久久99久久99精品免观看软件 | 黄色一级大片在线免费看国产一 | 日韩三级视频在线看 | av电影av在线 | 久久视频在线 | 亚洲一区美女视频在线观看免费 | 成人av在线一区二区 | 五月花激情 | 人人澡av| 久久男人影院 | 一本—道久久a久久精品蜜桃 | 日韩欧美一区二区三区在线观看 | 天天干天天拍天天操 | 日日噜噜噜噜夜夜爽亚洲精品 | 四虎成人精品永久免费av | 欧美性生活一级片 | 久久视频一区 | 999久久久久久久久久久 | 日韩爱爱网站 | 日韩精品一区二区久久 | 激情视频亚洲 | 五月天激情视频 | 在线小视频国产 | 国产伦理一区二区 | 久久综合九色综合97_ 久久久 | 久久久久亚洲精品 | 一区二区三区电影 | 天天干天天综合 | 欧美二区视频 | 久久国产精品一区二区三区四区 | 视频成人永久免费视频 | 在线观看中文字幕dvd播放 | 亚洲国产理论片 | 69夜色精品国产69乱 | 天天天天天操 | 91在线免费看片 | 99精品免费久久久久久日本 | 久久久久亚洲精品国产 | 97在线超碰| 玖玖玖影院 | 亚洲视频网站在线观看 | 四虎在线观看 | 人人爽人人插 | 精品三级av | 91香蕉视频 | 视频在线亚洲 | 在线观看一级片 | 国产精品视频专区 | 在线观看色视频 | 免费看91的网站 | 992tv人人草| 黄色大片视频网站 | mm1313亚洲精品国产 | 国产精品一区免费观看 | 成人黄色大片在线观看 | 五月婷香蕉久色在线看 | 久草精品视频 | 亚洲精品在线视频 | 人人操日日干 | 国产男女无遮挡猛进猛出在线观看 | 2019精品手机国产品在线 | av先锋影音少妇 | 国产一级视频在线 | 三级av片 | av电影中文 | 最新真实国产在线视频 | 国产成人免费在线观看 | 六月丁香在线观看 | 午夜视频一区二区 | 搡bbbb搡bbb视频 | 日韩欧美区 | 日本久久免费电影 | 日韩大片在线播放 | 亚洲精品国产电影 | 99热在 | 精品一区二区电影 | 六月色丁香 | 久久论理 | 国产淫a | av综合网址 | 国模精品一区二区三区 | 国产黄色片一级三级 | 久久99精品久久久久婷婷 | 91久久久久久久一区二区 | 91成人在线视频观看 | 欧美黑人性爽 | 成人精品国产免费网站 | 亚洲第一香蕉视频 | 国产在线1区 | 美女视频黄免费的久久 | 亚洲国产欧美在线看片xxoo | 国产精品久久一区二区三区, | 中文字幕免费国产精品 | 日本中文字幕在线观看 | 天天操天天干天天操天天干 | 色婷婷中文 | 黄色精品久久久 | 久久精品国产美女 | 欧美另类亚洲 | 热久久免费视频精品 | 友田真希x88av | 亚洲精品高清在线观看 | 麻豆精品在线视频 | 日日爽 | 18av在线视频 | 国产视频精品久久 | 日日草av| 丁香六月婷婷开心婷婷网 | 男女全黄一级一级高潮免费看 | 成人小视频在线免费观看 | a天堂中文在线 | 尤物一区二区三区 | 国产专区在线看 | 99在线视频播放 | 涩涩网站在线播放 | 一级黄毛片 | 日韩精品一区二区三区高清免费 | 中文字幕免费 | www91在线观看| 六月婷婷久香在线视频 | 欧美疯狂性受xxxxx另类 | 亚洲伦理一区 | 天天射天天拍 | 久久精品国亚洲 | 国产成人一区二区三区 | 国产在线精品一区二区三区 | 国产69精品久久久久久 | 亚洲成年人在线播放 | 91传媒在线播放 | 亚洲码国产日韩欧美高潮在线播放 | 四虎免费在线观看视频 | 人人玩人人添人人 | 国产成人精品午夜在线播放 | 一本之道乱码区 | 成人手机在线视频 | 天天干,天天射,天天操,天天摸 | 六月激情网 | 亚洲一片黄 | 亚洲精品在线观看免费 | 久久久国产一区二区三区四区小说 | 日狠狠 | 一级α片| 精品久久久久久国产 | 日韩欧美一区二区在线播放 | 午夜免费福利片 | 99热这里有精品 | 麻豆国产露脸在线观看 | 日韩丝袜视频 | 国产香蕉av | 日本性高潮视频 | 麻豆视频免费入口 | 亚洲九九精品 | 五月婷婷,六月丁香 | 九九免费观看全部免费视频 | 午夜性盈盈 | 亚洲国产成人精品久久 | 一区二区三区高清在线 | 国产精品一区二区三区电影 | 精品久久久久久亚洲 | av福利网址导航 | 四虎天堂| 在线看国产日韩 | 日韩免费三区 | 国产亚洲免费的视频看 | 久久99热这里只有精品 | 玖草在线观看 | 日韩免费在线视频 | 久久69av| 国产护士av | 国产一区二区三区网站 | 少妇bbbb揉bbbb日本 | 精品国产一区二区三区蜜臀 | 97在线资源 | 久久99热这里只有精品国产 | 免费在线观看不卡av | 久久久精品综合 | 97超碰总站 | www色av| 黄色三级免费片 | 亚洲精品视频播放 | 国产又粗又猛又黄视频 | 日韩网站在线播放 | 蜜臀精品久久久久久蜜臀 | 亚洲视频免费视频 | 一区二区中文字幕在线 | 日韩精品在线视频免费观看 | 精品主播网红福利资源观看 | 97精品国产97久久久久久春色 | 国产精品久久久久亚洲影视 | 亚洲精品在线视频播放 | 六月天综合网 | 日韩精品一区二区免费视频 | 97超碰人人澡人人爱 | 91最新在线 | 男女全黄一级一级高潮免费看 | www.xxxx变态.com | 免费观看久久 | 91亚州| 中文字幕成人一区 | 亚洲国产成人av网 | 国产免费av一区二区三区 | 亚洲a成人v | 国产日韩欧美在线影视 | 天天操天天摸天天干 | 成人久久久久久久久 | 91免费版在线 | 91传媒91久久久 | 亚洲精品视频网址 | 激情网五月 | 性色视频在线 | 国产成人黄色 | 久久久久国产精品www | 黄色免费电影网站 | 国产精品久久久久久吹潮天美传媒 | 国产精品免费在线观看视频 | 国产高清在线免费观看 | 国产一区视频免费在线观看 | 色婷婷一| www.久久免费 | 天天爽天天摸 | 超碰在线观看97 | 色的网站在线观看 | 日韩精品一区二区在线观看视频 | 日韩毛片在线一区二区毛片 | 最新国产视频 | 91成人免费视频 | 天天综合网国产 | 午夜美女wwww | av免费在线网 | 色香com.| 日韩欧美国产成人 | 波多野结衣网址 | 色婷婷综合久久久 | 中文字幕永久免费 | 国产精品一区二区av日韩在线 | av在线等| 免费黄a大片 | 国产精品久久久免费看 | 婷婷综合在线 | 97在线看| 久久色视频 | 天天操天天操 | 999久久国产精品免费观看网站 | 日韩中文字幕免费在线播放 | 九九免费精品 | 久久人人爽人人人人片 | 天天干天天干天天色 | 992tv人人草 黄色国产区 | 中文字幕免费观看全部电影 | 综合久久精品 | 成人免费观看大片 | 亚洲视频高清 | 麻豆视频网址 | 国产精品wwwwww | 日日干av | 黄色三级免费 | 免费看片网址 | 国产精品视频地址 | 成人污视频在线观看 | 9999在线观看| 日韩夜夜爽 | 99在线高清视频在线播放 | 久久婷婷一区二区三区 | 天堂久色| 国产成人黄色av | 一区二区三区免费在线播放 | 色综合天天综合网国产成人网 | 91成人短视频在线观看 | 成人黄色视 | 亚洲精品视频第一页 | 成年人天堂com | 丁香婷婷电影 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 国产精品入口久久 | 97成人在线| 久久精品国产一区二区三区 | 美女一级毛片视频 | 青草视频网 | 九七在线视频 | 天天操夜夜想 | 日韩激情视频在线观看 | 久久99在线观看 | 日韩在线观看不卡 | 精品1区二区| 日韩av片无码一区二区不卡电影 | 久久久久国产精品免费 | 日本中文字幕久久 | 国产精品免费在线播放 | 国产原创中文在线 | 国产一区二区网址 | 国内精品在线观看视频 | 国产一级片毛片 | 国产精品女同一区二区三区久久夜 | 操操操影院 | 亚州精品一二三区 | 色老板在线视频 | a视频在线看| 黄色成人毛片 | 伊人av综合 | 91手机在线看片 | 久久久久 免费视频 | 男女拍拍免费视频 | 久久婷综合 | 久久国产精品久久精品 | 午夜电影一区 | 免费高清男女打扑克视频 | 在线亚洲午夜片av大片 | 五月婷婷中文 | 日本中出在线观看 | a久久久久久 | 国产一卡二卡在线 | 欧美日韩中文字幕在线视频 | 不卡中文字幕av | 色永久免费视频 | 日韩免费视频播放 | 91久久精品日日躁夜夜躁国产 | 中文字幕 婷婷 | 国产美女视频一区 | 色在线免费观看 | 国产又粗又猛又黄视频 | 亚洲国产午夜精品 | 国产手机在线精品 | 国产香蕉久久 | 国产精品乱码一区二三区 | 日本性生活一级片 | 国产91aaa | 久久综合九色欧美综合狠狠 | 天天操天天射天天爽 | 亚洲成人第一区 | 国产成人一区二区啪在线观看 | 99欧美精品| 国内精品视频在线 | 亚洲男男gaygayxxxgv | 韩日成人av | 人人玩人人添人人 | 国产精品久久久久久吹潮天美传媒 | 日韩精品一区二区三区高清免费 | 免费久久久 | 91久久电影| 中文字幕乱视频 | 亚洲电影免费 | 久久美女高清视频 | 国产精品福利在线观看 | 色综合天天狠狠 | 成年人国产在线观看 | 激情深爱五月 | 99精品视频免费全部在线 | 日韩一区二区三区在线观看 | 欧美性生活久久 | 亚洲成av人影片在线观看 | 日日日视频| 国产成人免费高清 | 日本不卡视频 | 免费网站色 | 成人欧美一区二区三区黑人麻豆 | 国产成a人亚洲精v品在线观看 | 久久久一本精品99久久精品66 | 国产.精品.日韩.另类.中文.在线.播放 | 欧美日韩国产一区二区在线观看 | 99人久久精品视频最新地址 | 久久久久免费精品视频 | 亚洲精品视频中文字幕 | 天天射狠狠干 | 成人av免费电影 | 久久黄色片 | 久章操| 999视频网 | 国产精品 中文在线 | 亚洲综合干 | 国产一级视频在线免费观看 | 高清中文字幕 | av动图| 国产一区二区在线免费 | 欧美另类视频 | 精品在线观看视频 | 毛片激情永久免费 | 国产激情电影综合在线看 | 亚洲精品在线看 | 9在线观看免费高清完整版在线观看明 | 久久久久国产精品视频 | 中文字幕一区二区三区四区视频 | 亚洲精品日韩在线观看 | 欧美成人亚洲成人 | 99久久网站 | 亚洲精品视频网址 | 国产成人精品不卡 | 在线天堂中文在线资源网 | 欧美日韩电影在线播放 | 免费看国产曰批40分钟 | 99热这里只有精品国产首页 | 日本精品视频在线观看 | 国产成人精品综合久久久久99 | 国产精品大片免费观看 | 欧美久草网 | www.天天射 | 婷婷六月综合网 | 91网在线看| 中文乱码视频在线观看 | 国产精品免费视频网站 | 亚州精品成人 | 国产白浆在线观看 | 婷婷视频在线观看 | 91麻豆看国产在线紧急地址 | 成人网页在线免费观看 | 午夜视频免费 | 国产福利一区二区在线 | 激情自拍av | 日韩久久激情 | 91av小视频| 久久综合免费视频影院 | 九九国产视频 | 毛片播放网站 | 久久久午夜视频 | 精品国产99 | 成年在线观看 | 黄色片免费看 | 超级碰碰碰免费视频 | 久久爱www.| 中文字幕在线色 | 深夜免费福利网站 | 一区二区欧美在线观看 | 日韩高清av在线 | 日韩无在线 | 欧美一级片在线免费观看 | 在线视频a| 91精品国产成人 | 日韩色高清 | 97超视频| 久久影视精品 | 亚洲精品午夜国产va久久成人 | 日韩电影久久 | 欧美调教网站 | 久久久久久蜜桃一区二区 | 国产一区二区午夜 | 午夜视频在线瓜伦 | 欧美91在线| 中文在线a∨在线 | 久久久精品国产免费观看一区二区 | 中文字幕av免费在线观看 | 日韩一级电影在线观看 | 91最新在线视频 | 久久久久99精品国产片 | 狠狠躁日日躁狂躁夜夜躁av | 奇米网在线观看 | 99久久精品免费看国产一区二区三区 | 亚洲欧美成人在线 | 五月激情av | 免费国产ww| 欧美日韩国产精品一区二区三区 | 欧美一区二区免费在线观看 | 欧美 日韩 国产 中文字幕 | 国产成人精品一区一区一区 | 91视频免费播放 | 99精品在线免费 | 在线亚洲高清视频 | 97网| 国产.精品.日韩.另类.中文.在线.播放 | 青青河边草免费视频 | 一区二区三区国产精品 | 亚洲精品国产精品99久久 | 999久久 | 色婷婷www | 天堂av在线免费 | 国产在线不卡精品 | 国产精品一区二区av影院萌芽 | 国产成人久久精品77777综合 | 欧美激情第十页 | 亚洲成av人影片在线观看 | 最近中文国产在线视频 | 日韩在线观看网址 | av最新资源| 亚洲天堂色婷婷 | 国产黄色片一级 | 久久免费黄色 | 午夜 久久 tv| 欧美经典久久 | 91成人在线观看高潮 | 国语久久| 免费在线观看日韩 | 国产天天爽 | 西西444www大胆无视频 | 天天综合成人 | 天天射网 | 久久综合爱 | 国产不卡免费视频 | 特级毛片在线免费观看 | 91九色最新地址 | 高清av影院 | 91成人精品观看 | 看全黄大色黄大片 | 色丁香久久 | 成人国产电影在线观看 | 日韩免费高清 | 天天操狠狠操夜夜操 | 国产夫妻性生活自拍 | 免费试看一区 | 欧美日韩视频在线一区 | 99久久精品免费看国产一区二区三区 | 视频一区在线免费观看 | 亚洲午夜精品一区 | 国际精品久久 | 成人免费在线视频观看 | 国产综合福利在线 | 又黄又爽又色无遮挡免费 | 亚洲欧美视频在线观看 | 在线免费观看成人 | 激情小说网站亚洲综合网 | 国产精品正在播放 | 久久精品播放 | 婷婷综合激情 | 人人澡视频 | 最新中文在线视频 | 五月婷婷久久丁香 | 色av色av色av | 亚洲精品国产拍在线 | 五月婷婷丁香在线观看 | 亚洲精品中文字幕视频 | 182午夜在线观看 | 日韩精品免费一区二区在线观看 | 国产精品一区二区在线播放 | 韩国av免费在线 | 色资源网免费观看视频 | 国产成人一级 | 91精品国产综合久久久久久久 | 狠狠色丁香婷婷综合最新地址 | 中文字幕免费高清av | 日韩一级黄色片 | 97国产精品一区二区 | 麻豆久久 | 夜夜操天天摸 | 国产九九九视频 | 欧美日韩精品影院 | 天天天天干 | 视频一区二区三区视频 | 久久久www成人免费毛片麻豆 | 狠狠狠色狠狠色综合 | 国产精品一区二区三区在线播放 | 在线精品视频在线观看高清 | 草久草久 | 亚洲国内在线 | 欧美精品久久久久久久久久 | 精品国产1区2区3区 国产欧美精品在线观看 | 精品国产一区二区三区免费 | 天天干 夜夜操 | 欧美91精品久久久久国产性生爱 | 亚洲精品字幕在线观看 | 国产精品久久久久久久毛片 | 啪啪激情网 | 国产经典 欧美精品 | 成人97视频| 久久九九久久 | 手机av电影在线 | 青青久草在线视频 | 在线性视频日韩欧美 | 99精品久久99久久久久 | 日韩高清在线观看 | 美女啪啪图片 | 亚洲乱码精品久久久久 | 天天干天天拍天天操天天拍 | 国产精品一区二区视频 | 最近中文字幕视频网 | 精品久久一区二区三区 | 免费亚洲精品视频 | 久久三级毛片 | 国产精品激情在线观看 | 久草影视在线观看 | 欧美综合在线视频 | 国产高清日韩欧美 | 国产精品96久久久久久吹潮 | av黄在线播放 | 欧美在线视频a | 久久综合导航 | 久久久麻豆精品一区二区 | 91精品一区国产高清在线gif | 99色网站| 玖玖在线观看视频 | 亚洲视频免费视频 | 操久| 国产精品女同一区二区三区久久夜 | 在线播放91 | 黄色网大全 | 激情五月婷婷综合网 | 激情小说网站亚洲综合网 | 久久爽久久爽久久av东京爽 | 在线看片a| 亚洲国产成人精品电影在线观看 | 成年人免费在线播放 | 制服丝袜天堂 | 91精品爽啪蜜夜国产在线播放 | 日日摸日日添日日躁av | 亚洲永久国产精品 | 天天操人| 免费99精品国产自在在线 | 亚洲国产精品久久久久久 | 天天操天天爽天天干 | 在线免费观看国产黄色 | 最新成人av | 中文字幕免费观看视频 | 国产精品自产拍在线观看桃花 | www色,com| 18岁免费看片 | 99这里只有久久精品视频 | 亚洲视频在线观看 | 91大神精品视频在线观看 | 欧美日韩xx | 亚洲砖区区免费 | 日韩欧三级 | 亚洲国产精品电影 | 国产美女视频 | 免费亚洲婷婷 | 午夜99| 中文字幕在线播放第一页 | 少妇bbbb搡bbbb搡bbbb | 丁香婷婷激情网 | 天天插天天爱 | 四虎小视频| 人人要人人澡人人爽人人dvd | 成人网在线免费视频 | 探花国产在线 | 草久久久久| 国产日韩在线一区 | 国产精品手机在线播放 | 国产黄在线 | 免费观看版 | 美女网站视频免费都是黄 | 午夜精品久久久久久久99无限制 | av大片免费在线观看 | 中文字幕电影一区 | 久热爱| 欧美成人精品三级在线观看播放 | 久久午夜电影网 | 国产精品日韩欧美 | 999国内精品永久免费视频 | 最近高清中文在线字幕在线观看 | 久久久久免费精品国产 | 国产在线视频不卡 | 毛片网站观看 | 日本韩国精品在线 | 亚洲精品成人av在线 | 亚洲精品视频国产 | 久草在线网址 | 成年人免费在线观看网站 | 99re6热在线精品视频 | 蜜桃麻豆www久久囤产精品 | 亚洲国产97在线精品一区 | 免费国产一区二区视频 | 日本韩国在线不卡 | 亚洲精品自在在线观看 | 亚洲欧美精品在线 | 国产成人综合在线观看 | 亚洲一区日韩在线 | 亚洲欧美日韩精品久久奇米一区 | 一区二区三区久久精品 | 中文av字幕在线观看 | 香蕉影院在线播放 | 欧美一级视频在线观看 | 在线观看不卡的av | www.黄色片网站 | 亚洲综合视频在线 | 久久高清国产视频 | 在线国产小视频 | 亚洲 欧洲 国产 精品 | 国产精品色在线 | 亚洲欧美日韩精品久久奇米一区 | 国产中文字幕视频 | 国产精品久久久久久99 | 91看片在线 | 夜夜看av| 99久热在线精品 | 久久天天拍 | 国产偷在线 | 日日天天 | 免费一级片观看 | 麻豆影视网 | 最近中文字幕免费 | 天堂av在线免费观看 | 日韩网站在线免费观看 | 日韩精品一区二区三区中文字幕 | 精品中文字幕在线观看 | 国产一区二区视频在线 | 五月色丁香 | 超碰97免费在线 | 在线观看中文av | 免费观看国产成人 | 不卡电影免费在线播放一区 | 狠狠狠狠狠狠干 | 精品乱码一区二区三四区 | 精品超碰 | 欧美大jb| 五月天综合在线 | 久久久这里有精品 | 亚洲精选99 | 五月天激情综合 | 一本一本久久a久久精品综合妖精 | 亚洲成色| 婷婷五天天在线视频 | 国产午夜精品久久久久久久久久 | 久产久精国产品 | 成人毛片在线视频 | 99久久日韩精品视频免费在线观看 | 一本—道久久a久久精品蜜桃 | 国产美女在线免费观看 | 天天操狠狠干 | 99在线观看免费视频精品观看 | 一性一交视频 | av不卡免费在线观看 | 亚洲天堂香蕉 | 免费h在线观看 | 欧美 亚洲 另类 激情 另类 | 国产综合视频在线观看 | 国产一区二区影院 | 香蕉网址 | 久久久久久毛片精品免费不卡 | 亚洲精品合集 | 在线之家免费在线观看电影 | 国产精品嫩草影院99网站 | 日本韩国中文字幕 | 五月天六月婷 | 91喷水| 六月天色婷婷 | 手机版av在线 | 五月婷婷免费 | 999久久精品 | 国产一区在线免费 | 尤物一区二区三区 | 在线播放视频一区 | 久久久久久久久久国产精品 | 中文字幕在线免费观看视频 | 亚洲国产日韩av | 99 久久久久| 久久综合色婷婷 | 狠狠色丁香婷婷 | 国产一区二区三区在线免费观看 | av一级免费 | 人人艹人人| 亚洲第五色综合网 | 久久综合中文色婷婷 | 日韩一级电影网站 | 99精品偷拍视频一区二区三区 | 午夜精品久久久久99热app | 天天天干天天射天天天操 | av三级av | 麻豆 videos | 日韩激情综合 | 黄色a一级视频 | 成人在线观看日韩 | 日日操夜夜操狠狠操 | 97爱爱爱| 精品人人人人 | 国产自制av | 国产精品综合在线观看 | 国产精品麻豆一区二区三区 | 精品人人爽 | 又黄又爽又刺激视频 | 欧美人牲 | 亚洲综合欧美日韩狠狠色 | 97香蕉超级碰碰久久免费软件 | 超碰97网站 | 国产色网| 精品国产伦一区二区三区观看体验 | 黄色三级免费网址 | 国产精品久久免费看 | 亚洲jizzjizz日本少妇 | 精品国产精品一区二区夜夜嗨 | 婷婷在线网站 | 香蕉在线观看 | 精品国产一区二区三区日日嗨 | 91亚洲狠狠婷婷综合久久久 | 热久久这里只有精品 | 免费在线观看av网址 | 97视频中文字幕 | 久久在线视频精品 | 免费在线观看av网址 | 国产91在 | 99精品久久久久久久久久综合 | 日本性xxx| 欧美一级视频免费看 | 久久久久欧美精品999 | 久久久精品 | 精久久久久 | a国产精品 | 伊香蕉大综综综合久久啪 | 欧美福利视频一区 | 欧美国产不卡 | 99国产高清 | 国产成人精品一区二区三区免费 | 有码视频在线观看 | 亚洲国产精品影院 | 久久精品9 | 狠狠操狠狠插 | 成人福利av| 91精品一区国产高清在线gif | 91看片看淫黄大片 | 久久亚洲私人国产精品va | 精品亚洲欧美一区 | 成人免费电影 | 亚洲人成人99网站 | 国产成人精品一区二 | 日日夜夜精品网站 | 一区二区三区日韩在线 | 成人理论电影 | 欧美激情综合网 | 五月婷婷开心中文字幕 | 国产视频一区在线播放 | 在线成人av | 国产二区视频在线观看 | 日本性xxx| 国产黄a三级三级三级三级三级 | 久久精品亚洲精品国产欧美 | 国产亚洲无 | 91黄色在线视频 | 91视视频在线直接观看在线看网页在线看 | 激情动态| 久久精品成人欧美大片古装 | 天堂av在线免费观看 | 欧美午夜一区二区福利视频 | 国产极品尤物在线 | 精品一区二区三区在线播放 | 最近中文字幕大全中文字幕免费 | 久久精品一二三区 | av福利免费 | 九九爱免费视频在线观看 | 成人国产精品av | 国产精品a成v人在线播放 | 91在线资源 | 91精品一| 一区二区影视 | 在线中文字幕av观看 | 日韩免费视频在线观看 | 亚州中文av | 99久久久久国产精品免费 | 人人看人人 | 黄色小说18 | 色吧av色av| 久久午夜精品 | 久久这里只有精品久久 | 91.dizhi永久地址最新 | 四虎精品成人免费网站 | 久草视频视频在线播放 | 麻豆精品传媒视频 | 国产成人精品综合久久久 | 国产在线中文字幕 | 日本三级吹潮在线 | 天天插天天爱 | 精品久久久久久久久亚洲 | 人人狠狠综合久久亚洲婷 | 伊人天堂网 | 亚洲乱码精品久久久久 | 日韩美一区二区三区 | 久久婷婷国产色一区二区三区 | 欧美色噜噜噜 | 久草网在线视频 | 精品久久网 | 午夜精品999 | 一级免费片 | 中文字幕国产在线 | 91久草视频| 不卡的av在线 | 久久久麻豆精品一区二区 | 99热这里精品 | 丝袜美腿在线视频 | 欧美成人精品欧美一级乱 | 日韩欧美在线综合网 | 久久精品免费看 | 久久久久久高潮国产精品视 | 久久精品人人做人人综合老师 | 91久久爱热色涩涩 | 亚洲国产一区在线观看 | 精品美女久久久久 | 在线亚洲精品 | 500部大龄熟乱视频 欧美日本三级 | www国产亚洲精品久久网站 | 国产91在线免费视频 | 在线观看 国产 | 五月婷婷毛片 | 精品国模一区二区三区 | 欧美做受高潮 | 欧美色图视频一区 | 成年人看片| 亚洲男人天堂a | 三级av在线免费观看 | 久草在线观看视频免费 | 精品福利片 | 久久久久日本精品一区二区三区 | 久久精品免费播放 | 欧美日韩精品在线免费观看 | 最新av在线网站 | 国产视频久久久久 | 久久久久久毛片 | 色福利网 | 亚洲五月婷婷 | 狠狠色丁香久久婷婷综合五月 | 国产精品丝袜久久久久久久不卡 | 日韩在线一区二区免费 | 国产精品久久免费看 | 日韩精品免费一线在线观看 | 日韩国产精品一区 | 草久草久 | 天天干中文字幕 | 中文字幕在线免费 | 国产在线美女 | av电影一区二区三区 | 欧美国产日韩在线观看 | 国产无吗一区二区三区在线欢 | 色综合天天天天做夜夜夜夜做 | 亚洲色图 校园春色 | 久久99精品久久久久久秒播蜜臀 | 欧洲高潮三级做爰 | 操操色 | 98精品国产自产在线观看 | 97超碰在线人人 | 久久精品视频3 | 99久久99久久 | 天天干干 | 奇米影视在线99精品 | 国产护士av | 激情五月***国产精品 | 久久久精品久久日韩一区综合 | 国产高清成人av | 国产涩图 | 日韩在线观看你懂的 | 国产亚洲精品久久久久久久久久久久 | 人人澡人摸人人添学生av | 女女av在线 | 国内偷拍精品视频 | 国产亚洲精品bv在线观看 | 日韩精品免费一线在线观看 | 中文字幕第一页在线视频 | 久久国产精品一国产精品 | www.香蕉 | 欧美九九九 | 91人人插| 福利一区二区三区四区 | 亚洲永久精品国产 | 精品一区二区在线观看 | 欧美精品久久久久久久免费 | 国产99在线免费 | 久久精品在线 | 久久精精品视频 | 日韩欧美在线国产 | 丁香激情五月 | 日本性久久 | 麻豆视频在线免费 | 青春草视频 | 欧美精品久久久久久久久久 | 日本在线观看视频一区 | 日韩欧美精品在线观看 | 在线播放 一区 | 国产黄色片在线免费观看 | 精品嫩模福利一区二区蜜臀 | 久草视频免费观 | 17婷婷久久www| 欧美另类xxx| av一级免费 |