日韩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架构和源码的全部內容,希望文章能夠幫你解決所遇到的問題。

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

一级a毛片高清视频 | 亚洲自拍自偷 | av在线a| 探花国产在线 | 亚洲片在线资源 | 91av在线国产| 国产精品黑丝在线观看 | 91视频国产免费 | 久久在线免费观看视频 | 天天做天天爱夜夜爽 | 天天夜操 | 欧美精品视 | 黄色tv视频| 国产国语在线 | 国内精品亚洲 | 黄色大片日本免费大片 | 国产一区二区三区高清播放 | 亚洲蜜桃在线 | aaa日本高清在线播放免费观看 | 国产一级二级在线观看 | 在线精品国产 | 超碰日韩| 婷婷久月| 日日操网站| 中文一二区 | 婷婷在线免费 | 成人永久在线 | av在线com| 麻豆国产视频下载 | 精品福利在线视频 | 激情视频网页 | av中文字幕剧情 | 日韩精品一区在线播放 | av成人动漫 | 欧美激情另类 | 国产视频日韩 | 亚洲视频免费视频 | 天天综合成人网 | 伊人天天 | 久久久久久免费视频 | 久久精久久精 | 午夜精品婷婷 | 久久精品电影院 | 国产在线 一区二区三区 | 国产第页 | 欧美中文字幕第一页 | 中文字幕免费播放 | 国产成人精品一区二 | av电影在线免费观看 | 欧美俄罗斯性视频 | 色狠狠久久av五月综合 | av高清不卡 | 国产 欧美 日本 | 综合色影院 | 人人玩人人添人人澡97 | 亚洲伦理一区二区 | 欧美一区二区三区在线 | 91九色视频在线播放 | 久久久亚洲精华液 | 亚洲国产丝袜在线观看 | 精品欧美小视频在线观看 | 欧美一级专区免费大片 | 亚洲片在线资源 | 久久这里只有精品视频首页 | 中文字幕免费观看全部电影 | 国产69精品久久久久9999apgf | 日韩电影在线一区二区 | 久草在线观 | 国产精品一二 | 又紧又大又爽精品一区二区 | 久久精品5 | 黄色大全免费观看 | 色视频网址 | 欧美国产一区在线 | 日本在线精品视频 | 久久免费国产精品1 | 激情五月伊人 | 国产精品久久久久一区二区三区 | 国产日韩精品一区二区在线观看播放 | 国产精品 日韩 欧美 | 蜜臀久久99精品久久久久久网站 | 在线免费观看视频一区二区三区 | 91激情视频在线 | 正在播放 国产精品 | 久久天天躁夜夜躁狠狠躁2022 | 亚洲黄色一级视频 | 亚洲精品国产精品国自产在线 | 天天拍天天草 | 中文国产在线观看 | 在线观看av国产 | 国产精品久久久久久久免费观看 | 欧美日韩久 | 黄色大片网| 欧美日韩国产一二三区 | 99视频这里只有 | 亚洲色图 校园春色 | 国产免费成人av | 91麻豆操 | 麻豆视频免费入口 | 波多野结衣在线视频一区 | 97偷拍视频 | 成人免费av电影 | 色免费在线 | 狠狠干网站| 精品99在线视频 | 亚洲国产中文字幕在线 | 久草.com| 黄色大片免费播放 | 日韩欧美高清 | 在线精品视频免费播放 | 911国产在线观看 | 久久久久国产一区二区三区四区 | 中文字幕超清在线免费 | 91av电影在线 | 日韩欧美在线第一页 | 欧美嫩草影院 | 久久伊人91 | 亚洲欧美日韩在线看 | 啪啪免费试看 | 国产精品一区久久久久 | 天天色成人 | 久久成人免费 | 青青河边草观看完整版高清 | 日韩性xxxx| 欧美日韩国产精品一区 | 夜夜操网站| 欧美一二区在线 | 日本精品一区二区三区在线观看 | 日韩三级在线 | 天天曰天天射 | 欧美日韩18 | 精品久久久久久国产 | 91成熟丰满女人少妇 | 在线看一区 | 日韩激情av在线 | 久久久久久久国产精品影院 | 国产黄在线 | 精品久久久精品 | 国产麻豆电影在线观看 | 久草在线免费资源 | 天天操天天操天天操天天 | 国产高清精品在线观看 | 在线免费观看国产精品 | 99精品网站 | 亚洲欧洲中文日韩久久av乱码 | 视频一区在线播放 | 亚洲国产精品女人久久久 | 国产精品久久久久久久久久久免费看 | 91九色在线视频观看 | 蜜臀av性久久久久av蜜臀三区 | 欧美一二三区在线观看 | 亚洲一区日韩精品 | 婷婷亚洲综合五月天小说 | 激情文学综合丁香 | 粉嫩高清一区二区三区 | 成人羞羞免费 | 国产亚洲精品女人久久久久久 | 天天操夜夜摸 | 久久噜噜少妇网站 | 国产偷国产偷亚洲清高 | 亚洲精品一区中文字幕乱码 | 国产精品久久99综合免费观看尤物 | 狠狠的操 | 久久黄网站| 麻豆传媒电影在线观看 | 九九99 | 波多野结衣精品在线 | 久草精品在线观看 | 久久免费大片 | 日日色综合 | 国产四虎在线 | 在线 国产 日韩 | 亚洲男模gay裸体gay | 992tv在线观看 | 国产精品一区在线 | 国产亚州精品视频 | www.超碰 | 亚洲经典中文字幕 | 亚洲精品观看 | 国产一区二区三区高清播放 | 久久久久一区二区三区四区 | wwwav视频 | 国产一区二区三区午夜 | 日韩精品一区二区不卡 | 欧美日韩国产综合网 | 久久人人爽人人爽 | 亚洲精品男女 | 热99久久精品 | 国产午夜视频在线观看 | 不卡av电影在线 | 精品国产免费看 | 日韩一区二区三区高清在线观看 | av网站有哪些 | 中文字幕视频观看 | 在线观看涩涩 | 国产中文字幕一区二区三区 | 99精品在线播放 | 亚洲成熟女人毛片在线 | 成年在线观看 | 国产在线观看免费观看 | 久久婷婷影视 | 2000xxx影视| 国产 日韩 中文字幕 | 久久午夜精品视频 | 开心综合网 | 蜜桃视频日本 | 夜夜婷婷 | 免费日韩三级 | 国产一区二区在线免费播放 | 91亚瑟视频 | 色91在线视频 | 亚洲精品久久久蜜桃直播 | 日韩在线欧美在线 | 国产精品女主播一区二区三区 | 亚洲无吗av | 亚洲 欧美 综合 在线 精品 | 精品美女视频 | 免费视频a | 偷拍视频一区 | 久久不射影院 | 日韩激情视频在线 | 久久一区国产 | a在线一区 | 成人午夜电影网 | 天天天天爽 | 深夜免费小视频 | 91九色视频在线观看 | 国产第一页在线播放 | 亚洲涩综合| 中文字幕乱码在线播放 | 手机av电影在线 | 91精品国产自产在线观看永久 | 中日韩三级视频 | 久久国产精品免费一区二区三区 | av黄色亚洲 | 91免费看片黄 | 国产露脸91国语对白 | 一本一道久久a久久精品 | 欧美性生活一级片 | 久操视频在线免费看 | 国产精品免费成人 | 欧美日韩免费观看一区二区三区 | 天天操天天操天天操天天操天天操 | 国产成人一区二区精品非洲 | 久久a级片 | 日韩高清 一区 | 亚洲精品国产精品国 | 久久99久久99精品免视看婷婷 | 91麻豆精品国产自产 | 国产黄色大片 | av色网站| 天天射天天色天天干 | 伊人午夜 | 97人人澡人人添人人爽超碰 | 国产精品剧情 | 草久草久 | 欧美日韩在线观看一区二区 | 91九色蝌蚪视频在线 | 中文字幕色播 | 欧美精品乱码久久久久 | 成人小视频在线 | 97视频在线观看播放 | 久久久污| 中文字幕免费高清av | 999久久久久久久久久久 | 国产精品一区二区三区在线播放 | 日韩成人在线一区二区 | 丁香高清视频在线看看 | 国产日韩精品一区二区在线观看播放 | 一区二区毛片 | 亚洲一区黄色 | 免费在线精品视频 | 最新av网址在线观看 | 免费观看的黄色片 | 婷婷在线不卡 | 六月丁香在线视频 | 欧美日韩在线看 | 免费a视频在线 | 99久国产 | 国产精品午夜免费福利视频 | 国产精品99视频 | 香蕉影院在线 | 欧美精品免费在线观看 | 婷婷色狠狠 | 中文字幕人成不卡一区 | 久操免费视频 | 天天做天天爱夜夜爽 | 天天射综合 | 三级av免费看 | 91传媒免费观看 | 三级视频国产 | 久久电影网站中文字幕 | 亚洲一级在线观看 | 日本中文字幕在线一区 | 日韩极品在线 | 久久www免费人成看片高清 | 久久热首页 | 天堂网在线视频 | 免费看三级黄色片 | 欧美日韩国产mv | 丁香婷婷深情五月亚洲 | 久久手机精品视频 | 国产一区免费视频 | 久久五月婷婷综合 | 欧美日韩精品综合 | 亚洲欧美在线综合 | 国产综合激情 | 国产一级片免费视频 | 久久久久国产成人免费精品免费 | 日本黄色大片免费 | 伊人首页 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产自产在线视频 | 免费的成人av | 日日夜夜综合 | 中文字幕av在线电影 | 亚洲精品视频在线观看免费 | 欧美性做爰猛烈叫床潮 | 国产精品自在欧美一区 | 日韩一级黄色av | 97激情影院| 亚洲精品天天 | 午夜av电影院 | 日日夜夜天天久久 | 色婷婷激情四射 | 日日干天天射 | 又黄又爽免费视频 | 五月天婷婷免费视频 | 久久久久在线 | 81精品国产乱码久久久久久 | 六月丁香六月婷婷 | 人人草人人草 | 久久综合九色综合久99 | 一级黄色免费网站 | 97在线观看视频免费 | 国产中文在线播放 | 国产精品综合在线观看 | 日韩乱理| 香蕉视频国产在线观看 | 98涩涩国产露脸精品国产网 | 香蕉网在线 | 国产精品区二区三区日本 | 久久久国产网站 | 日韩免费电影一区二区 | 国内精品久久久久久久久久 | 亚洲午夜精品久久久久久久久久久久 | 五月天六月色 | 天天天操天天天干 | 国产精品成人a免费观看 | 91中文字幕一区 | 国产破处在线视频 | 国产精品久久久久久爽爽爽 | 九九热在线视频免费观看 | 三级毛片视频 | 亚洲另类视频在线 | 最近免费中文字幕 | 91精品久久久久久久久久入口 | 天堂va在线高清一区 | 欧美在线视频不卡 | 婷婷av在线 | jizz18欧美18 | 久久久久国产精品厨房 | 最近中文字幕大全中文字幕免费 | 久久99久久99精品免费看小说 | 亚洲国产字幕 | 亚洲成人中文在线 | 在线 成人 | 亚洲精品久久久蜜桃 | 精品国产1区 | 黄色avwww| 最近免费中文字幕mv在线视频3 | 午夜久久久精品 | 91久久精品一区二区三区 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产一区二区三精品久久久无广告 | 免费中文字幕在线观看 | 日韩在线视频免费看 | 精品国自产在线观看 | 国产一级电影 | 中文字幕制服丝袜av久久 | 国产精品久久久久久久久久免费看 | 天天色天天射天天操 | 久久国产免 | 91大神电影 | 亚洲高清网站 | 国精产品999国精产品岳 | 国产视频精品视频 | 麻豆免费视频 | 精品国产乱码久久久久久浪潮 | 亚洲aⅴ在线观看 | 热久久精品在线 | 狠狠伊人| 黄色在线观看www | 国产精品久久久久aaaa | 西西www4444大胆在线 | 日本mv大片欧洲mv大片 | 亚洲激情校园春色 | 久久成人高清 | 日韩a在线 | 午夜国产在线 | 日本久久精 | 久久精品系列 | 我要色综合天天 | 久操视频在线 | 国产中文字幕三区 | 亚洲天天在线日亚洲洲精 | 国产91综合一区在线观看 | 国产精品99久久久久久大便 | 在线视频一二三 | 69亚洲视频 | 亚洲黄色片 | 国产成人精品久久亚洲高清不卡 | 黄色软件在线观看免费 | 久久丁香| 国产精品一区二区三区99 | 国产高清在线 | 国产h片在线观看 | 欧美国产高清 | 精品久久久久久久久久久久久久久久久久 | 天天综合色网 | 91在线精品一区二区 | 国产96在线 | 视频在线一区二区三区 | 免费av片在线 | 欧美a级成人淫片免费看 | 婷婷色综合色 | 女人高潮特级毛片 | 在线观看免费黄视频 | 日本一区二区不卡高清 | 婷婷av综合 | 日本在线成人 | 最新av在线免费观看 | 亚洲午夜不卡 | 成人在线视频免费观看 | 精品欧美一区二区三区久久久 | 激情开心色 | 日本成人中文字幕在线观看 | 美女网站黄免费 | 国产午夜在线 | 中文字幕日韩精品有码视频 | 精品一二| 精品亚洲va在线va天堂资源站 | 日韩在线免费播放 | 亚洲精选视频免费看 | 色av男人的天堂免费在线 | 日韩精品免费在线视频 | 国产在线视频导航 | 久热国产视频 | 日韩电影在线观看中文字幕 | 狠狠久久综合 | 久久成电影 | 五月网婷婷 | av大全在线播放 | 国产一级片不卡 | 黄色免费在线视频 | 全久久久久久久久久久电影 | 欧美成人精品欧美一级乱黄 | 亚洲一区二区精品 | 色av资源网 | 黄色在线观看免费网站 | 一区中文字幕在线观看 | 精品久久久999 | 欧美亚洲久久 | 国产精品久久久久久久久久免费 | 中文字幕一区二区三区在线播放 | 午夜天使 | 日韩中文在线视频 | 91av在线免费视频 | av高清免费在线 | 97精品一区二区三区 | 成人久久 | 亚洲欧美成人综合 | 婷婷丁香av | 精品久久在线 | 亚洲国产成人av网 | 亚洲视频在线观看 | 欧美午夜久久 | 国产精品久久电影网 | 人人澡超碰碰97碰碰碰软件 | 国产精品 日韩 欧美 | 99久热精品 | 天天激情综合网 | 中文字幕在线看视频国产 | 亚洲精品黄色 | 欧美色噜噜噜 | www.夜色321.com | 成人免费看黄 | 成在线播放 | 国产一区二区免费看 | 五月天久久激情 | 国产精品18p| 91九色视频在线观看 | 最近日本中文字幕a | 亚洲综合在线视频 | 在线v| a一片一级 | 日本精品久久久久中文字幕5 | 夜添久久精品亚洲国产精品 | 日批视频国产 | 国际精品久久久 | 日韩在线播放视频 | 亚洲成年片 | 久久电影日韩 | 国产亚洲在线观看 | 中文字幕在线观看播放 | 欧美一区成人 | 国产在线观看国语版免费 | 国产色资源 | 涩涩资源网| 日韩高清在线一区二区 | 成人97视频一区二区 | 五月天狠狠操 | 911亚洲精品第一 | 色婷婷播放 | 欧美激情视频久久 | 天堂av在线免费观看 | 激情一区二区三区欧美 | 激情综合中文娱乐网 | 六月激情久久 | 天天天天爱天天躁 | 日韩在线观看视频中文字幕 | 婷婷激情影院 | 91成人免费观看视频 | 亚洲一区二区黄色 | 精品国产电影 | 97在线观看视频免费 | 最近中文字幕大全 | 精品久久久久久国产 | 丁香五婷 | 成人国产精品av | 五月天综合网 | 久久精品五月 | 97超碰人人澡人人爱 | 久久精品91久久久久久再现 | 91探花视频 | 精品国产区在线 | 国产精品女 | 久久久久久久久久免费 | 亚洲九九爱 | 国产精品免费观看国产网曝瓜 | 婷色在线 | 久久99精品国产麻豆婷婷 | 亚洲午夜小视频 | 亚洲成免费 | 91一区啪爱嗯打偷拍欧美 | 日韩视频在线一区 | 午夜av免费| 97成人在线 | 精品视频免费播放 | 九九热免费在线视频 | 精品免费久久 | 欧美日韩aa| 久久精品屋 | 亚洲第一区在线播放 | 欧美另类美少妇69xxxx | 久久网站免费 | 日韩欧美精品在线 | 亚洲一区在线看 | 久久国产免 | 日本丶国产丶欧美色综合 | 444av| 亚洲免费成人av电影 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 91av大全 | 韩日电影在线 | 成人免费一区二区三区在线观看 | 狠狠色狠狠色综合日日小说 | 中文字幕美女免费在线 | 久久av在线播放 | 中文av字幕在线观看 | 亚洲高清精品在线 | 欧美调教网站 | www色com| 亚洲草视频 | 久草在线一免费新视频 | 国产精品尤物 | 欧美成人精品xxx | 干av在线 | 在线观看视频日韩 | 久久精品毛片基地 | 精品国产一区二区三区男人吃奶 | 最新中文在线视频 | 精品v亚洲v欧美v高清v | 亚洲国产精品久久 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 婷婷中文字幕 | 国产黄a三级三级三级三级三级 | 日韩亚洲在线视频 | 在线观看国产日韩 | 99精品国产一区二区三区不卡 | 国产成人久久av免费高清密臂 | 久久九精品| 日韩大片在线免费观看 | 精品久久久久久久久久久久久久久久 | 中文字幕日本在线观看 | 亚洲国产精品一区二区久久hs | 五月婷婷视频在线 | 欧美午夜精品久久久久 | 96视频免费在线观看 | 天天av综合网 | 国产精品69久久久久 | 日韩精品免费在线播放 | 国内成人精品2018免费看 | 久久久久麻豆v国产 | 草久在线观看 | 蜜臀av免费一区二区三区 | 日韩在线免费小视频 | 国产午夜视频在线观看 | 在线免费观看的av网站 | avove黑丝| 免费看国产黄色 | 日韩精品91偷拍在线观看 | 国产亚洲视频中文字幕视频 | 久久美女免费视频 | 亚洲精品一区二区18漫画 | 成人在线观看av | 中文字幕在线观看视频一区二区三区 | 国产精品久久久av久久久 | 国产精品电影一区二区 | 激情久久久久 | 亚洲免费a | 亚洲va综合va国产va中文 | 欧美成人影音 | 欧美日韩国产欧美 | 亚洲va欧美va国产va黑人 | 亚洲一二三区精品 | 日韩电影在线一区 | 成人在线免费视频观看 | 欧美精品成人在线 | 国产精品欧美一区二区 | 在线观看视频在线观看 | 黄色成人毛片 | 国产乱码精品一区二区三区介绍 | 国产91欧美 | 成人一区影院 | 午夜精品电影一区二区在线 | 久久婷婷五月综合色丁香 | 精品一区二区免费 | 91精品在线免费观看视频 | 国产成人在线免费观看 | av一本久道久久波多野结衣 | 免费网址你懂的 | 一区二精品 | 狠狠色婷婷丁香六月 | 综合激情久久 | 国产又粗又硬又爽视频 | 久久综合久久综合这里只有精品 | av网站免费看 | 亚州欧美视频 | 国产精品入口麻豆 | 国产精品午夜久久 | 男女全黄一级一级高潮免费看 | 日本不卡久久 | 美女免费视频一区二区 | 在线观看视频精品 | 日韩精品久久久久久久电影竹菊 | 在线有码中文字幕 | 91在线播放综合 | 少妇bbw揉bbb欧美 | 人人插人人射 | www亚洲精品| 国产精品久久久久久超碰 | 国产精品免费麻豆入口 | 久草视频在线看 | 亚洲精品456在线播放 | 97视频在线观看播放 | 国产视频不卡一区 | 成人在线观看免费 | 日本中文字幕网址 | 日日干av| 国产精品va视频 | 99视频在线免费 | 日韩a级黄色 | 永久免费的av电影 | 九九九在线观看视频 | 日韩精品一区二区不卡 | 天天色.com | 亚洲成人999| 久久黄色a级片 | 在线看片中文字幕 | 人人藻人人澡人人爽 | 国产精品手机看片 | av综合 日韩 | 久久成电影 | 在线观看深夜视频 | 国产高清视频色在线www | www.黄色网.com | 五月婷网 | 日韩a在线观看 | 亚洲精品456在线播放 | 国产精品精品久久久久久 | 婷婷精品国产欧美精品亚洲人人爽 | 天天舔天天搞 | 伊人婷婷综合 | 午夜影视一区 | 一级欧美日韩 | 久久久久亚洲精品 | 久色婷婷 | 国产精品区在线观看 | 欧美福利片在线观看 | 2023国产精品自产拍在线观看 | 91人人爽人人爽人人精88v | 亚洲精品乱码久久久久v最新版 | 久久人人爽人人人人片 | 国产一区二区三区高清播放 | 欧美成人在线免费观看 | 欧美性生活免费看 | 国产亚洲精品久久久久久无几年桃 | 日韩免费精品 | 探花视频在线版播放免费观看 | 黄色av播放| 久久精品视频在线看 | 久久久久久福利 | 高清av免费一区中文字幕 | 国产人成一区二区三区影院 | 成人国产综合 | 国产精品99久久久久久武松影视 | 久久精品久久久久 | 日韩色综合网 | 欧美一级视频一区 | 国产小视频在线看 | 激情图片qvod | 涩涩网站在线观看 | 色婷婷狠狠五月综合天色拍 | 日日夜夜草 | 亚洲天堂网在线观看视频 | 特级西西www44高清大胆图片 | 婷婷久久一区 | 色综合亚洲精品激情狠狠 | 欧洲av在线| 精品一区二区日韩 | 成年人在线电影 | 国产精品一区二区久久精品 | 日日干夜夜骑 | 免费看日韩片 | 亚洲精品乱码久久久久久蜜桃动漫 | 国产精品 美女 | 蜜臀aⅴ国产精品久久久国产 | 在线观看成年人 | 国产美女精品在线 | 亚洲黑丝少妇 | 国产乱码精品一区二区三区介绍 | 四虎影视www | 日韩精品在线观看视频 | 久久久精品久久日韩一区综合 | 国产黑丝一区二区 | 国产高清视频在线播放一区 | 色网站免费在线观看 | 国产精品www | 亚洲国产精品久久久 | 欧美日韩国产色综合一二三四 | 久久9999久久免费精品国产 | 99亚洲国产 | 五月天.com| 免费中文字幕在线观看 | 91精品视频观看 | 久久久久高清 | 精品视频123区在线观看 | 99热免费在线 | 国产精品日韩久久久久 | 4438全国亚洲精品在线观看视频 | 精品五月天 | 久久免费视频播放 | 国产日韩在线播放 | 九九久久国产 | 中文字幕无吗 | 免费黄在线观看 | 国产精品免费一区二区三区 | 亚洲人视频在线 | 国产成人av免费在线观看 | 四虎成人免费影院 | 国产一区精品在线观看 | 夜夜夜 | 中文字幕欧美激情 | 天天色天天射天天综合网 | 日韩精品在线视频免费观看 | 日日干天天射 | 久久视频99 | 免费观看不卡av | 少妇bbbb | 久久久精品日本 | 国产一区91 | 四虎国产精品成人免费影视 | 久久免费一 | 91色在线观看 | 91成版人在线观看入口 | 国产在线观看中文字幕 | 91在线成人 | 91丨九色丨91啦蝌蚪老版 | 五月天色丁香 | 色综合久久久久久久 | 99精品视频免费看 | 韩日精品在线 | 国产成人精品一区二区三区免费 | 开心激情综合网 | 亚洲一级久久 | 欧美人牲 | 久艹视频在线免费观看 | 欧美激情精品久久久久久 | 深夜免费小视频 | 国产一二区免费视频 | 国产成人在线免费观看 | 99久久电影| 日韩免费在线看 | 日韩一区二区三区在线看 | 亚洲精品中文字幕在线观看 | 精品视频资源站 | 手机在线中文字幕 | 丝袜制服天堂 | 国产精品久久久久影院日本 | 亚洲春色综合另类校园电影 | 婷婷视频在线观看 | 98超碰在线 | 国产精品嫩草影院9 | 欧美在线视频不卡 | 亚洲第一色 | 婷婷在线免费视频 | 日本精品久久久久中文字幕5 | www.xxxx欧美 | 国产一区精品在线观看 | 深爱婷婷 | 色婷婷激情网 | 成人一区不卡 | 久久日本视频 | 精品久久久久久亚洲 | 91在线视频免费91 | 国产午夜精品福利视频 | 夜夜爽天天爽 | 免费av看片 | 91探花系列在线播放 | 视频在线播放国产 | 91成人在线观看喷潮 | 成人av在线播放网站 | 亚洲精品男人的天堂 | 国产亚洲高清视频 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 色婷婷激情电影 | 天天操操| 国产女人40精品一区毛片视频 | 成年美女黄网站色大片免费看 | 国产一区二区久久精品 | 香蕉97视频观看在线观看 | 久草在线视频网 | 色小说在线| 色九九在线| 日韩视频免费在线观看 | 香蕉影视在线观看 | 亚洲精品视频在线观看网站 | 欧美淫aaa免费观看 日韩激情免费视频 | 欧美日韩中文在线 | 欧美亚洲国产一卡 | 二区三区在线视频 | 成人黄色电影视频 | 日本在线观看一区 | 青草草在线| 亚洲精品一区二区三区新线路 | 狠狠色丁香 | 久久久久久久精 | 免费网站看av片 | 国产淫a| 人人爽人人爽人人片av免 | 开心激情综合网 | 99久久婷婷国产一区二区三区 | 色资源网免费观看视频 | 国产一二三在线视频 | 久久久久久久福利 | 久久99九九99精品 | 亚洲人成网站精品片在线观看 | 黄色成人小视频 | 亚洲黄色高清 | 精品免费国产一区二区三区四区 | 国产一区二区视频在线播放 | 亚洲免费成人 | 日本黄色一级电影 | 国产在线色视频 | 久久99国产视频 | 天天天干 | 国产在线观看高清视频 | 偷拍福利视频一区二区三区 | 在线a视频免费观看 | 久99久视频 | 久久久国产一区二区三区四区小说 | 色网址99 | 日韩欧美精品一区 | 香蕉久久久久久久 | 中文字幕制服丝袜av久久 | www视频在线免费观看 | 狠狠色丁香久久婷婷综合_中 | 日韩日韩日韩日韩 | 97视频在线观看视频免费视频 | 成人免费视频网站 | 波多野结衣视频一区 | 免费看的国产视频网站 | 欧美中文字幕久久 | 国产美女搞久久 | 天天操天天艹 | 最新日本中文字幕 | 一区二区三区久久精品 | 亚洲综合射 | 久久不卡电影 | 精品久久一级片 | 日韩免费一级a毛片在线播放一级 | 日韩欧美在线不卡 | 精品久久久久久国产偷窥 | 久久精品成人热国产成 | 黄色成人av | 成年人看片 | www日日| 久久精品a | 四虎5151久久欧美毛片 | www.伊人色.com | 18国产精品白浆在线观看免费 | 最新日本中文字幕 | 91九色精品国产 | 亚洲在线视频免费观看 | 99久久婷婷 | 日本3级在线观看 | 国产69精品久久久久99 | 成人免费av电影 | 香蕉国产91 | 91免费日韩 | 国产小视频你懂的在线 | 看毛片网站 | 日日添夜夜添 | 91超在线| 久久视频在线免费观看 | 久久久黄视频 | 精品国产理论 | 国产精品久久免费看 | 国产一区二区三区在线 | 成人a在线观看高清电影 | 91在线视频精品 | 亚洲国产成人在线播放 | 国产精品久久久久久av | 婷婷婷国产在线视频 | 视频在线观看入口黄最新永久免费国产 | 在线观看的a站 | 99视频在线免费观看 | 日本在线免费看 | 99视频免费 | 中文日韩在线 | 日日射av| 日日干天天操 | av超碰在线 | 日产av在线播放 | 日韩av一区二区在线播放 | 91免费观看 | 国产精品18videosex性欧美 | 婷婷狠狠操 | 人人爽人人爽人人片av | 亚州精品在线视频 | 国产精品久久久久久欧美 | 国产精品视频最多的网站 | 成年人三级网站 | 欧美成天堂网地址 | 国产黄色一级片在线 | 久久艹艹 | 新版资源中文在线观看 | 久久久久免费网 | 国产美腿白丝袜足在线av | 四虎www. | 欧美日韩视频在线观看一区二区 | 国产精品视频最多的网站 | 丁香六月中文字幕 | 日韩中文在线电影 | 激情视频免费在线观看 | 久久有精品 | 天天射天天干天天 | 日韩av免费一区二区 | 视频在线亚洲 | 一本—道久久a久久精品蜜桃 | 国产精品国产三级国产aⅴ入口 | 日韩精品在线一区 | 欧美另类老妇 | 在线精品视频免费播放 | 亚洲视频精品在线 | 亚洲精品午夜久久久久久久久久久 | 日韩精品在线一区 | 激情久久久久 | 麻豆你懂的 | 精品国产1区 | 久久久久久麻豆 | 国产成人精品久久久 | 黄污网站在线 | 天天做天天射 | 天天操狠狠操夜夜操 | 黄色app网站在线观看 | 国产精品久久99综合免费观看尤物 | 成人a视频片观看免费 | 精品国产免费人成在线观看 | 欧美综合在线视频 | 五月天六月丁香 | 亚洲精品免费视频 | 久久99精品国产99久久 | 久久久精品日本 | 综合视频在线 | aaa黄色毛片 | 伊人资源站 |