国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

mybatis-plus攔截器、字段填充器、類型處理器、表名替換、SqlInjector(聯(lián)合主鍵處理)

 更新時(shí)間:2021年11月09日 08:52:05   作者:LL小蝸牛  
本文主要介紹了mybatis-plus攔截器、字段填充器、類型處理器、表名替換、SqlInjector(聯(lián)合主鍵處理),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

最近有個(gè)練手的小例子,大概就是配置兩個(gè)數(shù)據(jù)源,從一個(gè)數(shù)據(jù)源讀取數(shù)據(jù)寫到另一個(gè)數(shù)據(jù)源,雖然最后做了出來,但是不支持事務(wù)。。。就當(dāng)是對mybatis-plus/mybatis組件使用方式的記錄吧,本次例子使用的仍是mybatis-plus

回憶一下mybatis核心對象:

  • Configuration 初始化基礎(chǔ)配置,比如MyBatis的別名等,一些重要的類型對象,如,插件,映射器,ObjectFactory和typeHandler對象,MyBatis所有的配置信息都維持在Configuration對象之中
  • SqlSessionFactory SqlSession工廠
  • SqlSession 作為MyBatis工作的主要頂層API,表示和數(shù)據(jù)庫交互的會話,完成必要數(shù)據(jù)庫增刪改查功能
  • Executor MyBatis執(zhí)行器,是MyBatis 調(diào)度的核心,負(fù)責(zé)SQL語句的生成和查詢緩存的維護(hù)
  • StatementHandler 封裝了JDBC Statement操作,負(fù)責(zé)對JDBC statement 的操作,如設(shè)置參數(shù)、將Statement結(jié)果集轉(zhuǎn)換成List集合。
  • ParameterHandler 負(fù)責(zé)對用戶傳遞的參數(shù)轉(zhuǎn)換成JDBC Statement 所需要的參數(shù),
  • ResultSetHandler 負(fù)責(zé)將JDBC返回的ResultSet結(jié)果集對象轉(zhuǎn)換成List類型的集合;
  • TypeHandler 負(fù)責(zé)java數(shù)據(jù)類型和jdbc數(shù)據(jù)類型之間的映射和轉(zhuǎn)換
  • MappedStatement MappedStatement維護(hù)了一條<select|update|delete|insert>節(jié)點(diǎn)的封裝,
  • SqlSource 負(fù)責(zé)根據(jù)用戶傳遞的parameterObject,動(dòng)態(tài)地生成SQL語句,將信息封裝到BoundSql對象中,并返回
  • BoundSql 表示動(dòng)態(tài)生成的SQL語句以及相應(yīng)的參數(shù)信息

組件介紹

攔截器

mybatis可以在執(zhí)行語句的過程中對特定對象進(jìn)行攔截調(diào)用,主要有四個(gè)

  • Executor (update, query, flushStatements, commit, rollback, getTransaction, close, isClosed) 處理增刪改查
  • ParameterHandler (getParameterObject, setParameters) 設(shè)置預(yù)編譯參數(shù)
  • ResultSetHandler (handleResultSets, handleOutputParameters) 處理結(jié)果
  • StatementHandler (prepare, parameterize, batch, update, query) 處理sql預(yù)編譯,設(shè)置參數(shù)

這四個(gè)是可以攔截的對象,大概的做法是實(shí)現(xiàn)mybatis攔截器的接口并在上面添加注解來確定攔截那些方法

下面是接口Interceptor所要實(shí)現(xiàn)的方法,setPropertites可以用來初始化,而plugin則包裝目標(biāo)對象供攔截器處理,基于動(dòng)態(tài)代理實(shí)現(xiàn),Plugin類是動(dòng)態(tài)代理類,對實(shí)現(xiàn)Interceptor的接口的類進(jìn)行處理,而實(shí)現(xiàn)的攔截器會被加入到攔截器鏈進(jìn)行處理

 Object intercept(Invocation var1) throws Throwable;
 
    default Object plugin(Object target) {
        return Plugin.wrap(target, this);
    }
 
    default void setProperties(Properties properties) {
    }

plugin.warp方法

攔截器鏈:

public class InterceptorChain {
    private final List<Interceptor> interceptors = new ArrayList();
 
    public InterceptorChain() {
    }
 
    public Object pluginAll(Object target) {
        Interceptor interceptor;
        for(Iterator var2 = this.interceptors.iterator(); var2.hasNext(); target = interceptor.plugin(target)) {
            interceptor = (Interceptor)var2.next();
        }
 
        return target;
    }
 
    public void addInterceptor(Interceptor interceptor) {
        this.interceptors.add(interceptor);
    }
 
    public List<Interceptor> getInterceptors() {
        return Collections.unmodifiableList(this.interceptors);
    }
}

并在handler里面添加這些攔截器類,執(zhí)行pluginAll方法,返回一個(gè)經(jīng)過代理鏈處理的對象

實(shí)現(xiàn)該接口以后,要添加注解來表明攔截哪些方法,方法則是上面四個(gè)對象的擁有的方法。下面這個(gè)注解則是指定了攔截哪些對象的哪個(gè)方法,args則是被攔截方法的參數(shù)

public @interface Signature {
    Class<?> type();
 
    String method();
 
    Class<?>[] args();
}

比如這個(gè)例子

        @Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class})

Signature注解就對應(yīng)上面的接口、方法及其參數(shù),然后在攔截器添加一個(gè)@Intercepts,這個(gè)注解的內(nèi)容是Signature注解數(shù)組

有了攔截器,初步想法是根據(jù)方法攔截,如果select則使用讀數(shù)據(jù)源,增刪改則使用寫數(shù)據(jù)源,這個(gè)其實(shí)原理和之前寫的一篇代碼級別讀寫分離很相似,也是通過ThreadLocal存放當(dāng)前線程的數(shù)據(jù)源,然后通過攔截器來判斷用哪個(gè)數(shù)據(jù)源,交由AbstarctRoutingDataSource來根據(jù)ThreadLoacl里面的值來處理。

但是有個(gè)問題,兩個(gè)數(shù)據(jù)源轉(zhuǎn)換,表名、字段名不一定相等,比如從pgsql的一個(gè)叫user_info表里的數(shù)據(jù)轉(zhuǎn)到mysql叫user表的數(shù)據(jù),字段名都不相同

我的處理方法是查詢對象的目標(biāo)的字段名為準(zhǔn),然后給每個(gè)字段一個(gè)注解指向修改對象的數(shù)據(jù)源表字段名,如果查詢目標(biāo)表沒有插入目標(biāo)表的字段,便在select的時(shí)候默認(rèn)select null或者用代碼限定查詢的字段。這里首先先定義了三個(gè)注解,分別對應(yīng)查、改相應(yīng)的數(shù)據(jù)源、表名、字段

@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface TranDB {
    DBType from();
    DBType to();
    Class object();
}
 
public @interface TranField {
    String from() default "";
 
    String to();
 
    String empty = "null";
}
 
public @interface TranTable {
    String from();
    String to();
}

User類

@TranTable(from = "user_info", to = "user")
public class User {
 
    @TranField(to = "id")
    @TableId
    private Integer userId;
    @TranField(to = "wx_nickname")
    private String userAccount;
    @TranField(to = "roles")
    private String mobile;
    @TranField(from=TranField.empty,to="create_time")
    private Date createTime;
    @TranField(from=TranField.empty,to="update_time")
    private Date updateTime;
    @TranField(from=TranField.empty,to="bonus")
    private Integer bonus;
    @TranField(to="wx_id")
    private String[] test;
}

UserMapper

@TranDB(from = DBType.PGSQL,to=DBType.MYSQL,object=User.class)
public interface UserMapper extends BaseMapper<User> {
}

這里添加一個(gè)緩存mapper信息類,方便在攔截器中調(diào)用,其中有個(gè)成員變量是用來存儲mapperName對應(yīng)的TranDB注解信息,攔截器通過攔截的方法獲取mapper名稱,再通過這個(gè)mapper信息類獲取他的TranDB注解,這個(gè)注解里面有對應(yīng)的實(shí)體class,可以用來獲取字段信息注解及表名信息注解,而另一個(gè)成員變量則是用來存放待會說到的表名替換,這里面實(shí)現(xiàn)了兩個(gè)接口,一個(gè)通過spring容器加載資源的接口,另一個(gè)則是用來初始化bean的。

package com.trendy.task.transport.config;
 
import com.baomidou.mybatisplus.extension.parsers.ITableNameHandler;
import com.trendy.task.transport.annotations.TranDB;
import com.trendy.task.transport.handler.SelfTableNameHandler;
import com.trendy.task.transport.util.CamelHumpUtils;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.ResourceLoaderAware;
import org.springframework.core.io.Resource;
import org.springframework.core.io.ResourceLoader;
import org.springframework.core.io.support.ResourcePatternResolver;
import org.springframework.core.io.support.ResourcePatternUtils;
import org.springframework.core.type.classreading.CachingMetadataReaderFactory;
import org.springframework.core.type.classreading.MetadataReader;
import org.springframework.core.type.classreading.MetadataReaderFactory;
 
import java.util.*;
 
/**
 * Mapper信息緩存類
 */
public class MapperAuxFeatureMap implements ResourceLoaderAware, InitializingBean {
 
 
    private static ResourceLoader resourceLoader;
 
    @Value("${tran.mapperlocation}")
    public   String MAPPER_LOCATION ;
 
    public static final String TABLEPREFIX="t_";
 
    //表名處理
    public  Map<String, ITableNameHandler> tableNameHandlerMap;
 
    //mapper文件的注解
    public  Map<String, TranDB> mapperTranDbMap;
 
    //通過方法獲取mapper名稱
    public static String getMapperNameFromMethodName(String source){
        int end = source.lastIndexOf(".") + 1;
        String mapper = source.substring(0, end - 1);
        mapper = mapper.substring(mapper.lastIndexOf(".") + 1);
        return mapper;
    }
    
    @Override
    public void setResourceLoader(ResourceLoader resourceLoader) {
       MapperAuxFeatureMap.resourceLoader=resourceLoader;
    }
    @Override
    public void afterPropertiesSet() throws Exception {
        ResourcePatternResolver resolver = ResourcePatternUtils.getResourcePatternResolver(resourceLoader);
        MetadataReaderFactory metaReader = new CachingMetadataReaderFactory(resourceLoader);
        Resource[] resources = resolver.getResources("classpath*:"+MAPPER_LOCATION.replace(".","/")+"/**/*.class");
        mapperTranDbMap = new HashMap<>();
        tableNameHandlerMap = new HashMap<>();
        for (Resource r : resources) {
            MetadataReader reader = metaReader.getMetadataReader(r);
            String className = reader.getClassMetadata().getClassName();
            Class<?> c = Class.forName(className);
            if (c.isAnnotationPresent(TranDB.class)) {
                String name = c.getSimpleName();
                TranDB tranDB = c.getAnnotation(TranDB.class);
                mapperTranDbMap.put(name, tranDB);
                String value = tranDB.object().getSimpleName();
                tableNameHandlerMap.put(TABLEPREFIX+ CamelHumpUtils.humpToLine(value),new SelfTableNameHandler(tranDB.object()));
            }
        }
    }
}
 

替換數(shù)據(jù)源的部分代碼,對query和update(即增刪改)方法進(jìn)行攔截,改方法使用mysql數(shù)據(jù)源,查方法使用pgsql數(shù)據(jù)源

package com.trendy.task.transport.dyma;
 
 
import com.trendy.task.transport.annotations.TranDB;
import com.trendy.task.transport.config.MapperAuxFeatureMap;
import org.apache.ibatis.executor.Executor;
import org.apache.ibatis.mapping.MappedStatement;
import org.apache.ibatis.mapping.SqlCommandType;
import org.apache.ibatis.plugin.*;
import org.apache.ibatis.session.ResultHandler;
import org.apache.ibatis.session.RowBounds;
 
import java.util.Properties;
 
/**
 * @author: lele
 * @date: 2019/10/23 下午4:24
 */
@Intercepts({
        @Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class}),
        @Signature(type = Executor.class, method = "query", args = {MappedStatement.class, Object.class,
                RowBounds.class, ResultHandler.class})
})
public class DynamicDataSourceInterceptor implements Interceptor {
 
    private MapperAuxFeatureMap mapperAuxFeatureMap;
 
    public DynamicDataSourceInterceptor(MapperAuxFeatureMap mapperAuxFeatureMap) {
        this.mapperAuxFeatureMap = mapperAuxFeatureMap;
    }
 
    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        //如果讀取數(shù)據(jù),使用From的庫,否則使用To庫
        DBType db =null;
        Object[] objects = invocation.getArgs();
        MappedStatement statement = (MappedStatement) objects[0];
        String mapper = MapperAuxFeatureMap.getMapperNameFromMethodName(statement.getId());
        TranDB tranDB = mapperAuxFeatureMap.mapperTranDbMap.get(mapper);
        if (statement.getSqlCommandType().equals(SqlCommandType.SELECT)) {
            db = tranDB.from();
        } else {
            db = tranDB.to();
        }
        DynamicDataSourceHolder.setDbType(db);
        return invocation.proceed();
    }
 
    @Override
    public Object plugin(Object o) {
        if (o instanceof Executor) {
            return Plugin.wrap(o, this);
        } else {
            return o;
        }
    }
 
    @Override
    public void setProperties(Properties properties) {
 
    }
}

然后對字段進(jìn)行修改的攔截器,這里為什么要繼承AbstactSqlPaserHandler呢,因?yàn)榭梢詮?fù)用他的方法,以及為后來加入表名替換的類做準(zhǔn)備,這里的流程是獲取原來字段的名字,并改為TranField的to所存儲的內(nèi)容

package com.trendy.task.transport.handler;
 
import com.baomidou.mybatisplus.core.toolkit.PluginUtils;
import com.baomidou.mybatisplus.extension.handlers.AbstractSqlParserHandler;
import com.trendy.task.transport.annotations.TranDB;
import com.trendy.task.transport.annotations.TranField;
import com.trendy.task.transport.config.MapperAuxFeatureMap;
import com.trendy.task.transport.util.CamelHumpUtils;
import org.apache.ibatis.executor.statement.StatementHandler;
import org.apache.ibatis.mapping.BoundSql;
import org.apache.ibatis.mapping.MappedStatement;
import org.apache.ibatis.mapping.SqlCommandType;
import org.apache.ibatis.plugin.*;
import org.apache.ibatis.reflection.MetaObject;
import org.apache.ibatis.reflection.SystemMetaObject;
 
import java.lang.reflect.Field;
import java.sql.Connection;
import java.sql.Statement;
import java.util.HashMap;
import java.util.Map;
 
/**
 * @author: lele
 * @date: 2019/10/23 下午5:12
 */
 
@Intercepts({
        @Signature(
                type = StatementHandler.class,
                method = "prepare",
                args = {Connection.class, Integer.class}
        ),
        @Signature(
                type = StatementHandler.class,
                method = "update",
                args = {Statement.class}
        ),
        @Signature(
                type = StatementHandler.class,
                method = "batch",
                args = {Statement.class}
        )
})
public class FieldHandler extends AbstractSqlParserHandler implements Interceptor {
    private MapperAuxFeatureMap mapperAuxFeatureMap;
 
    public FieldHandler(MapperAuxFeatureMap mapperAuxFeatureMap) {
        this.mapperAuxFeatureMap = mapperAuxFeatureMap;
    }
 
    @Override
    public Object plugin(Object target) {
        return target instanceof StatementHandler ? Plugin.wrap(target, this) : target;
    }
 
    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        StatementHandler statementHandler =  PluginUtils.realTarget(invocation.getTarget());
        MetaObject metaObject = SystemMetaObject.forObject(statementHandler);
        super.sqlParser(metaObject);
        MappedStatement mappedStatement = (MappedStatement) metaObject.getValue("delegate.mappedStatement");
        BoundSql boundSql = (BoundSql) metaObject.getValue("delegate.boundSql");
        Boolean select = mappedStatement.getSqlCommandType().equals(SqlCommandType.SELECT);
        if (!select) {
            //通過獲取mapper名稱從緩存類中獲取對應(yīng)的注解
            String mapperName = MapperAuxFeatureMap.getMapperNameFromMethodName(mappedStatement.getId());
            TranDB tranDB = mapperAuxFeatureMap.mapperTranDbMap.get(mapperName);
           //獲取類的所有屬性
            Class clazz = tranDB.object();
            Map<String, Field> mapField = new HashMap<>(clazz.getFields().length);
            while (!clazz.equals(Object.class)) {
                Field[] fields = clazz.getDeclaredFields();
                for (Field field : fields) {
                    field.setAccessible(true);
                    mapField.put(field.getName(), field);
                }
                clazz = clazz.getSuperclass();
            }
            //替換sql
            String sql = boundSql.getSql();
            for (Map.Entry<String, Field> entry : mapField.entrySet()) {
                String sqlFieldName = CamelHumpUtils.humpToLine(entry.getKey());
                if (sql.contains(sqlFieldName)) {
                    String from = entry.getValue().getAnnotation(TranField.class).to();
                    sql = sql.replaceAll(sqlFieldName, from);
                }
            }
            metaObject.setValue("delegate.boundSql.sql", sql);
        }
        return invocation.proceed();
    }
}

現(xiàn)在還有一個(gè)問題要處理,就是表名替換,但是這個(gè)有個(gè)小坑,這個(gè)功能也相當(dāng)于上面替換sql的功能比如insert into user(user_info,user_id) values ...,比如把user這個(gè)表名替換為user_info這個(gè)表來執(zhí)行,此時(shí)的插入語句會把所有user的替換成user_info,這時(shí)候官方的建議是用@TableName這個(gè)注解更改表名避免出現(xiàn)這個(gè)情況

表名處理器

使用:實(shí)現(xiàn)ITableNameHandler,并實(shí)現(xiàn)接口方法返回一個(gè)表名字

package com.trendy.task.transport.handler;
 
import com.baomidou.mybatisplus.extension.parsers.ITableNameHandler;
import com.trendy.task.transport.annotations.TranTable;
import org.apache.ibatis.reflection.MetaObject;
 
/**
 * @author: lele
 * @date: 2019/10/24 下午2:39
 * 表名替換的handler
 */
public class SelfTableNameHandler implements ITableNameHandler {
    private final Class clazz;
 
    public SelfTableNameHandler(Class clazz) {
        this.clazz = clazz;
    }
 
    @Override
    public String dynamicTableName(MetaObject metaObject, String sql, String tableName) {
        TranTable t = (TranTable) clazz.getAnnotation(TranTable.class);
        if (sql.toLowerCase().startsWith("select")) {
            return t.from();
        } else {
            return t.to();
        }
    }
}

也可以注入到mp自帶的分頁那個(gè)攔截器中

 @Bean
    public FieldHandler fieldHandler() {
        FieldHandler f = new FieldHandler(mapperAuxFeatureMap());
        DynamicTableNameParser t = new DynamicTableNameParser();
        t.setTableNameHandlerMap(mapperAuxFeatureMap().tableNameHandlerMap);
        f.setSqlParserList(Collections.singletonList(t));
        return f;
    }

字段填充器

mysql的表里有創(chuàng)建時(shí)間、修改時(shí)間、積分,對于這些字段,而pgsql表里面沒有,這時(shí)候想在插入時(shí)使用一個(gè)默認(rèn)的值,這時(shí)候可以使用字段填充器

做法:實(shí)現(xiàn)MetaObjectHandler接口,并重寫里面的方法,然后在字段的@TableField的fill類型里面說明需要填充時(shí)情況

例子,對createTime,updateTime,bouns進(jìn)行默認(rèn)填充,使用getFieldValueByName和setFieldValByName方法進(jìn)行賦值

package com.trendy.task.transport.handler;
 
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import java.util.Date;
 
 
/**
 * @author lulu
 * @Date 2019/10/24 23:15
 * 自動(dòng)填充的handler
 */
 
public class DefaultFieldValueHandler implements MetaObjectHandler {
 
    public static final String CREATETIME = "createTime";
    public static final String UPDATETIME = "updateTime";
    public static final String BOUNS = "bonus";
 
    private void handle(String name, MetaObject metaObject, Object target) {
        Object o = getFieldValByName(name, metaObject);
        if (o == null) {
            setFieldValByName(name, target, metaObject);
        }
    }
 
    @Override
    public void insertFill(MetaObject metaObject) {
        handle(CREATETIME, metaObject, new Date());
        handle(UPDATETIME, metaObject, new Date());
        handle(BOUNS, metaObject, 500);
    }
 
    @Override
    public void updateFill(MetaObject metaObject) {
        handle(UPDATETIME, metaObject, new Date());
    }
}

然后為user添加注解@TableField的注解

  @TranField(from=TranField.empty,to="create_time")
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;
    @TranField(from=TranField.empty,to="update_time")
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;
    @TranField(from=TranField.empty,to="bonus")
    @TableField(fill= FieldFill.INSERT)
    private Integer bonus;

然后在全局配置中加入這個(gè)字段填充器類

 @Bean
    public GlobalConfig globalConfig() {
        GlobalConfig globalConfig = new GlobalConfig();
        globalConfig.setBanner(false);
        globalConfig.setMetaObjectHandler(defaultFieldValueHandler());
        return globalConfig;
    }

工廠類配置上全局配置 sqlSessionFactory.setGlobalConfig(globalConfig());

類型處理器

類型處理器,用于 JavaType 與 JdbcType 之間的轉(zhuǎn)換,用于 PreparedStatement 設(shè)置參數(shù)值和從 ResultSet 或 CallableStatement 中取出一個(gè)值,比如把String、Integer、Long、Double放到數(shù)據(jù)庫里面用逗號分隔形式存儲,此時(shí)可以

自定義類型處理器,這里針對上面四個(gè)對象數(shù)組實(shí)現(xiàn)類型轉(zhuǎn)換處理,setxxx方法主要是對參數(shù)進(jìn)行處理,然后把處理后的結(jié)果放入數(shù)據(jù)庫中,而get方法則處理從數(shù)據(jù)庫取出來的數(shù)據(jù)該如何處理,這里接受一個(gè)lambda函數(shù)作為方法轉(zhuǎn)換,即字符串-》目標(biāo)類型,這里定義一個(gè)抽象類統(tǒng)一處理方法,然后具體轉(zhuǎn)換方法由子類實(shí)現(xiàn)

package com.trendy.task.transport.handler;
 
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedJdbcTypes;
import org.apache.ibatis.type.MappedTypes;
 
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.function.Function;
 
/**
 * @author lulu
 * @Date 2019/10/25 21:46
 */
//@MappedJdbcTypes({})表明處理哪種jdbc類型
@MappedTypes(Object[].class)//表明處理哪種javatype
public abstract class AbstractArrayTypeHandler<T> extends BaseTypeHandler<Object[]> {
 
    //這里接受一個(gè)lambdah函數(shù)做轉(zhuǎn)換處理
   private final Function<String,T> method;
 
    public AbstractArrayTypeHandler(Function<String,T> method){
        this.method=method;
    }
 
    @Override
    public void setNonNullParameter(PreparedStatement preparedStatement, int i, Object[] objects, JdbcType jdbcType) throws SQLException {
            StringBuilder sb=new StringBuilder();
            for(Object o:objects){
                sb.append(o.toString()+",");
            }
            sb.deleteCharAt(sb.length()-1);
            preparedStatement.setString(i,sb.toString());
    }
 
    @Override
    public T[] getNullableResult(ResultSet resultSet, String s) throws SQLException {
        return getArray(resultSet.getString(s));
    }
 
    @Override
    public T[] getNullableResult(ResultSet resultSet, int i) throws SQLException {
        return getArray(resultSet.getString(i));
    }
    @Override
    public Object[] getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
        return  getArray(callableStatement.getString(i));
    }
 
    protected  T[] getArray(String source){
        if(source==null){
            return null;
        }
        String[] resString=source.split(",");
        if(this.method==null){
            return (T[])resString;
        }
        T[] resArray= (T[]) new Object[resString.length];
        for (int i = 0; i < resString.length; i++) {
            resArray[i]=method.apply(resString[i]);
        }
        return resArray;
    }
 
}

然后定義一個(gè)工廠存放子類

package com.trendy.task.transport.handler;
 
import java.util.function.Function;
 
/**
 * @author lulu
 * @Date 2019/10/25 22:33
 */
public interface ArrayTypeHandlerFactory {
 
     class IntegerArrayTypeHandler extends AbstractArrayTypeHandler<Integer>{
        public IntegerArrayTypeHandler() {
            super(Integer::parseInt);
        }
    }
     class DoubleArrayTypeHandler extends AbstractArrayTypeHandler<Double>{
        public DoubleArrayTypeHandler(){
            super(Double::parseDouble);
        }
    }
     class LongArrayTypeHandler extends AbstractArrayTypeHandler<Long>{
        public LongArrayTypeHandler(){
            super(Long::parseLong);
        }
    }
     class StringArrayTypeHandler extends AbstractArrayTypeHandler<String>{
        public StringArrayTypeHandler(){
            super(null);
        }
    }
}
 

指定處理類型

    @TableField(typeHandler = ArrayTypeHandlerFactory.StringArrayTypeHandler.class)

好了,現(xiàn)在來測試下,

 @Test
    public void selectById() {
        List<User> userList = userService.list(new LambdaQueryWrapper<User>().select(User::getUserId,User::getMobile,User::getUserAccount,User::getTest));
        userService.saveBatch(userList);
    }

大概就到這里,代碼完整版的github地址:GitHub - 97lele/transport

但是這個(gè)有個(gè)缺陷,就是不支持事務(wù),還有saveOrUpdate方法也不支持,因?yàn)閮蓚€(gè)數(shù)據(jù)源都不一樣,他是先查,看是否有再做更新或者插入操作,這些問題仍需解決,且當(dāng)作一個(gè)使用方法記錄的小例子吧

補(bǔ)充

mybatis-plus默認(rèn)的baseMapper不支持批量的插入和更新,有時(shí)候會為了這個(gè)批量的方法去繼承serviceImpl類,而這個(gè)類有沒有其他的業(yè)務(wù)代碼在里面,繼承僅僅是為了獲取批量操作的方法,會顯得這個(gè)類有點(diǎn)”貧血“

對于這種情況,偶然看到一個(gè)開源的項(xiàng)目onemall對BaseMapper做了擴(kuò)展,使它支持了批量插入的做法,在此基礎(chǔ)下,我也做了一定的擴(kuò)展

根據(jù)自己的見解,簡單描述下流程:

核心就是自定義一個(gè)sql自動(dòng)注入器,mybatis-plus會掃描mapper類 ,為每個(gè)mapper類構(gòu)造一個(gè)MappedStatement(相當(dāng)于mapper里的一個(gè)sql)

添加到配置類里面(具體在下面(2)),只會在初始化時(shí)候執(zhí)行一次,而我們要做的,就是把某個(gè)特定mapper,注入我們想要的模板方法

具體注入在MybatisMapperAnnotationBuilder,注入動(dòng)態(tài)sql,getSqlInjector獲取sql注入器,并為當(dāng)前的MapperBuilderAssistant對象(類似于mapper)注入mappedStatement(sql)

(1)注入開始,里面的inspectInject就是

inspectInject就會把a(bǔ)bstractMethod一一注入進(jìn)去

public void inspectInject(MapperBuilderAssistant builderAssistant, Class<?> mapperClass) {
        Class<?> modelClass = extractModelClass(mapperClass);
        if (modelClass != null) {
            String className = mapperClass.toString();
            Set<String> mapperRegistryCache = GlobalConfigUtils.getMapperRegistryCache(builderAssistant.getConfiguration());
            if (!mapperRegistryCache.contains(className)) {
                List<AbstractMethod> methodList = this.getMethodList(mapperClass);
                if (CollectionUtils.isNotEmpty(methodList)) {
                    TableInfo tableInfo = TableInfoHelper.initTableInfo(builderAssistant, modelClass);
                    // 循環(huán)注入自定義方法
                    methodList.forEach(m -> m.inject(builderAssistant, mapperClass, modelClass, tableInfo));
                } else {
                    logger.debug(mapperClass.toString() + ", No effective injection method was found.");
                }
                mapperRegistryCache.add(className);
            }
        }
    }

((2)抽象方法注入類,最終放到configuration類緩存,形成一個(gè)sql

具體看看AbstractMethod的實(shí)現(xiàn)類,而默認(rèn)的DefaultSqlInject類就有我們baseMapper所包含的默認(rèn)方法,我們要添加多兩個(gè)方法,批量更新和批量插入

下面開始編碼

首先繼承AbstarctMethod類,實(shí)現(xiàn)我們想注入的sql模板

對于批量插入,使用 insert into table columns values (values),(values),(values)

對于批量更新,使用 update table set xx=xx,xx=xx where xx=xx;update table set xx=xx,xx=xx where xx=xx;update table set xx=xx,xx=xx where xx=xx;進(jìn)行分號分割

因?yàn)橐玫綐?biāo)簽解析的功能,需要用script包裹起來。


具體初始化模板如下, 對其進(jìn)行填充

public enum CustomSqlMethodEnum {
    /**
     * 批量插入
     */
    INSERT_BATCH("insertBatch",
            "批量插入",
            "<script>\n"
                    + "INSERT INTO %s %s VALUES \n"
                    + "<foreach collection=\"collection\"  item=\"item\" separator=\",\"> %s\n </foreach>\n"
                    + "</script>"),
    /**
     * 批量更新
     */
    UPDATE_BATCH("updateBatchByIds",
            "批量更新",
            "<script>\n" +
                    "<foreach collection=\"collection\" item=\"item\" separator=\";\"> update %s set %s where %s </foreach>\n"
                    + "</script>"
    ),
 
    /**
     * 根據(jù)聯(lián)合鍵查詢
     */
    SELECT_BY_COMPOSEKEYS("selectByComposeKeys",
            "聯(lián)合主鍵查詢",
            "<script>" +
                    " select <choose> <when test=\"ew!=null and ew.sqlSelect != null and ew.sqlSelect != ''\"> ${ew.sqlSelect} </when> <otherwise> * </otherwise> </choose> from %s "
                    + "<where> <foreach collection=\"collection\" item=\"item\" open=\"(\" close=\")\" separator=\"or\"> ( %s ) </foreach> <if test=\"ew!=null and ew.sqlSegment != null and ew.sqlSegment != ''\">\n" +
                    "AND ${ew.sqlSegment}\n" +
                    "</if> </where> </script>"
    ),
 
    /**
     * 根據(jù)聯(lián)合鍵查詢
     */
    SELECT_IDS_BY_COMPOSEKEYS("selectIdsByComposeKeys",
            "聯(lián)合主鍵查詢id",
            "<script>" +
                    " select %s from %s "
                    + "<where> <foreach collection=\"collection\" item=\"item\" open=\"(\" close=\")\" separator=\"or\"> ( %s ) </foreach> </where> </script>"
    ),
 
    /**
     * 根據(jù)聯(lián)合主鍵刪除
     */
    DELETE_BY_COMPOSEKEYS("deleteByComposeKeys",
            "聯(lián)合主鍵刪除",
            "<script>" +
                    " delete from %s "
                    + "<where> <foreach collection=\"collection\" item=\"item\" open=\"(\" close=\")\" separator=\"or\"> ( %s ) </foreach> </where> </script>"
    ),
    /**
     * 根據(jù)聯(lián)合主鍵更新
     */
    UPDATE_BY_COMPOSEKEYS("updateByComposeKeys"
            , "聯(lián)合主鍵批量修改",
            "<script>\n" +
                    "<foreach collection=\"collection\" item=\"item\" separator=\";\"> update %s set %s where %s </foreach>\n"
                    + "</script>"
    );
 
 
    private final String method;
    private final String desc;
    private final String sql;
 
    CustomSqlMethodEnum(String method, String desc, String sql) {
        this.method = method;
        this.desc = desc;
        this.sql = sql;
    }
 
    public String getMethod() {
        return method;
    }
 
    public String getDesc() {
        return desc;
    }
 
    public String getSql() {
        return sql;
    }
}

下面是構(gòu)造批量插入和更新的代碼邏輯

批量插入:主要是構(gòu)造——表名、插入列、插入值,這里為了防止覆蓋數(shù)據(jù)庫默認(rèn)值,也可以做if test 的那種判空,來取消插入,不過比較麻煩,這里就不做了

public class InsertBatch extends AbstractMethod {
    @Override
    public MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {
        KeyGenerator keyGenerator = new NoKeyGenerator();
 
        CustomSqlMethodEnum sqlMethod = CustomSqlMethodEnum.INSERT_BATCH;
 
        // ==== 拼接 sql 模板 ==============
        StringBuilder columnScriptBuilder = new StringBuilder(LEFT_BRACKET);
        StringBuilder valuesScriptBuilder = new StringBuilder(LEFT_BRACKET);
        // 主鍵拼接
        if (StringUtils.isNotBlank(tableInfo.getKeyColumn())) {
            //(x1,x2,x3
            columnScriptBuilder.append(tableInfo.getKeyColumn()).append(COMMA);
            //(item.xx,item.xx
            valuesScriptBuilder.append(SqlScriptUtils.safeParam(SQLConditionWrapper.ITEM + DOT + tableInfo.getKeyProperty())).append(COMMA);
        }
        // 普通字段拼接
        List<TableFieldInfo> fieldList = tableInfo.getFieldList();
        for (TableFieldInfo fieldInfo : fieldList) {
            //有更新默認(rèn)填充器的不參與賦值
            if (!fieldInfo.isWithInsertFill() && fieldInfo.isWithUpdateFill()) {
                continue;
            }
            columnScriptBuilder.append(fieldInfo.getColumn()).append(COMMA);
            valuesScriptBuilder.append(SqlScriptUtils.safeParam(SQLConditionWrapper.getCondition(fieldInfo.getProperty()).toString())).append(COMMA);
        }
        // 替換多余的逗號為括號
        //(x1,x2)
        columnScriptBuilder.setCharAt(columnScriptBuilder.length() - 1, ')');
        //(item.xx,item.xx2)
        valuesScriptBuilder.setCharAt(valuesScriptBuilder.length() - 1, ')');
        // sql 模板占位符替換
        String columnScript = columnScriptBuilder.toString();
        String valuesScript = valuesScriptBuilder.toString();
        String sql = String.format(sqlMethod.getSql(), tableInfo.getTableName(), columnScript, valuesScript);
 
 
        // === mybatis 主鍵邏輯處理:主鍵生成策略,以及主鍵回填=======
        String keyColumn = null;
        String keyProperty = null;
        // 表包含主鍵處理邏輯,如果不包含主鍵當(dāng)普通字段處理
        if (StringUtils.isNotBlank(tableInfo.getKeyProperty())) {
            if (tableInfo.getIdType() == IdType.AUTO) {
                /** 自增主鍵 */
                keyGenerator = new Jdbc3KeyGenerator();
                keyProperty = tableInfo.getKeyProperty();
                keyColumn = tableInfo.getKeyColumn();
            } else {
                if (null != tableInfo.getKeySequence()) {
                    keyGenerator = TableInfoHelper.genKeyGenerator(sqlMethod.getMethod(), tableInfo, builderAssistant);
                    keyProperty = tableInfo.getKeyProperty();
                    keyColumn = tableInfo.getKeyColumn();
                }
            }
        }
        // 模板寫入
        SqlSource sqlSource = languageDriver.createSqlSource(configuration, sql, modelClass);
        return this.addInsertMappedStatement(mapperClass, modelClass, sqlMethod.getMethod(), sqlSource, keyGenerator, keyProperty, keyColumn);
    }
}

更新sql構(gòu)造,這里要注意字段上的字段策略(FieldStrategy),附上處理類

public class UpdateBatchByIds extends AbstractMethod {
    @Override
    public MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {
        CustomSqlMethodEnum sqlMethod = CustomSqlMethodEnum.UPDATE_BATCH;
        /**
         * update table set <if test ="item.pro!=null">key1=#{item.pro}</if>, key2=#{item.pro2} where keycolom = %s
         * */
        StringBuilder withChevScript = new StringBuilder();
        StringBuilder lastFiledScriptBuilder=new StringBuilder();
        StringBuilder keyScriptBuilder = new StringBuilder();
        if (StringUtils.isNotBlank(tableInfo.getKeyColumn())) {
            keyScriptBuilder.append(tableInfo.getKeyColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.ITEM + DOT + tableInfo.getKeyProperty()));
        }
        List<TableFieldInfo> fieldList = tableInfo.getFieldList();
        for (int i = 0; i < fieldList.size(); i++) {
            TableFieldInfo fieldInfo = fieldList.get(i);
            Boolean isLast=(i==(fieldList.size()-1));
            //有插入默認(rèn)填充器的不參與賦值
            if (fieldInfo.isWithInsertFill() && !fieldInfo.isWithUpdateFill()) {
                continue;
            }
            boolean change = false;
            if (Objects.equals(fieldInfo.getUpdateStrategy(), FieldStrategy.NOT_NULL) && !fieldInfo.isWithUpdateFill()) {
                SQLConditionWrapper.appendNotNull(withChevScript, fieldInfo.getProperty());
                change = true;
            }
            if (Objects.equals(fieldInfo.getUpdateStrategy(), FieldStrategy.NOT_EMPTY) && !fieldInfo.isWithUpdateFill()) {
                SQLConditionWrapper.appendNotEmpty(withChevScript, fieldInfo.getProperty());
                change = true;
            }
            if (change) {
                withChevScript.append(fieldInfo.getColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.getCondition(fieldInfo.getProperty()).toString()));
                withChevScript.append(COMMA).append("</if>");
                if(isLast&&lastFiledScriptBuilder.length()==0){
                    //如果沒有其他字段替補(bǔ),弄個(gè)占位的,不然會出現(xiàn)語法錯(cuò)誤的情況
                    withChevScript.append(tableInfo.getKeyColumn()).append(EQUALS).append(tableInfo.getKeyColumn());
                }
            }else{
                lastFiledScriptBuilder.append(fieldInfo.getColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.getCondition(fieldInfo.getProperty()).toString())).append(COMMA);
            }
        }
        //處理多余的逗號
        if(!StringUtils.isBlank(lastFiledScriptBuilder)&&!StringUtils.isBlank(withChevScript)){
            int leftChevIndex= withChevScript.lastIndexOf(LEFT_CHEV);
            if(withChevScript.charAt(leftChevIndex-1)!=','){
                withChevScript.replace(leftChevIndex,leftChevIndex+1,",<");
            }
            if(lastFiledScriptBuilder.lastIndexOf(COMMA)==lastFiledScriptBuilder.length()-1){
                lastFiledScriptBuilder.deleteCharAt(lastFiledScriptBuilder.length()-1);
            }
        }
        withChevScript.append(lastFiledScriptBuilder);
        // sql 模板占位符替換
        String sql = String.format(sqlMethod.getSql(), tableInfo.getTableName(), withChevScript, keyScriptBuilder);
        // 模板寫入
        SqlSource sqlSource = languageDriver.createSqlSource(configuration, sql, modelClass);
        return this.addUpdateMappedStatement(mapperClass, modelClass, sqlMethod.getMethod(), sqlSource);
    }
}
public class SQLConditionWrapper {
    public final static String ITEM = "item";
 
    public static StringBuilder appendNotNull(StringBuilder builder, String property) {
        return appendEnd(appendStart(builder, getCondition(property)));
    }
 
    public static StringBuilder appendNotEmpty(StringBuilder builder, String property) {
        StringBuilder condition = getCondition(property);
        StringBuilder append = appendStart(builder, condition)
                .append(" ").append(AND).append(" ").append(condition).append(EXCLAMATION_MARK).append(EQUALS).append(" ").append("''");
        return appendEnd(append);
    }
 
    private static StringBuilder appendEnd(StringBuilder builder) {
        builder.append("\"")
                .append(RIGHT_CHEV);
        return builder;
    }
 
    private static StringBuilder appendStart(StringBuilder builder, StringBuilder item) {
        builder.append(LEFT_CHEV)
                .append("if test=\"")
                .append(item).append(EXCLAMATION_MARK).append(EQUALS).append(NULL);
        return builder;
    }
 
    public static StringBuilder getCondition(String property) {
        return new StringBuilder()
                .append(ITEM).append(DOT).append(property);
    }
}

然后就自定義mapper及sql注入器

public interface CustomMapper<T> extends BaseMapper<T> {
    /**
     * 批量插入
     * @param collection 批量插入數(shù)據(jù)
     * @return ignore
     */
    int insertBatch(@Param("collection") Collection<T> collection);
 
    /**
     * 批量更新
     * @param collection
     * @return
     */
    int updateBatchByIds(@Param("collection") Collection<T> collection);
 
}

這里sql注入器要判斷下是繼承了該類,才進(jìn)行方法擴(kuò)展

@ConditionalOnExpression("${mybatis-plus.custom-mapper.enabled:true}")
@Component
public class CustomSqlInject extends DefaultSqlInjector {
    //初始化時(shí)候會加載
    @Override
    public List<AbstractMethod> getMethodList(Class<?> mapperClass) {
        List<AbstractMethod> methodList = super.getMethodList(mapperClass);
        //屬于自己定義的mapper才添加方法
        if (((ParameterizedTypeImpl) mapperClass.getGenericInterfaces()[0]).getRawType().equals(CustomMapper.class)) {
            methodList.add(new InsertBatch());
            methodList.add(new UpdateBatchByIds());
        }
        if (((ParameterizedTypeImpl) mapperClass.getGenericInterfaces()[0]).getRawType().equals(ComposeKeyMapper.class)) {
            methodList.add(new SelectByComposeKeys());
            methodList.add(new SelectIdsByComposeKeys());
            methodList.add(new UpdateByComposeKeys());
            methodList.add(new InsertBatch());
        }
        return methodList;
    }
}

可以直接注入到spring里面,或者通過進(jìn)行設(shè)置

GlobalConfigUtils.getGlobalConfig(sqlSessionFactory.getConfiguration()).setSqlInjector(xx)

測試一下,定義實(shí)體,下面的typeHandler可以去掉,

@TableName(
        value = "demo"
)
@Data
@Accessors(chain = true)
public class Demo extends BaseEntity {
    private static final long serialVersionUID = 1L;
    @TableId("id")
    private Long id;
 
    @TableField("name")
    private String name;
    @TableField(
            value = "age",
            typeHandler = LongFormatAESEncryptHandler.class
    )
    private Long age;
    @TableField(
            value = "secret",
            typeHandler = StringFormatAESEncryptHandler.class
    )
    private String secret;
    @TableField(
            value = "CREATED_ID",
            fill = FieldFill.INSERT
    )
    private Long createdId;
    @TableField(
            value = "CREATED_BY",
            fill = FieldFill.INSERT
    )
    private String createdBy;
    @TableField(
            value = "CREATION_DATE",
            fill = FieldFill.INSERT
    )
    private Date creationDate;
    @TableField(
            value = "CREATED_BY_IP",
            fill = FieldFill.INSERT
    )
    private String createdByIp;
    @TableField(
            value = "LAST_UPDATED_ID",
            fill = FieldFill.UPDATE
    )
    private Long lastUpdatedId;
    @TableField(
            value = "LAST_UPDATED_BY",
            fill = FieldFill.UPDATE
    )
    private String lastUpdatedBy;
    @TableField(
            value = "LAST_UPDATE_DATE",
            fill = FieldFill.INSERT_UPDATE
    )
    private Date lastUpdateDate;
    @TableField(
            value = "LAST_UPDATED_BY_IP",
            fill = FieldFill.UPDATE
    )
    private String lastUpdatedByIp;
 
 
}

繼承自定義mapper

public interface TempMapper extends CustomMapper<Demo> {
}

controller了的兩個(gè)方法,可以支持事務(wù)

@GetMapping("/testBatch")
    @Transactional(rollbackFor = Exception.class)
    public void testBatch() {
        List<Demo> demos = new LinkedList<>();
        for (int i = 0; i < 10; i++) {
            Demo de = new Demo().setAge(Long.valueOf(i))
                    .setId(Long.valueOf(i + 1))
                    .setName("test" + i)
                    .setSecret(UUID.randomUUID().toString());
            demos.add(de);
        }
        tempMapper.insertBatch(demos);
    }
 
    @GetMapping("/testBatch2")
    @Transactional(rollbackFor = Exception.class)
    public void testBatch2() {
        List<Demo> demos = new LinkedList<>();
        for (int i = 0; i < 5; i++) {
            Demo de = new Demo().setAge(Long.valueOf(i))
                    .setId(Long.valueOf(i + 1))
                    .setName("test-change" + i)
                    .setSecret(UUID.randomUUID().toString());
            demos.add(de);
        }
        tempMapper.updateBatchByIds(demos);
        //int i=1/0;
    }

對于自定sql注入,還可以抽取一些公用的方法進(jìn)行添加,比如邏輯刪除,版本號更新,進(jìn)行聯(lián)合主鍵的批量修改和查詢,下面給出聯(lián)合主鍵的處理方案

下面是構(gòu)造根據(jù)wrapper和聯(lián)合主鍵進(jìn)行查詢的,核心也是定義好sql,然后進(jìn)行注入,但這里需要自定義一個(gè)注解來標(biāo)識哪個(gè)是聯(lián)合主鍵

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface ComposeKey {
 
}
public class SelectByComposeKeys extends AbstractMethod {
    @Override
    public MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {
        CustomSqlMethodEnum sqlMethod = CustomSqlMethodEnum.SELECT_BY_COMPOSEKEYS;
        //select #{ew.sqlSelect} from table_name where  (composekey1=xx and composekey2=xx) or (composekey1=xx1 and composekey2=xx1)
        String sqlTemplate = sqlMethod.getSql();
        String tableName = tableInfo.getTableName();
        List<TableFieldInfo> composeKeys = tableInfo.getFieldList().stream().filter(e -> e.getField().isAnnotationPresent(ComposeKey.class))
                .collect(Collectors.toList());
        if(CollectionUtils.isEmpty(composeKeys)){
            throw new ApiException("not composeKey found in class:"+modelClass.getName());
        }
        StringBuilder builder=new StringBuilder();
        for (int i = 0; i < composeKeys.size(); i++) {
            TableFieldInfo composeKey = composeKeys.get(i);
            builder.append(composeKey.getColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.ITEM + DOT + composeKey.getProperty()));
            if(i!=composeKeys.size()-1){
                builder.append(" ").append(AND).append(" ");
            }
        }
        String finalSql = String.format(sqlTemplate, tableName, builder);
        SqlSource sqlSource = languageDriver.createSqlSource(configuration, finalSql, modelClass);
        return this.addSelectMappedStatementForTable(mapperClass,sqlMethod.getMethod(),sqlSource,tableInfo);
    }
}

更新操作

public class UpdateByComposeKeys extends AbstractMethod {
    @Override
    public MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {
        CustomSqlMethodEnum sqlMethod = CustomSqlMethodEnum.UPDATE_BY_COMPOSEKEYS;
        /**
         * update table set <if test ="item.pro!=null">key1=#{item.pro}</if>, key2=#{item.pro2} where keycolom = %s
         */
        StringBuilder withChevScript = new StringBuilder();
        StringBuilder lastFiledScriptBuilder = new StringBuilder();
        StringBuilder keyScriptBuilder = new StringBuilder();
        StringBuilder placeHolder = new StringBuilder();
 
        List<TableFieldInfo> fieldList = tableInfo.getFieldList();
        for (int i = 0; i < fieldList.size(); i++) {
            TableFieldInfo fieldInfo = fieldList.get(i);
            Boolean isLast = (i == (fieldList.size() - 1));
            if (fieldInfo.getField().isAnnotationPresent(ComposeKey.class)) {
                keyScriptBuilder.append(" ").append(fieldInfo.getColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.ITEM + DOT + fieldInfo.getProperty()))
                .append(" ").append(AND);
                placeHolder.append(fieldInfo.getColumn()).append(EQUALS).append(fieldInfo.getColumn()).append(COMMA);
                continue;
            }
            //有插入默認(rèn)填充器或者主鍵的不參與賦值
            if (fieldInfo.isWithInsertFill() && !fieldInfo.isWithUpdateFill()) {
                continue;
            }
            boolean change = false;
            if (Objects.equals(fieldInfo.getUpdateStrategy(), FieldStrategy.NOT_NULL) && !fieldInfo.isWithUpdateFill()) {
                SQLConditionWrapper.appendNotNull(withChevScript, fieldInfo.getProperty());
                change = true;
            }
            if (Objects.equals(fieldInfo.getUpdateStrategy(), FieldStrategy.NOT_EMPTY) && !fieldInfo.isWithUpdateFill()) {
                SQLConditionWrapper.appendNotEmpty(withChevScript, fieldInfo.getProperty());
                change = true;
            }
            if (change) {
                withChevScript.append(fieldInfo.getColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.getCondition(fieldInfo.getProperty()).toString()));
                withChevScript.append(COMMA).append("</if>");
                if (isLast && lastFiledScriptBuilder.length() == 0) {
                    //如果沒有其他字段替補(bǔ),弄個(gè)占位的,不然會出現(xiàn)語法錯(cuò)誤的情況
                    if (placeHolder.length() > 0) {
                        //刪除多余的逗號
                        placeHolder.deleteCharAt(placeHolder.length() - 1);
                        withChevScript.append(placeHolder);
                    }
 
                }
            } else {
                lastFiledScriptBuilder.append(fieldInfo.getColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.getCondition(fieldInfo.getProperty()).toString())).append(COMMA);
            }
        }
        if (placeHolder.length() == 0) {
            throw new ApiException("not composeKey found in class:" + modelClass.getName());
        }
        //處理多余的逗號
        if (!StringUtils.isBlank(lastFiledScriptBuilder) && !StringUtils.isBlank(withChevScript)) {
            int leftChevIndex = withChevScript.lastIndexOf(LEFT_CHEV);
            if (withChevScript.charAt(leftChevIndex - 1) != ',') {
                withChevScript.replace(leftChevIndex, leftChevIndex + 1, ",<");
            }
            if (lastFiledScriptBuilder.lastIndexOf(COMMA) == lastFiledScriptBuilder.length() - 1) {
                lastFiledScriptBuilder.deleteCharAt(lastFiledScriptBuilder.length() - 1);
            }
        }
        if(!StringUtils.isBlank(keyScriptBuilder)){
            int i = keyScriptBuilder.lastIndexOf(AND);
            keyScriptBuilder.delete(i,i+AND.length());
        }
        withChevScript.append(lastFiledScriptBuilder);
        // sql 模板占位符替換
        String sql = String.format(sqlMethod.getSql(), tableInfo.getTableName(), withChevScript, keyScriptBuilder);
        // 模板寫入
        SqlSource sqlSource = languageDriver.createSqlSource(configuration, sql, modelClass);
        return this.addUpdateMappedStatement(mapperClass, modelClass, sqlMethod.getMethod(), sqlSource);
    }
}
public class SelectIdsByComposeKeys extends AbstractMethod {
    @Override
    public MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {
        CustomSqlMethodEnum sqlMethod = CustomSqlMethodEnum.SELECT_IDS_BY_COMPOSEKEYS;
        //select composekeys from table_name where  (composekey1=xx and composekey2=xx) or (composekey1=xx1 and composekey2=xx1)
        String sqlTemplate = sqlMethod.getSql();
        String tableName = tableInfo.getTableName();
        List<TableFieldInfo> composeKeys = tableInfo.getFieldList().stream().filter(e -> e.getField().isAnnotationPresent(ComposeKey.class))
                .collect(Collectors.toList());
        if(CollectionUtils.isEmpty(composeKeys)){
            throw new ApiException("not composeKey found in class:"+modelClass.getName());
        }
        StringBuilder builder=new StringBuilder();
        StringBuilder select=new StringBuilder();
 
        for (int i = 0; i < composeKeys.size(); i++) {
            TableFieldInfo composeKey = composeKeys.get(i);
            select.append(composeKey.getColumn());
            builder.append(composeKey.getColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.ITEM + DOT + composeKey.getProperty()));
            if(i!=composeKeys.size()-1){
                builder.append(" ").append(AND).append(" ");
                select.append(COMMA);
            }
        }
        String finalSql = String.format(sqlTemplate,select, tableName, builder);
        SqlSource sqlSource = languageDriver.createSqlSource(configuration, finalSql, modelClass);
        return this.addSelectMappedStatementForTable(mapperClass,sqlMethod.getMethod(),sqlSource,tableInfo);
    }
}
public class DeleteByComposeKeys extends AbstractMethod {
    @Override
    public MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {
        CustomSqlMethodEnum sqlMethod = CustomSqlMethodEnum.DELETE_BY_COMPOSEKEYS;
        //delete  from table_name where  (composekey1=xx and composekey2=xx) or (composekey1=xx1 and composekey2=xx1)
        String sqlTemplate = sqlMethod.getSql();
        String tableName = tableInfo.getTableName();
        List<TableFieldInfo> composeKeys = tableInfo.getFieldList().stream().filter(e -> e.getField().isAnnotationPresent(ComposeKey.class))
                .collect(Collectors.toList());
        if(CollectionUtils.isEmpty(composeKeys)){
            throw new ApiException("not composeKey found in class:"+modelClass.getName());
        }
        StringBuilder builder=new StringBuilder();
        for (int i = 0; i < composeKeys.size(); i++) {
            TableFieldInfo composeKey = composeKeys.get(i);
            builder.append(composeKey.getColumn()).append(EQUALS).append(SqlScriptUtils.safeParam(SQLConditionWrapper.ITEM + DOT + composeKey.getProperty()));
            if(i!=composeKeys.size()-1){
                builder.append(" ").append(AND).append(" ");
            }
        }
        String finalSql = String.format(sqlTemplate, tableName, builder);
        SqlSource sqlSource = languageDriver.createSqlSource(configuration, finalSql, modelClass);
        return this.addDeleteMappedStatement(mapperClass, sqlMethod.getMethod(), sqlSource);
    }
 
}

定義mappe類,這里對于原生的方法就不進(jìn)行支持了

public interface ComposeKeyMapper<T> extends CustomMapper<T> {
    /**
     * @param params  查詢的主鍵入?yún)?
     * @param wrapper 查詢的列會用到 ew.sqlSelect
     * @return
     */
    List<T> selectByComposeKeys(@Param("collection") Collection<T> params, @Param(Constants.WRAPPER) Wrapper<T> wrapper);
 
    /**
     * 批量更新
     *
     * @param params
     */
    void updateByComposeKeys(@Param("collection") Collection<T> params);
 
    /**
     * 只查詢主鍵
     *
     * @param params
     * @return
     */
    List<T> selectIdsByComposeKeys(@Param("collection") Collection<T> params);
 
    /**
     * 聯(lián)合主鍵刪除
     * @param params
     * @return
     */
    int deleteByComposeKeys(@Param("collection")Collection<T> params);
 
    /**
     * 下面的方法不支持
     * @param entity
     * @return
     */
    @Override
    default int updateById(T entity) {
        throw new UnsupportedOperationException();
    }
 
    @Override
    default int updateBatchByIds(Collection<T> collection) {
        throw new UnsupportedOperationException();
    }
 
    @Override
    default T selectById(Serializable id) {
        throw new UnsupportedOperationException();
    }
 
    @Override
    default List<T> selectBatchIds(Collection<? extends Serializable> idList) {
        throw new UnsupportedOperationException();
    }
 
    @Override
    default int deleteBatchIds(Collection<? extends Serializable> idList){
        throw new UnsupportedOperationException();
    }
 
    @Override
    default int deleteById(Serializable id){
        throw new UnsupportedOperationException();
    }
}

可以看到查詢是按照預(yù)期給出的,也支持wrapper形式的查詢

要注意,xml文件里的優(yōu)先級是比自定義注入的優(yōu)先級高的,這里沒給出單個(gè)update,單個(gè)查詢,單個(gè)刪除的方法,這些都可以根據(jù)自己業(yè)務(wù)需求弄一下,項(xiàng)目上沒用到就不寫了

對于sqlSession也可以自己做一些小優(yōu)化

類型有reuse,編譯一次可以繼續(xù)服用,使用場景:執(zhí)行同一個(gè)sql,參數(shù)值不同

默認(rèn)的simple是每次都會編譯一下

batch相當(dāng)于一個(gè)會話里面執(zhí)行多條sql

reuse示例

 public static void executeReuse(Consumer<SqlSession> consumer) {
        SqlSessionFactory factory = SpringContextHolder.getBean(SqlSessionFactory.class);
        SqlSession sqlSession = factory.openSession(ExecutorType.REUSE, true);
        try {
            consumer.accept(sqlSession);
        } finally {
            sqlSession.close();
        }
    }

到此這篇關(guān)于mybatis-plus攔截器、字段填充器、類型處理器、表名替換、SqlInjector(聯(lián)合主鍵處理)的文章就介紹到這了,更多相關(guān)mybatis-plus攔截器、字段填充器、類型處理器、表名替換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring的懶加載機(jī)制原理和配置詳解

    Spring的懶加載機(jī)制原理和配置詳解

    這篇文章主要介紹了Spring的懶加載機(jī)制原理和配置詳解,Spring提供了懶加載機(jī)制,所謂的懶加載機(jī)制就是可以規(guī)定指定的bean不在啟動(dòng)時(shí)立即創(chuàng)建,而是在后續(xù)第一次用到時(shí)才創(chuàng)建,從而減輕在啟動(dòng)過程中對時(shí)間和內(nèi)存的消耗,需要的朋友可以參考下
    2023-10-10
  • 啟動(dòng) Eclipse 彈出 Failed to load the JNI shared library jvm.dll 錯(cuò)誤的解決方法

    啟動(dòng) Eclipse 彈出 Failed to load the JNI shared library jvm.dll

    這篇文章主要介紹了有時(shí)候,新電腦上回碰到打開Eclipse時(shí),彈出提示“Failed to load the JNI shared library jvm.dll”錯(cuò)誤,這里給大家分享解決方案
    2016-08-08
  • Spring-AOP 靜態(tài)正則表達(dá)式方法如何匹配切面

    Spring-AOP 靜態(tài)正則表達(dá)式方法如何匹配切面

    這篇文章主要介紹了Spring-AOP 靜態(tài)正則表達(dá)式方法如何匹配切面的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 解決多模塊項(xiàng)目中Mybatis的Mapper內(nèi)部方法找不到的問題

    解決多模塊項(xiàng)目中Mybatis的Mapper內(nèi)部方法找不到的問題

    這篇文章主要介紹了解決多模塊項(xiàng)目中Mybatis的Mapper內(nèi)部方法找不到的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • IDEA報(bào)錯(cuò)Error?running‘Application‘:Command?line?is?too?long的問題

    IDEA報(bào)錯(cuò)Error?running‘Application‘:Command?line?is?too?lo

    這篇文章主要介紹了IDEA報(bào)錯(cuò)Error?running?‘Application‘:Command?line?is?too?long的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • java maven中如何引入自己的lib

    java maven中如何引入自己的lib

    在JavaMaven項(xiàng)目中引入自己的庫可以簡化為幾個(gè)步驟:首先,確保庫以JAR格式存在或打包成JAR;其次,將JAR文件放置在項(xiàng)目目錄或安裝到本地Maven倉庫;最后,在pom.xml中添加依賴,這樣做可以使項(xiàng)目更加模塊化,便于管理和維護(hù),感興趣的朋友跟隨小編一起看看吧
    2024-09-09
  • Java?lambda表達(dá)式與泛型整理總結(jié)

    Java?lambda表達(dá)式與泛型整理總結(jié)

    Lambda?表達(dá)式(lambda?expression)是一個(gè)匿名函數(shù),Lambda表達(dá)式基于數(shù)學(xué)中的λ演算得名。泛型編程,故如其名,是一個(gè)泛化的編程方式。其實(shí)現(xiàn)原理為程序員編寫一個(gè)函數(shù)/類的代碼示例,讓編譯器去填補(bǔ)出不同的函數(shù)實(shí)現(xiàn)
    2022-07-07
  • Java實(shí)現(xiàn)簡單棋盤存檔和讀取功能

    Java實(shí)現(xiàn)簡單棋盤存檔和讀取功能

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡單棋盤存檔和讀取功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • JDK的具體安裝步驟(帶圖帶解釋巨詳細(xì))

    JDK的具體安裝步驟(帶圖帶解釋巨詳細(xì))

    Java是一種廣泛使用的編程語言,許多應(yīng)用程序和系統(tǒng)都依賴于它,如果您想進(jìn)行Java編程或運(yùn)行Java應(yīng)用程序,首先需要安裝Java開發(fā)工具包(JDK),這篇文章主要給大家介紹了關(guān)于JDK具體安裝步驟的相關(guān)資料,文中介紹的方法帶圖帶解釋巨詳細(xì),需要的朋友可以參考下
    2024-05-05
  • 基于HttpClient在HTTP協(xié)議接口測試中的使用(詳解)

    基于HttpClient在HTTP協(xié)議接口測試中的使用(詳解)

    下面小編就為大家?guī)硪黄贖ttpClient在HTTP協(xié)議接口測試中的使用(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10

最新評論

国产精品一二三不卡带免费视频| 一区二区三区久久久91| 97精品成人一区二区三区| 五十路在线观看完整版| 国产激情av网站在线观看| 欧美成人综合色在线噜噜| 亚洲免费va在线播放| 欧美精品中文字幕久久二区| 青青青青青免费视频| 亚洲国产欧美一区二区丝袜黑人| 午夜精品在线视频一区| 国产丰满熟女成人视频| 爱有来生高清在线中文字幕| 日本一区精品视频在线观看| 骚逼被大屌狂草视频免费看| 加勒比视频在线免费观看| 风流唐伯虎电视剧在线观看| 精品一区二区亚洲欧美| 欧美亚洲少妇福利视频| 日韩av有码中文字幕| 搞黄色在线免费观看| 晚上一个人看操B片| 天天干夜夜操啊啊啊| 亚洲欧美另类自拍偷拍色图| 黄色视频在线观看高清无码 | 97人妻色免费视频| 亚洲免费成人a v| 狠狠的往里顶撞h百合| 精品美女在线观看视频在线观看| 欧美viboss性丰满| 色秀欧美视频第一页| 1区2区3区4区视频在线观看| 国产大学生援交正在播放| 午夜激情精品福利视频| 99一区二区在线观看| 韩国亚洲欧美超一级在线播放视频| 日本av高清免费网站| 日本午夜爽爽爽爽爽视频在线观看 | 黄工厂精品视频在线观看| 久久一区二区三区人妻欧美| 直接观看免费黄网站| 黑人3p华裔熟女普通话| 婷婷色中文亚洲网68| 97精品人妻一区二区三区精品| 少妇一区二区三区久久久| 精品久久久久久久久久久99| 日本丰满熟妇BBXBBXHD| 久久精品亚洲国产av香蕉| 中文字幕av男人天堂| 免费无毒热热热热热热久| 人妻3p真实偷拍一二区| 亚洲一级 片内射视正片| av日韩在线观看大全| 九九视频在线精品播放| 偷拍美女一区二区三区| 三级黄色亚洲成人av| 青青青青操在线观看免费| 中文字幕高清资源站| 亚洲一区二区三区精品乱码| 欧美另类z0z变态| 免费观看丰满少妇做受| 人妻无码中文字幕专区| 国产之丝袜脚在线一区二区三区| 国产av福利网址大全| 黑人变态深video特大巨大| 国产精品3p和黑人大战| 国产又色又刺激在线视频 | 黄工厂精品视频在线观看| 久久www免费人成一看片| 国产亚洲国产av网站在线| 亚洲欧美日韩视频免费观看| 91九色porny国产蝌蚪视频| 免费大片在线观看视频网站| 色婷婷久久久久swag精品| 精品91高清在线观看| 日曰摸日日碰夜夜爽歪歪| 欧美另类z0z变态| 免费观看丰满少妇做受| 亚洲 人妻 激情 中文| 国产精品一二三不卡带免费视频| 99热99re在线播放| 中文字幕av男人天堂| 成人色综合中文字幕| 好太好爽好想要免费| 国产成人综合一区2区| 三级等保密码要求条款| 顶级尤物粉嫩小尤物网站| 男人的天堂一区二区在线观看| 欧美色呦呦最新网址| 91色秘乱一区二区三区| 亚洲精品在线资源站| 日韩av大胆在线观看| 欧美乱妇无乱码一区二区| 日韩欧美高清免费在线| 亚洲 中文字幕在线 日韩| 粉嫩av蜜乳av蜜臀| 日本a级视频老女人| 老司机福利精品视频在线| 国产美女午夜福利久久| 天天做天天干天天操天天射| 人妻av无码专区久久绿巨人| 成人激情文学网人妻| 免费无毒热热热热热热久| 丝袜国产专区在线观看| 天天夜天天日天天日| 只有精品亚洲视频在线观看| 亚洲av男人的天堂你懂的| 亚洲高清一区二区三区视频在线| 久久精品国产999| wwwxxx一级黄色片| 亚洲另类伦春色综合小| 日韩人妻在线视频免费| 中文字幕 码 在线视频| xxx日本hd高清| 成人高潮aa毛片免费| 日韩国产乱码中文字幕| 视频在线亚洲一区二区| 黄色视频在线观看高清无码| 天天日天天干天天干天天日| 成人国产激情自拍三区| 成人性黑人一级av| 在线免费视频 自拍| 日本性感美女写真视频| 超碰在线观看免费在线观看| 人妻激情图片视频小说| 91精品国产综合久久久蜜| 亚洲1069综合男同| 国产黄网站在线观看播放| 内射久久久久综合网| 日本阿v视频在线免费观看| 亚洲 自拍 色综合图| 国际av大片在线免费观看| 女同性ⅹxx女同h偷拍| 中文字幕在线免费第一页| weyvv5国产成人精品的视频| 色综合色综合色综合色| 亚洲男人在线天堂网| 亚洲免费视频欧洲免费视频| 中文字幕av第1页中文字幕| 女人精品内射国产99| 青青草亚洲国产精品视频| 丁香花免费在线观看中文字幕| 天天日天天敢天天干| 四虎永久在线精品免费区二区| 亚洲在线一区二区欧美| 亚洲在线观看中文字幕av| 亚洲熟色妇av日韩熟色妇在线| av破解版在线观看| 超黄超污网站在线观看| 亚国产成人精品久久久| 天天插天天狠天天操| 男人的网址你懂的亚洲欧洲av| 国产片免费观看在线观看| 欧美一区二区三区激情啪啪啪| 91国语爽死我了不卡| 最新的中文字幕 亚洲| 久久久久久久亚洲午夜综合福利| 国产伊人免费在线播放| 都市激情校园春色狠狠| 玖玖一区二区在线观看| 国产精品女邻居小骚货| 人人妻人人爱人人草| 国产麻豆剧传媒精品国产av蜜桃| 精品成人午夜免费看| 精品av国产一区二区三区四区 | 国产品国产三级国产普通话三级| 93视频一区二区三区| 婷婷六月天中文字幕| 亚洲综合乱码一区二区| 18禁免费av网站| 欧美在线一二三视频| 天天想要天天操天天干| 在线观看免费视频网| 天天射夜夜操综合网| 亚洲成人熟妇一区二区三区| 国产一区二区欧美三区| 久精品人妻一区二区三区| 自拍偷拍一区二区三区图片| 啊啊啊想要被插进去视频| 91麻豆精品传媒国产黄色片| 成人区人妻精品一区二视频| 成人免费公开视频无毒| 成年美女黄网站18禁久久| 亚洲图库另类图片区| 在线可以看的视频你懂的 | 日韩精品中文字幕播放| 综合一区二区三区蜜臀| 91精品国产观看免费| av中文字幕电影在线看| 粗大的内捧猛烈进出爽大牛汉子| 午夜美女福利小视频| 日本免费视频午夜福利视频| 97超碰最新免费在线观看| 亚洲精品在线资源站| 国产精品亚洲在线观看| 天天通天天透天天插| 97国产在线观看高清| 午夜精品福利一区二区三区p| 经典国语激情内射视频| 国产精品福利小视频a| 日本五十路熟新垣里子| 欧美视频中文一区二区三区| 黄色成年网站午夜在线观看| 天天通天天透天天插| 午夜影院在线观看视频羞羞羞| 天天操夜夜操天天操天天操| 亚洲一区二区久久久人妻| 欧美成人综合色在线噜噜| 中文字幕在线观看极品视频| 国产视频一区二区午夜| 青青草亚洲国产精品视频| 五十路在线观看完整版| 久久这里只有精品热视频| 中文字幕网站你懂的| 亚洲精品午夜久久久久| 五十路丰满人妻熟妇| 亚洲av日韩高清hd| 亚洲图片偷拍自拍区| 欧美一区二区三区在线资源| 日本熟女50视频免费| 亚洲综合色在线免费观看| 天堂女人av一区二区| 女同久久精品秋霞网| 亚洲免费成人a v| japanese五十路熟女熟妇| a v欧美一区=区三区| 国产成人综合一区2区| eeuss鲁片一区二区三区| 精品久久久久久久久久久99| 国产乱子伦精品视频潮优女| 亚洲精品午夜久久久久| 国产免费av一区二区凹凸四季| 成人av久久精品一区二区| 精品久久久久久高潮| 午夜在线精品偷拍一区二| 亚洲图库另类图片区| 在线 中文字幕 一区| 影音先锋女人av噜噜色| 欧美成人精品在线观看| 91精品高清一区二区三区| 极品性荡少妇一区二区色欲| 最后99天全集在线观看| 99精品国产aⅴ在线观看| 国产黑丝高跟鞋视频在线播放| 国产乱子伦精品视频潮优女| 日韩三级电影华丽的外出| 日本少妇人妻xxxxxhd| 久久久久久九九99精品| 黑人大几巴狂插日本少妇| 日韩剧情片电影在线收看| 成人av天堂丝袜在线观看| 硬鸡巴动态操女人逼视频| av无限看熟女人妻另类av| 国产高清在线观看1区2区| 亚国产成人精品久久久| 亚洲欧美清纯唯美另类| 亚洲青青操骚货在线视频| 亚洲成a人片777777| 五十路av熟女松本翔子| 日本韩国免费福利精品| 91高清成人在线视频| 亚洲第一黄色在线观看| 欧美亚洲偷拍自拍色图| 国产精品sm调教视频| 最新国产精品拍在线观看| 一区二区熟女人妻视频| 熟女人妻一区二区精品视频| 五十路熟女人妻一区二| 日本阿v视频在线免费观看| 日韩美女精品视频在线观看网站| 欧美精品中文字幕久久二区| 免费手机黄页网址大全| 538精品在线观看视频| 搡老熟女一区二区在线观看 | 国产三级精品三级在线不卡| 国产三级片久久久久久久| 久久99久久99精品影院| 99久久成人日韩欧美精品| 1区2区3区不卡视频| 97色视频在线观看| av视屏免费在线播放| 国产精品伦理片一区二区| 一级a看免费观看网站| 一区二区久久成人网| 精品国产亚洲av一淫| 中国黄色av一级片| 538精品在线观看视频| 亚洲av午夜免费观看| 综合一区二区三区蜜臀| av高潮迭起在线观看| 男人的天堂av日韩亚洲| 啊用力插好舒服视频| 色天天天天射天天舔| 综合激情网激情五月五月婷婷| 91在线视频在线精品3| 亚洲熟色妇av日韩熟色妇在线| 国产变态另类在线观看| 精品国产乱码一区二区三区乱| 999九九久久久精品| aⅴ五十路av熟女中出| 亚洲精品午夜久久久久| 三级黄色亚洲成人av| xxx日本hd高清| 适合午夜一个人看的视频| 制服丝袜在线人妻中文字幕| 欧美 亚洲 另类综合| 午夜青青草原网在线观看| 日韩二区视频一线天婷婷五| 偷拍3456eee| 欧美精品黑人性xxxx| 18禁无翼鸟成人在线| 91精品激情五月婷婷在线| 日韩激情文学在线视频| 欧美日韩亚洲国产无线码| 风流唐伯虎电视剧在线观看| 国产乱子伦精品视频潮优女| 高清一区二区欧美系列| av天堂加勒比在线| 精产国品久久一二三产区区别| 国产精品黄大片在线播放| 日韩伦理短片在线观看| 99久久超碰人妻国产| 久久久精品999精品日本| 婷婷综合蜜桃av在线| 亚洲的电影一区二区三区| 日韩欧美一级精品在线观看| 天天插天天色天天日| 天天操天天干天天日狠狠插| 欧美精品黑人性xxxx| 国产高清女主播在线| 人妻av无码专区久久绿巨人| 黄色黄色黄片78在线| 自拍偷拍一区二区三区图片| 91精品啪在线免费| 3D动漫精品啪啪一区二区下载| 久久国产精品精品美女| 婷婷激情四射在线观看视频| 五十路老熟女码av| 国产日本精品久久久久久久| 大鸡吧插入女阴道黄色片| 18禁网站一区二区三区四区| 国产高清女主播在线| av森泽佳奈在线观看| 激情小视频国产在线 | av中文字幕福利网| 免费无毒热热热热热热久| 天天操天天污天天射| 日日操综合成人av| 在线观看视频一区麻豆| 国产欧美精品一区二区高清| 欧亚乱色一区二区三区| 男人的网址你懂的亚洲欧洲av| 亚洲午夜精品小视频| 国产精品国产三级国产午| 天天射,天天操,天天说| 日韩a级黄色小视频| 国产黄色大片在线免费播放| 色爱av一区二区三区| 成人蜜桃美臀九一一区二区三区 | 丝袜肉丝一区二区三区四区在线| 蜜臀成人av在线播放| 91社福利《在线观看| 日韩在线视频观看有码在线| 日韩在线视频观看有码在线| 欧美精品久久久久久影院| 国产精品国产三级国产精东| 美女骚逼日出水来了| 天天干天天日天天谢综合156| 午夜精品福利91av| 黄工厂精品视频在线观看| 国产精品欧美日韩区二区| 精品国产午夜视频一区二区| 99热碰碰热精品a中文| 青青青青青青青青青青草青青 | 91人妻人人做人人爽在线| 国产午夜无码福利在线看| 免费69视频在线看| av在线观看网址av| 18禁无翼鸟成人在线| 99精品国产aⅴ在线观看| 欧洲日韩亚洲一区二区三区| 香蕉av影视在线观看| 十八禁在线观看地址免费| 任我爽精品视频在线播放| 伊人开心婷婷国产av| 亚洲推理片免费看网站| 一区二区三区的久久的蜜桃的视频 | 久久免费看少妇高潮完整版| 啊啊好慢点插舔我逼啊啊啊视频| 国产精品免费不卡av| 欧美一区二区三区高清不卡tv| 国产高清在线观看1区2区| 粗大的内捧猛烈进出爽大牛汉子| 熟女在线视频一区二区三区| 超pen在线观看视频公开97| 一区二区三区欧美日韩高清播放| 精品国产在线手机在线| 黄工厂精品视频在线观看 | 色噜噜噜噜18禁止观看| av在线播放国产不卡| 国产成人午夜精品福利| 亚洲一区久久免费视频| 男人天堂最新地址av| 2020国产在线不卡视频| 亚洲成人av一区久久| 好吊操视频这里只有精品| 天天想要天天操天天干| 久久国产精品精品美女| 午夜在线精品偷拍一区二| 可以在线观看的av中文字幕| 日本一区美女福利视频| av手机免费在线观看高潮| 亚洲日本一区二区三区| 最新91精品视频在线| 国产一线二线三线的区别在哪| 亚洲欧美国产综合777| av天堂中文免费在线| 午夜大尺度无码福利视频| 亚洲一区久久免费视频| 国产成人一区二区三区电影网站| 丰满少妇翘臀后进式| 国产亚州色婷婷久久99精品| 人妻少妇性色欲欧美日韩| 护士特殊服务久久久久久久| 天天日天天舔天天射进去| 亚洲第一伊人天堂网| 亚洲av午夜免费观看| 老有所依在线观看完整版 | 在线观看911精品国产 | 日本a级视频老女人| 性色av一区二区三区久久久| 日本性感美女写真视频| 国产麻豆剧传媒精品国产av蜜桃 | 视频在线免费观看你懂得| 日本一二三区不卡无| 日本一二三中文字幕| 欧美日本aⅴ免费视频| 亚洲丝袜老师诱惑在线观看| 91试看福利一分钟| 日本少妇人妻xxxxx18| 天天日天天干天天插舔舔| 在线视频这里只有精品自拍| 国产成人精品av网站| 天美传媒mv视频在线观看| 又黄又刺激的午夜小视频| 国产1区,2区,3区| 欧美中文字幕一区最新网址| av一本二本在线观看| 日本黄色三级高清视频| 午夜免费观看精品视频| 色花堂在线av中文字幕九九| 亚洲精品精品国产综合| 都市家庭人妻激情自拍视频| 粉嫩av蜜乳av蜜臀| 在线免费视频 自拍| 精品乱子伦一区二区三区免费播| 成人乱码一区二区三区av| 精品一区二区三四区| 久草视频 久草视频2| 丰满少妇人妻xxxxx| 女同互舔一区二区三区| 丰满少妇人妻xxxxx| www久久久久久久久久久| 无套猛戳丰满少妇人妻| 欧美日本国产自视大全| 护士小嫩嫩又紧又爽20p| 久久精品亚洲成在人线a| 视频一区二区三区高清在线| 偷拍自拍亚洲视频在线观看| 大屁股熟女一区二区三区| 动漫美女的小穴视频| 熟女人妻一区二区精品视频| 成人免费公开视频无毒| 97精品视频在线观看| 精品一区二区三四区| 日本一区二区三区免费小视频| 一区二区三区的久久的蜜桃的视频| 999热精品视频在线| 桃色视频在线观看一区二区| 亚洲伊人久久精品影院一美女洗澡| 欧美日本aⅴ免费视频| 久久精品国产999| 亚洲av男人天堂久久| 啊啊好大好爽啊啊操我啊啊视频| 欧美亚洲偷拍自拍色图| 免费国产性生活视频| 很黄很污很色的午夜网站在线观看| 日韩精品中文字幕播放| 国内资源最丰富的网站| 国产内射中出在线观看| 偷偷玩弄新婚人妻h视频| 亚洲天堂精品福利成人av| 女同久久精品秋霞网| 91成人在线观看免费视频| 午夜精品福利一区二区三区p| 国产精品熟女久久久久浪潮| 中文字幕 亚洲av| 粉嫩av懂色av蜜臀av| 天堂va蜜桃一区入口| 中文字幕欧美日韩射射一| 绝色少妇高潮3在线观看| 五十路熟女av天堂| 日韩av大胆在线观看| 蜜臀av久久久久蜜臀av麻豆| 黄色黄色黄片78在线| 在线免费观看黄页视频| 成人24小时免费视频| 韩国黄色一级二级三级| 天天日天天添天天爽| 2012中文字幕在线高清| 日韩熟女av天堂系列| 欧美精品 日韩国产| 年轻的人妻被夫上司侵犯| av网址在线播放大全| 超碰公开大香蕉97| 欧美性受xx黑人性猛交| 亚洲最大黄 嗯色 操 啊| 青青青青视频在线播放| heyzo蜜桃熟女人妻| 日日爽天天干夜夜操| 91精品国产91久久自产久强| 天天躁日日躁狠狠躁躁欧美av | 女生自摸在线观看一区二区三区| 在线免费观看靠比视频的网站 | 大香蕉大香蕉在线看| 亚洲av天堂在线播放| 日韩精品啪啪视频一道免费| 欧美男同性恋69视频| 精品人妻一二三区久久| 北条麻妃高跟丝袜啪啪| 日本熟妇喷水xxx| 1000部国产精品成人观看视频| 极品丝袜一区二区三区| 人妻熟女中文字幕aⅴ在线 | 99精品国自产在线人| 亚洲国产美女一区二区三区软件| 插小穴高清无码中文字幕| 成熟丰满熟妇高潮xx×xx| 熟女俱乐部一二三区| 一色桃子久久精品亚洲| 国产黄色片在线收看| 熟女国产一区亚洲中文字幕| 把腿张开让我插进去视频| 国产精品国产三级国产午| 欧美专区日韩专区国产专区| 91www一区二区三区| 黄色成年网站午夜在线观看| 好吊操视频这里只有精品| 精品视频一区二区三区四区五区| 熟女少妇激情五十路| 久久这里只有精品热视频| 国产精品欧美日韩区二区| 无忧传媒在线观看视频| 天天日天天玩天天摸| 麻豆性色视频在线观看| 人妻凌辱欧美丰满熟妇| 亚洲免费va在线播放| 啊慢点鸡巴太大了啊舒服视频| 一区二区熟女人妻视频| 综合激情网激情五月天| 午夜91一区二区三区| 天天爽夜夜爽人人爽QC| 一色桃子久久精品亚洲| 国产密臀av一区二区三| 亚洲图库另类图片区| 亚洲欧美成人综合视频| 国产精品人久久久久久| 中文字幕无码一区二区免费| 黄色成年网站午夜在线观看| 啪啪啪啪啪啪啪免费视频| 97精品视频在线观看| 国产一级麻豆精品免费| 日本一本午夜在线播放| 日本成人一区二区不卡免费在线| 成人高清在线观看视频| 国产视频网站一区二区三区| 亚洲精品 日韩电影| 亚洲色偷偷综合亚洲AV伊人| www天堂在线久久| 午夜dv内射一区区| 美味人妻2在线播放| 懂色av蜜桃a v| 视频在线免费观看你懂得| 亚洲精品一线二线在线观看| 亚洲天堂精品福利成人av| 国产中文字幕四区在线观看| 日韩熟女av天堂系列| 亚洲国产香蕉视频在线播放| 91九色porny蝌蚪国产成人| 成人亚洲精品国产精品| 少妇露脸深喉口爆吞精| 青青青视频自偷自拍38碰| 日韩午夜福利精品试看| 色在线观看视频免费的| 熟女妇女老妇一二三区| 黄色片年轻人在线观看| 日韩av有码中文字幕| 成人久久精品一区二区三区| 色综合色综合色综合色| 亚洲 中文 自拍 另类 欧美| 男人的网址你懂的亚洲欧洲av| 亚洲av成人网在线观看| 又色又爽又黄又刺激av网站| 亚洲福利精品视频在线免费观看| 欧美在线精品一区二区三区视频| 日韩欧美亚洲熟女人妻| 一区二区三区综合视频| 亚洲一区二区三区精品乱码| 欧美日韩国产一区二区三区三州| 天天操天天操天天碰| 亚洲自拍偷拍综合色| 美女吃鸡巴操逼高潮视频| 黄色大片免费观看网站| 亚洲视频在线观看高清| 亚洲免费成人a v| 手机看片福利盒子日韩在线播放| 五十路丰满人妻熟妇| 中文字幕 人妻精品| 亚洲 国产 成人 在线| 狠狠躁狠狠爱网站视频| 久久久久久9999久久久久| 日本韩国免费福利精品| 天天摸天天干天天操科普| 久草福利电影在线观看| 亚洲视频在线观看高清| 欧美色婷婷综合在线| 麻豆精品成人免费视频| 天天日天天干天天舔天天射| 18禁美女无遮挡免费| 亚洲熟妇x久久av久久| 91九色porny国产蝌蚪视频| 一区二区熟女人妻视频| 五十路在线观看完整版| 在线免费观看99视频| 免费费一级特黄真人片| 精品av国产一区二区三区四区 | 国产精品自拍在线视频| 国产精品伦理片一区二区| 伊人日日日草夜夜草| 天天色天天操天天透| 国产91久久精品一区二区字幕| 成人高清在线观看视频| 一区二区三区精品日本| 天天干天天操天天插天天日| 国产视频精品资源网站| 在线观看免费视频网| 中文字幕人妻熟女在线电影| 国产熟妇一区二区三区av| 18禁网站一区二区三区四区| 黄色中文字幕在线播放| 99re国产在线精品| 亚洲欧美在线视频第一页| 91国内精品自线在拍白富美| 动漫黑丝美女的鸡巴| 色哟哟国产精品入口| 久草视频在线一区二区三区资源站 | 黄工厂精品视频在线观看| 亚洲精品在线资源站| 精品少妇一二三视频在线| 欧美特级特黄a大片免费| 美女福利写真在线观看视频| avjpm亚洲伊人久久| 三级黄色亚洲成人av| 夜夜嗨av蜜臀av| 日本黄在免费看视频| 老有所依在线观看完整版| 午夜青青草原网在线观看| 自拍偷区二区三区麻豆| 后入美女人妻高清在线| 天天干天天啪天天舔| 久久久精品国产亚洲AV一| 成人av天堂丝袜在线观看| 国产成人精品久久二区91| 在线不卡成人黄色精品| 精品老妇女久久9g国产| 精品av国产一区二区三区四区| 91人妻精品久久久久久久网站 | 午夜久久香蕉电影网| 日韩在线视频观看有码在线| 成人国产影院在线观看| 欧美一级片免费在线成人观看| 国产精品自偷自拍啪啪啪| 亚洲va天堂va国产va久| 99热久久这里只有精品8| 日本人妻少妇18—xx| 亚洲青青操骚货在线视频| 天天射,天天操,天天说| 欧美乱妇无乱码一区二区| 国产福利在线视频一区| 久久久久久久久久一区二区三区| 日韩欧美中文国产在线| 中文字幕在线一区精品| 在线免费观看亚洲精品电影| 中国黄片视频一区91| 揄拍成人国产精品免费看视频| 啪啪啪啪啪啪啪啪啪啪黄色| 视频 一区二区在线观看| 天天日天天鲁天天操| 最新中文字幕乱码在线| 91精品资源免费观看| 性感美女诱惑福利视频| 黑人进入丰满少妇视频| 日韩av免费观看一区| 91天堂天天日天天操| 青青青青视频在线播放| 亚洲高清一区二区三区视频在线| 馒头大胆亚洲一区二区| 在线播放 日韩 av| 肏插流水妹子在线乐播下载| 日本女大学生的黄色小视频| 成人综合亚洲欧美一区| 自拍偷拍日韩欧美一区二区| 开心 色 六月 婷婷| 国产精品日韩欧美一区二区| 婷婷色中文亚洲网68| 粉嫩欧美美人妻小视频| 78色精品一区二区三区| av线天堂在线观看| 九九视频在线精品播放| 18禁美女羞羞免费网站| 日韩熟女系列一区二区三区| 91啪国自产中文字幕在线| 国产又大又黄免费观看| 国产亚州色婷婷久久99精品| 91av精品视频在线| 午夜精品福利91av| 国产精彩对白一区二区三区| 午夜婷婷在线观看视频| 日本五十路熟新垣里子| 99热这里只有国产精品6| 狠狠的往里顶撞h百合| 国产精品成久久久久三级蜜臀av| 成熟丰满熟妇高潮xx×xx| 在线不卡日韩视频播放| av视网站在线观看| 国产精品系列在线观看一区二区| gav成人免费播放| 日韩中文字幕在线播放第二页| 国产亚洲视频在线二区| 91久久人澡人人添人人爽乱| 蜜桃视频在线欧美一区| 欧美日本在线视频一区| 人人妻人人人操人人人爽| 国产视频一区二区午夜| 免费在线看的黄网站| 亚洲成人熟妇一区二区三区| 国产清纯美女al在线| 日韩少妇人妻精品无码专区| 日本av熟女在线视频| 亚洲天堂有码中文字幕视频| 青青青aaaa免费| 100%美女蜜桃视频| 少妇被强干到高潮视频在线观看 | 一区二区三区四区五区性感视频 | 亚洲人妻视频在线网| 91极品新人『兔兔』精品新作| 偷青青国产精品青青在线观看| 国产精品久久久久久久女人18| 小穴多水久久精品免费看| 好吊视频—区二区三区| 亚洲va欧美va人人爽3p| 国产av一区2区3区| 天天干天天插天天谢| 成人av中文字幕一区| 18禁美女黄网站色大片下载| 五十路熟女人妻一区二| 亚洲精品久久视频婷婷| 亚洲熟妇x久久av久久| 岳太深了紧紧的中文字幕| 国产精品久久久久久久精品视频| 三级等保密码要求条款| 在线观看欧美黄片一区二区三区| 在线免费观看黄页视频| 这里有精品成人国产99| 天堂av在线播放免费| 99av国产精品欲麻豆| 女人精品内射国产99| 国产成人自拍视频在线免费观看| 超碰中文字幕免费观看| 欧美精产国品一二三区| 中国熟女一区二区性xx| 这里有精品成人国产99| 午夜精品亚洲精品五月色| 欧美一级片免费在线成人观看| 国产视频一区在线观看| 狠狠鲁狠狠操天天晚上干干| 免费一级特黄特色大片在线观看| 91精品视频在线观看免费| 天天射夜夜操狠狠干| 午夜大尺度无码福利视频| 91天堂精品一区二区| av在线播放国产不卡| 午夜久久久久久久99| 国产精品国产三级麻豆| 精品久久久久久高潮| 婷婷久久久综合中文字幕| 最新黄色av网站在线观看| 日本熟女50视频免费| 日韩欧美国产一区不卡| 人妻熟女中文字幕aⅴ在线| 日本熟妇一区二区x x| 最新国产亚洲精品中文在线| 国产成人精品av网站| 狠狠鲁狠狠操天天晚上干干| 亚洲码av无色中文| 亚洲激情,偷拍视频| 亚洲精品欧美日韩在线播放| 99re久久这里都是精品视频| av成人在线观看一区| 视频 一区二区在线观看| 男生舔女生逼逼视频| 午夜在线观看岛国av,com| 欧美综合婷婷欧美综合| 久草视频在线一区二区三区资源站| 日韩加勒比东京热二区| 亚洲的电影一区二区三区| 88成人免费av网站| 天天干天天插天天谢| 在线免费观看99视频| 国产精品国产精品一区二区| 国产精品熟女久久久久浪潮| 一区二区三区四区中文| av天堂加勒比在线| 久草视频中文字幕在线观看| 日韩欧美国产精品91| 欧美韩国日本国产亚洲| 天天日天天鲁天天操| 国产91嫩草久久成人在线视频| 亚洲欧美国产麻豆综合| 农村胖女人操逼视频| 男女第一次视频在线观看| 欧美精品亚洲精品日韩在线| 国产精品久久综合久久| 在线免费观看黄页视频| 视频在线亚洲一区二区| 人妻激情图片视频小说| 自拍偷拍 国产资源| 91超碰青青中文字幕| 一区二区熟女人妻视频| 中文字幕免费在线免费| 女同互舔一区二区三区| 搡老熟女一区二区在线观看| 日韩美女精品视频在线观看网站| 天天日天天爽天天爽| 亚洲中文字幕综合小综合| 国产不卡av在线免费| 9久在线视频只有精品| 国产av国片精品一区二区| 97国产福利小视频合集| 黄色视频在线观看高清无码| 日本韩国免费一区二区三区视频 | 天天日天天舔天天射进去| 青青青青青青青青青青草青青 | 综合国产成人在线观看| 天天干天天啪天天舔| av在线播放国产不卡| 天天射夜夜操综合网| 日本人妻欲求不满中文字幕| chinese国产盗摄一区二区 | 亚洲精品一线二线在线观看| 99一区二区在线观看| 久久丁香婷婷六月天| 91国内精品自线在拍白富美| 亚洲午夜电影之麻豆| 人妻激情图片视频小说| 亚洲欧美成人综合在线观看| 十八禁在线观看地址免费| 啪啪啪啪啪啪啪免费视频| 中文字幕第1页av一天堂网| 天天日天天干天天干天天日| 老司机深夜免费福利视频在线观看| 成年午夜影片国产片| 婷婷久久久久深爱网| 大鸡巴插入美女黑黑的阴毛| 欧洲精品第一页欧洲精品亚洲| 黄色片年轻人在线观看| 粉嫩av懂色av蜜臀av| av新中文天堂在线网址| 在线免费观看亚洲精品电影 | 久久热久久视频在线观看| 免费在线观看污污视频网站| 亚洲精品色在线观看视频| 可以在线观看的av中文字幕| 日韩av免费观看一区| 国产精品人妻熟女毛片av久| 亚洲欧美另类手机在线| 日韩不卡中文在线视频网站| 国产污污污污网站在线| 18禁网站一区二区三区四区| 日曰摸日日碰夜夜爽歪歪| 99国产精品窥熟女精品| 日韩不卡中文在线视频网站| 日本xx片在线观看| 插逼视频双插洞国产操逼插洞| 少妇ww搡性bbb91| 国产日韩一区二区在线看 | 91麻豆精品传媒国产黄色片| 欧美va亚洲va天堂va| 欧美一区二区三区乱码在线播放| 91chinese在线视频| 操的小逼流水的文章| 好吊视频—区二区三区| 亚洲精品色在线观看视频| 亚洲精品午夜久久久久| 在线观看免费视频网| japanese五十路熟女熟妇| 蜜桃精品久久久一区二区| jiujiure精品视频在线| 免费黄高清无码国产| 四虎永久在线精品免费区二区| 热99re69精品8在线播放| 青青青爽视频在线播放| 91‖亚洲‖国产熟女| av在线免费中文字幕| 色秀欧美视频第一页| 六月婷婷激情一区二区三区| 在线视频自拍第三页| 亚洲少妇高潮免费观看| 亚洲国产免费av一区二区三区 | 亚洲午夜伦理视频在线| 国产高清在线在线视频| 黄色成年网站午夜在线观看| 国产密臀av一区二区三| 国产精品成人xxxx| 中国视频一区二区三区| 青青青视频自偷自拍38碰| 国产女人叫床高潮大片视频| 不卡日韩av在线观看| 国产日韩欧美视频在线导航| 亚洲 欧美 精品 激情 偷拍| 狠狠鲁狠狠操天天晚上干干| 黄色视频在线观看高清无码| 日本少妇的秘密免费视频| 色爱av一区二区三区| 欧美3p在线观看一区二区三区| h国产小视频福利在线观看| 国产成人精品亚洲男人的天堂| 日日摸夜夜添夜夜添毛片性色av| av亚洲中文天堂字幕网| 人妻久久久精品69系列| 亚洲护士一区二区三区| 亚洲欧美色一区二区| 精品suv一区二区69| 亚洲午夜伦理视频在线| 精品一区二区三区三区88 | 日韩国产乱码中文字幕| 红桃av成人在线观看| 国产av福利网址大全| 国产精品人妻66p| 亚洲中文字幕综合小综合| 精品国产高潮中文字幕| 国产麻豆剧传媒精品国产av蜜桃| 91精品国产黑色丝袜| 国产丰满熟女成人视频| 国产又粗又黄又硬又爽| 人妻熟女中文字幕aⅴ在线| 99精品国自产在线人| 北条麻妃高跟丝袜啪啪| 一区二区免费高清黄色视频| 国产成人自拍视频在线免费观看| 欧美乱妇无乱码一区二区| 亚洲无码一区在线影院| 久久丁香花五月天色婷婷| 久久这里只有精品热视频| 黑人乱偷人妻中文字幕| 在线免费观看日本伦理| 亚洲av极品精品在线观看| 欧美日本aⅴ免费视频| 57pao国产一区二区| 天天日天天天天天天天天天天| 欧美 亚洲 另类综合| 91p0rny九色露脸熟女| 91精品国产麻豆国产| 亚洲在线免费h观看网站| 熟女91pooyn熟女| tube69日本少妇| av在线免费资源站| 亚洲日本一区二区久久久精品| 成年女人免费播放视频| 9久在线视频只有精品| 视频一区二区综合精品| 又粗又硬又猛又爽又黄的| 欧美xxx成人在线| 大鸡巴操娇小玲珑的女孩逼| 黄色的网站在线免费看| 成年女人免费播放视频| 人人妻人人澡人人爽人人dvl| 激情综合治理六月婷婷| 欧美 亚洲 另类综合| 久久这里只有精彩视频免费| 人妻无码色噜噜狠狠狠狠色| 亚洲国产免费av一区二区三区 | 91国内精品久久久久精品一| 国产精品久久久久久久久福交 | 亚洲精品一线二线在线观看| 岛国av高清在线成人在线| 午夜精品一区二区三区城中村| 午夜激情久久不卡一区二区| 日曰摸日日碰夜夜爽歪歪| 传媒在线播放国产精品一区| 伊人网中文字幕在线视频| 九一传媒制片厂视频在线免费观看| 涩涩的视频在线观看视频| 五月激情婷婷久久综合网| 日本高清在线不卡一区二区| 国产福利小视频免费观看| 亚洲精品乱码久久久本| 天天干天天日天天谢综合156| 综合色区亚洲熟妇shxstz| 在线制服丝袜中文字幕| 超黄超污网站在线观看| 成年人午夜黄片视频资源| 孕妇奶水仑乱A级毛片免费看 | 天天干夜夜操啊啊啊| 中文字幕 亚洲av| 日韩近亲视频在线观看| 中文字幕中文字幕人妻| 久久这里只有精品热视频 | 日韩加勒比东京热二区| 中文字幕乱码人妻电影| 91在线免费观看成人| 亚洲av色香蕉一区二区三区| 夜色福利视频在线观看| 国产综合视频在线看片| 老鸭窝日韩精品视频观看| 天天日天天干天天插舔舔| okirakuhuhu在线观看| 天天日夜夜操天天摸| 一区二区三区四区视频在线播放| 久久免费看少妇高潮完整版| 2012中文字幕在线高清| 91成人精品亚洲国产| 亚洲人妻国产精品综合| 中文字幕无码一区二区免费| 国产欧美日韩在线观看不卡| 中文字幕之无码色多多| 天堂av狠狠操蜜桃| 亚洲高清国产拍青青草原| 精品久久久久久久久久久久人妻| 久草视频在线免播放| 做爰视频毛片下载蜜桃视频1| 啊啊啊想要被插进去视频| 欧美精品黑人性xxxx| 欧美国品一二三产区区别| 97色视频在线观看| 国产精品人妻熟女毛片av久| 蜜桃臀av蜜桃臀av| 含骚鸡巴玩逼逼视频| 国产va精品免费观看| 日韩写真福利视频在线观看| 国产大学生援交正在播放| 精品老妇女久久9g国产| 天干天天天色天天日天天射| 阴茎插到阴道里面的视频| 午夜精品一区二区三区更新| 日本精品一区二区三区在线视频。 | 日日夜夜大香蕉伊人| 大鸡巴操娇小玲珑的女孩逼| 天天射夜夜操综合网| 欧美老妇精品另类不卡片| 91成人精品亚洲国产| 日韩激情文学在线视频| 91chinese在线视频| 天堂中文字幕翔田av| 国产在线观看免费人成短视频| 40道精品招牌菜特色| 亚洲高清国产一区二区三区| 日本一道二三区视频久久| 午夜精品亚洲精品五月色| 日本黄色特一级视频| wwwxxx一级黄色片| aaa久久久久久久久| av在线观看网址av| 成人在线欧美日韩国产| 亚洲国产欧美一区二区三区久久 | 99国产精品窥熟女精品| 黄色大片免费观看网站| 国产综合视频在线看片| 姐姐的朋友2在线观看中文字幕 | 国产日韩精品电影7777| 少妇人妻二三区视频| 激情综合治理六月婷婷| 久久久久久久99精品| 超黄超污网站在线观看| 日本美女成人在线视频| 欧美精品亚洲精品日韩在线| 亚洲图库另类图片区| 国产精品黄片免费在线观看| 亚洲国产精品久久久久久6| 韩国三级aaaaa高清视频| 国产福利小视频大全| 婷婷六月天中文字幕| 亚洲精品国产综合久久久久久久久| 婷婷色国产黑丝少妇勾搭AV| 亚洲av无码成人精品区辽| 国产三级影院在线观看| 亚洲国产欧美一区二区三区…| 亚洲最大免费在线观看| 天天日天天舔天天射进去| 国产日本精品久久久久久久| 久久久久只精品国产三级| 动漫精品视频在线观看| 亚洲av男人天堂久久| 亚洲高清视频在线不卡| 97少妇精品在线观看| 中文字幕在线欧美精品| 大陆胖女人与丈夫操b国语高清| gav成人免费播放| 天天操天天爽天天干| 日本午夜福利免费视频| 亚洲国产最大av综合| 久久永久免费精品人妻专区| 久久久噜噜噜久久熟女av| 91人妻精品一区二区久久| AV无码一区二区三区不卡| 中文字幕高清资源站| 天天躁日日躁狠狠躁av麻豆| 国产女人露脸高潮对白视频| 成人色综合中文字幕| 一二三中文乱码亚洲乱码one | 成人av免费不卡在线观看| 日韩欧美国产一区不卡| 18禁美女羞羞免费网站| 亚洲 欧美 精品 激情 偷拍| 狠狠操操操操操操操操操| 国产免费av一区二区凹凸四季| 亚洲特黄aaaa片| av在线免费观看亚洲天堂| 精品国产成人亚洲午夜| 五月天中文字幕内射| 自拍偷拍亚洲另类色图| 少妇高潮无套内谢麻豆| 馒头大胆亚洲一区二区| 2020久久躁狠狠躁夜夜躁| 亚洲成人熟妇一区二区三区| 日韩a级黄色小视频| 久久久久久久一区二区三| 天天日天天日天天射天天干| 91麻豆精品秘密入口在线观看| heyzo蜜桃熟女人妻| 在线可以看的视频你懂的| 成年人黄视频在线观看| 欧美成人精品在线观看| 亚洲乱码中文字幕在线| 国产伦精品一区二区三区竹菊| 亚洲综合图片20p| 爆乳骚货内射骚货内射在线| 青春草视频在线免费播放| 五月精品丁香久久久久福利社| 欧美日韩一级黄片免费观看| 韩国女主播精品视频网站| 国产男女视频在线播放| 久久久久久久精品老熟妇| 国产剧情演绎系列丝袜高跟| 毛片一级完整版免费| 91精品综合久久久久3d动漫| 美味人妻2在线播放| 夫妻在线观看视频91| 自拍偷拍日韩欧美亚洲| www,久久久,com| 99热这里只有国产精品6| 丁香花免费在线观看中文字幕| 日韩亚国产欧美三级涩爱| 99热99这里精品6国产| 亚洲va欧美va人人爽3p| 日本韩国在线观看一区二区| 欧美成人精品在线观看| 熟女俱乐部一二三区| 91香蕉成人app下载| 日本啪啪啪啪啪啪啪| 91免费观看国产免费| 国产中文字幕四区在线观看| 少妇人妻久久久久视频黄片| 国产精品国产三级国产精东| 在线播放国产黄色av| 久久精品国产亚洲精品166m| 精品suv一区二区69| 黄色成年网站午夜在线观看| 韩国黄色一级二级三级| 91人妻精品一区二区在线看| 天天日天天天天天天天天天天| 一二三区在线观看视频| 91国产在线免费播放| 中英文字幕av一区| 国产福利小视频免费观看| 成人18禁网站在线播放| 欧美亚洲自偷自拍 在线| 欧美一区二区三区啪啪同性| 精品少妇一二三视频在线| 99精品久久久久久久91蜜桃| 一级黄色片夫妻性生活| 视频一区二区综合精品| 亚洲欧美国产麻豆综合| 51国产成人精品视频| 在线观看视频一区麻豆| 日美女屁股黄邑视频| 成人av免费不卡在线观看| 丝袜肉丝一区二区三区四区在线| 999九九久久久精品| 天天操天天弄天天射| 青草亚洲视频在线观看| 岛国av高清在线成人在线| 久久久久久久久久久免费女人| 老司机免费视频网站在线看| 日本少妇在线视频大香蕉在线观看| 国产又色又刺激在线视频 | 9色在线视频免费观看| 午夜精品亚洲精品五月色| 日韩特级黄片高清在线看| 日韩美女综合中文字幕pp| 亚洲欧美一区二区三区电影| 国产日韩欧美视频在线导航| 亚洲 国产 成人 在线| 成人久久精品一区二区三区| 巨乳人妻日下部加奈被邻居中出| 看一级特黄a大片日本片黑人| 亚洲免费国产在线日韩| 老鸭窝日韩精品视频观看| 少妇与子乱在线观看| 国产麻豆91在线视频| 伊人综合aⅴ在线网| 国产黑丝高跟鞋视频在线播放| 涩涩的视频在线观看视频| brazzers欧熟精品系列| 五月天中文字幕内射| 黄片大全在线观看观看| 亚洲在线一区二区欧美| 六月婷婷激情一区二区三区| 国产一级麻豆精品免费| 91超碰青青中文字幕| 亚洲粉嫩av一区二区三区| 亚洲成人黄色一区二区三区| 操人妻嗷嗷叫视频一区二区| 视频 一区二区在线观看| 很黄很污很色的午夜网站在线观看| 99精品亚洲av无码国产另类| 午夜精品福利一区二区三区p | 日本熟妇喷水xxx| 91极品大一女神正在播放| 中文字幕一区二区三区人妻大片| 中文字幕综合一区二区| 91片黄在线观看喷潮| 午夜免费体验区在线观看| 国产露脸对白在线观看| 亚洲国产精品中文字幕网站| 女蜜桃臀紧身瑜伽裤| 亚洲高清一区二区三区视频在线| 视频在线亚洲一区二区| 国产亚州色婷婷久久99精品| 中文字幕日韩人妻在线三区| 国产aⅴ一线在线观看| 成人精品在线观看视频| av网站色偷偷婷婷网男人的天堂| 午夜美女少妇福利视频| 国产妇女自拍区在线观看| 岛国av高清在线成人在线| 日本三极片视频网站观看| 特一级特级黄色网片| 中文字幕高清在线免费播放| 欧美专区日韩专区国产专区| 人人妻人人爱人人草| 欧美特色aaa大片| 亚洲精品一线二线在线观看| 免费在线黄色观看网站| 成人av中文字幕一区| 成人国产小视频在线观看| 92福利视频午夜1000看| 特大黑人巨大xxxx| 熟女国产一区亚洲中文字幕| 91人妻人人做人人爽在线| 91精品视频在线观看免费| 91精品免费久久久久久| 东游记中文字幕版哪里可以看到| 成年女人免费播放视频| 午夜精品一区二区三区4| japanese五十路熟女熟妇| 亚洲欧美一卡二卡三卡| 2o22av在线视频| 日韩美女福利视频网| 99久久久无码国产精品性出奶水| 狍和女人的王色毛片| 日本熟女50视频免费| 精品91高清在线观看| 日韩av中文在线免费观看| 91成人在线观看免费视频| 亚洲精品高清自拍av| 最新91九色国产在线观看| 亚洲av色图18p| 天天日天天透天天操| 午夜在线一区二区免费| 国产视频一区在线观看| 亚洲精品久久综合久| 国产91精品拍在线观看| 欧洲亚洲欧美日韩综合| 黄页网视频在线免费观看| 人人妻人人澡人人爽人人dvl| 天天日天天添天天爽| 中出中文字幕在线观看| 免费观看成年人视频在线观看| 黄色男人的天堂视频| 99婷婷在线观看视频| 国产又粗又猛又爽又黄的视频美国| 91极品大一女神正在播放| 国产精品福利小视频a| 国产精品久久综合久久| 成人av中文字幕一区| 午夜大尺度无码福利视频| 人妻熟女在线一区二区| 亚洲图片偷拍自拍区| 久久久久久久久久久免费女人| 在线免费视频 自拍| 一色桃子久久精品亚洲| 精内国产乱码久久久久久| 少妇人妻二三区视频| 午夜91一区二区三区| 日本脱亚入欧是指什么| 少妇系列一区二区三区视频| 美女 午夜 在线视频| 亚洲的电影一区二区三区 | 亚洲免费国产在线日韩| 国产精品国色综合久久| 无码日韩人妻精品久久| 午夜免费观看精品视频| 人妻久久久精品69系列| 爆乳骚货内射骚货内射在线 | 美日韩在线视频免费看| 青青在线视频性感少妇和隔壁黑丝 | 亚洲伊人av天堂有码在线| 一二三区在线观看视频| 97瑟瑟超碰在线香蕉| 老熟妇凹凸淫老妇女av在线观看| nagger可以指黑人吗| 肏插流水妹子在线乐播下载 | 高潮喷水在线视频观看| 亚洲av无码成人精品区辽| 午夜久久香蕉电影网| av男人天堂狠狠干| 夜女神免费福利视频| 久久三久久三久久三久久| 日韩欧美国产精品91| 大尺度激情四射网站| 38av一区二区三区| 97瑟瑟超碰在线香蕉| sspd152中文字幕在线| 天天爽夜夜爽人人爽QC| 婷婷综合蜜桃av在线| 韩国三级aaaaa高清视频| 成年人的在线免费视频| 免费高清自慰一区二区三区网站| 2020中文字幕在线播放| 在线免费观看欧美小视频| 青娱乐蜜桃臀av色| 欧美怡红院视频在线观看| 久久精品国产999| 国产午夜无码福利在线看| 在线亚洲天堂色播av电影| 国产一线二线三线的区别在哪| 精品人妻每日一部精品| 自拍 日韩 欧美激情| 日韩人妻在线视频免费| 久久久久五月天丁香社区| 欧美爆乳肉感大码在线观看| 亚洲av色图18p| 2020久久躁狠狠躁夜夜躁 | 在线观看免费av网址大全| 国产日本精品久久久久久久| 天天日天天添天天爽| 亚洲超碰97人人做人人爱| 人妻av无码专区久久绿巨人| 一区二区三区日本伦理| 国产一区二区欧美三区| 午夜精品在线视频一区| 黄色男人的天堂视频| 亚洲精品久久综合久| 天天干天天操天天扣| 98视频精品在线观看| 性色av一区二区三区久久久| 青草亚洲视频在线观看| 人妻激情图片视频小说| 男人操女人的逼免费视频| 国产成人自拍视频在线免费观看| 日本福利午夜电影在线观看| 免费黄色成人午夜在线网站| 自拍偷区二区三区麻豆| 91国产在线免费播放| 99久久99久国产黄毛片| 国产日韩av一区二区在线| 久久久久国产成人精品亚洲午夜| 欧美精品国产综合久久| 亚洲精品成人网久久久久久小说| 开心 色 六月 婷婷| 99精品亚洲av无码国产另类| 亚洲码av无色中文| 亚洲av成人网在线观看| 午夜91一区二区三区| 水蜜桃国产一区二区三区| 91香蕉成人app下载| 高潮喷水在线视频观看| 年轻的人妻被夫上司侵犯| 婷婷久久久综合中文字幕| 99精品视频在线观看免费播放 | 亚洲国产在线精品国偷产拍| 91桃色成人网络在线观看| 搞黄色在线免费观看| 亚洲欧洲一区二区在线观看| 欧美黑人性暴力猛交喷水| 2022天天干天天操| 最新国产亚洲精品中文在线| 午夜在线观看岛国av,com| 99精品久久久久久久91蜜桃| 91福利视频免费在线观看| 99热这里只有国产精品6| 亚洲熟女女同志女同| 欧美交性又色又爽又黄麻豆| 亚洲伊人久久精品影院一美女洗澡 | 久草视频 久草视频2| 人人人妻人人澡人人| 国产日韩精品免费在线| 91极品新人『兔兔』精品新作| 日韩成人综艺在线播放| 超鹏97历史在线观看| 丰满熟女午夜福利视频| 18禁美女羞羞免费网站| 激情图片日韩欧美人妻| 国产卡一卡二卡三乱码手机| 新97超碰在线观看| 久草极品美女视频在线观看| 9国产精品久久久久老师 | 2021天天色天天干| 成年午夜影片国产片| 国产变态另类在线观看| 在线免费观看日本伦理| 2020久久躁狠狠躁夜夜躁| 97人妻无码AV碰碰视频| 91chinese在线视频| 中文字幕1卡1区2区3区| 亚洲av色香蕉一区二区三区| 果冻传媒av一区二区三区 | 欧美亚洲国产成人免费在线 | 精产国品久久一二三产区区别| 欧洲精品第一页欧洲精品亚洲| 91在线免费观看成人| 欧美精品黑人性xxxx| 欧美中国日韩久久精品| 亚洲天堂精品久久久| 国产精品成久久久久三级蜜臀av| 人妻3p真实偷拍一二区| 亚洲av色香蕉一区二区三区| 国产在线拍揄自揄视频网站| 人妻少妇亚洲精品中文字幕| 搡老妇人老女人老熟女| 美女日逼视频免费观看| 熟女国产一区亚洲中文字幕| 国产精品精品精品999| 特黄老太婆aa毛毛片| 亚洲国产成人av在线一区| 午夜精品福利一区二区三区p| 欧美视频综合第一页| 国产一区二区三免费视频| 国产精品久久久久久久精品视频| 亚洲av无硬久久精品蜜桃| 亚洲一区二区三区久久午夜| 韩国黄色一级二级三级| 57pao国产一区二区| 午夜青青草原网在线观看| 青青青青青青青青青青草青青| av在线播放国产不卡| 深夜男人福利在线观看| 国产实拍勾搭女技师av在线| 老司机免费福利视频网| 国产一区二区火爆视频| 欧美日韩一区二区电影在线观看| 偷拍自拍福利视频在线观看| 大香蕉伊人中文字幕| 三上悠亚和黑人665番号| 黄片色呦呦视频免费看| 日本午夜爽爽爽爽爽视频在线观看 | 蜜臀av久久久久久久| 亚洲精品一区二区三区老狼| 日韩精品啪啪视频一道免费| 好太好爽好想要免费| 韩国三级aaaaa高清视频| 亚洲av极品精品在线观看| AV无码一区二区三区不卡| 午夜美女少妇福利视频| 美女av色播在线播放| 99re久久这里都是精品视频| 蜜桃视频入口久久久| 狍和女人的王色毛片| 伊人网中文字幕在线视频| 97人人模人人爽人人喊| 黑人巨大的吊bdsm| 日本a级视频老女人| 久久久久久久久久一区二区三区| 人人妻人人人操人人人爽| 国产真实乱子伦a视频| 天码人妻一区二区三区在线看| 91人妻精品久久久久久久网站 | 一区国内二区日韩三区欧美| 免费岛国喷水视频在线观看| 农村胖女人操逼视频| 少妇与子乱在线观看| 天天操天天干天天日狠狠插| 内射久久久久综合网| av手机在线观播放网站| 欧美一区二区三区在线资源| 天天操,天天干,天天射| 国产精品国产三级麻豆| 亚洲国产精品美女在线观看| 亚洲高清视频在线不卡| 青青青青青手机视频| 国产亚洲视频在线观看| 免费观看丰满少妇做受| 天天爽夜夜爽人人爽QC| 国产不卡av在线免费| 五十路熟女av天堂| 18禁美女羞羞免费网站| 欧美精品中文字幕久久二区| 日本在线不卡免费视频| 亚洲 清纯 国产com| 国产精品手机在线看片| 欧美日韩不卡一区不区二区| 2019av在线视频| 蝴蝶伊人久久中文娱乐网| 日本精品美女在线观看| 亚洲日本一区二区久久久精品| 青青草成人福利电影| 天天日天天鲁天天操| 五十路在线观看完整版| 久久热久久视频在线观看| 97国产精品97久久| 四川五十路熟女av| 亚洲人成精品久久久久久久| 91国产在线视频免费观看| 内射久久久久综合网| av网址在线播放大全| 日本成人不卡一区二区| av大全在线播放免费| 婷婷久久久综合中文字幕| 日韩国产乱码中文字幕| 亚洲国产欧美国产综合在线| 午夜精品在线视频一区| 亚洲熟女久久久36d| 亚洲熟妇久久无码精品| 91快播视频在线观看| 中文字幕,亚洲人妻| 亚洲av在线观看尤物| 大鸡巴操娇小玲珑的女孩逼| 国产日本欧美亚洲精品视| 国内自拍第一页在线观看| 手机看片福利盒子日韩在线播放| 亚洲av色图18p| 日韩人妻xxxxx| 综合一区二区三区蜜臀| 女人精品内射国产99| 亚洲美女美妇久久字幕组| 日本韩国免费一区二区三区视频| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 国产视频网站国产视频| 91九色国产porny蝌蚪| 亚洲熟女久久久36d| 国产性生活中老年人视频网站| 亚洲图片偷拍自拍区| 欧美美女人体视频一区| 蜜臀av久久久久蜜臀av麻豆| 久久久久久九九99精品| 搡老熟女一区二区在线观看| 黄色视频在线观看高清无码| 大陆精品一区二区三区久久| 亚洲精品色在线观看视频| 青青青激情在线观看视频| 色婷婷久久久久swag精品| 国产精品sm调教视频| 日本美女成人在线视频| www久久久久久久久久久| 国产av自拍偷拍盛宴| 欧美一区二区三区啪啪同性| 日韩欧美一级黄片亚洲| 午夜影院在线观看视频羞羞羞| 精品成人午夜免费看| 免费无码人妻日韩精品一区二区 | 中国熟女@视频91| 一级黄色片夫妻性生活| 午夜免费观看精品视频| 韩国亚洲欧美超一级在线播放视频 | 一个色综合男人天堂| 春色激情网欧美成人| 最近中文字幕国产在线| 又粗又硬又猛又爽又黄的| 99精品国产免费久久| 好吊操视频这里只有精品| 精品久久久久久久久久中文蒉| sw137 中文字幕 在线| 在线观看视频一区麻豆| 天天日夜夜操天天摸| 黄色三级网站免费下载| 亚洲2021av天堂| 亚洲av日韩精品久久久久久hd| 麻豆精品成人免费视频| 欧洲精品第一页欧洲精品亚洲| 亚洲国产精品久久久久久6| 2025年人妻中文字幕乱码在线| 亚洲国产精品久久久久久6| 亚洲av色图18p| 久久久久久九九99精品| 亚洲国产成人在线一区| 无码精品一区二区三区人| 农村胖女人操逼视频| 精品国产亚洲av一淫| 国产福利在线视频一区| 黄色的网站在线免费看| 快点插进来操我逼啊视频| 福利午夜视频在线合集| 黄色在线观看免费观看在线| 日本一二三区不卡无| 国产福利在线视频一区| 亚洲 国产 成人 在线| 大鸡吧插入女阴道黄色片| gay gay男男瑟瑟在线网站| 日韩av中文在线免费观看| 特一级特级黄色网片| 精品国产午夜视频一区二区| 91天堂精品一区二区| 亚洲国产成人最新资源| 91国产资源在线视频| 天天干天天操天天爽天天摸| 亚洲精品三级av在线免费观看 | 91p0rny九色露脸熟女| 午夜dv内射一区区| 传媒在线播放国产精品一区| 免费无毒热热热热热热久| 国产美女午夜福利久久| 3337p日本欧洲大胆色噜噜| 亚洲图片偷拍自拍区| 亚洲一级 片内射视正片| 国产亚洲精品欧洲在线观看| 久久久超爽一二三av| av大全在线播放免费| 91麻豆精品传媒国产黄色片| 日本后入视频在线观看| 天天躁夜夜躁日日躁a麻豆| 欧美伊人久久大香线蕉综合| 久久精品亚洲成在人线a| 扒开让我视频在线观看| 精品黑人巨大在线一区| 国产一级麻豆精品免费| 好太好爽好想要免费| 九色精品视频在线播放| 啪啪啪啪啪啪啪免费视频| 自拍偷拍日韩欧美亚洲| 亚洲欧美激情中文字幕| 老司机免费福利视频网| 国产精品一区二区三区蜜臀av| 中文字幕亚洲久久久| 1区2区3区不卡视频| 亚洲免费va在线播放| 手机看片福利盒子日韩在线播放| 欧美日韩不卡一区不区二区| 亚洲中文字幕校园春色| 亚洲午夜在线视频福利| 偷拍自拍福利视频在线观看| 蜜桃视频17c在线一区二区| 老司机深夜免费福利视频在线观看| 日韩中文字幕精品淫| 精品一区二区三区在线观看| 亚洲男人让女人爽的视频| 91人妻精品一区二区久久| 日本午夜福利免费视频| 在线新三级黄伊人网| 黄色资源视频网站日韩| 中文字幕在线观看极品视频| 日韩av中文在线免费观看| 动色av一区二区三区| 少妇人妻久久久久视频黄片| 日韩欧美在线观看不卡一区二区| 黑人乱偷人妻中文字幕| www,久久久,com| 在线观看的a站 最新| 午夜在线观看一区视频| 国产精品亚洲а∨天堂免| 欧美亚洲牲夜夜综合久久| 男人操女人的逼免费视频| 亚洲熟女综合色一区二区三区四区| 久久久久只精品国产三级| 国产福利小视频二区| 最新国产亚洲精品中文在线| 亚洲在线一区二区欧美| 伊人网中文字幕在线视频| 淫秽激情视频免费观看| 国语对白xxxx乱大交| 日日夜夜大香蕉伊人| 国产精品人久久久久久| 日韩在线中文字幕色| 成人在线欧美日韩国产| 欧美精品一区二区三区xxxx| 天天色天天操天天透| 日本少妇在线视频大香蕉在线观看| 自拍偷拍日韩欧美亚洲| 日本最新一二三区不卡在线| 中国黄片视频一区91| 夜夜操,天天操,狠狠操| 亚洲女人的天堂av| 伊人情人综合成人久久网小说| 欧美80老妇人性视频| 亚洲av色图18p| av成人在线观看一区| av网站色偷偷婷婷网男人的天堂| 国产第一美女一区二区三区四区 | 亚洲成高清a人片在线观看| 男生用鸡操女生视频动漫| 岳太深了紧紧的中文字幕| 五十路熟女人妻一区二| 国产午夜激情福利小视频在线| 亚洲激情唯美亚洲激情图片| 免费黄页网站4188| 女警官打开双腿沦为性奴| 国产三级片久久久久久久| 2018最新中文字幕在线观看| 中文字幕国产专区欧美激情| 香蕉片在线观看av| 国产日韩欧美视频在线导航| 日韩一个色综合导航| 日本高清在线不卡一区二区| gogo国模私拍视频| 亚洲av成人免费网站| 成年人免费看在线视频| 在线新三级黄伊人网| 亚洲一区二区久久久人妻| 黄色无码鸡吧操逼视频| 香蕉91一区二区三区| 亚洲中文字幕综合小综合| 国产美女精品福利在线| 天天干夜夜操天天舔| 91国偷自产一区二区三区精品| 亚洲福利精品视频在线免费观看| 久草视频在线看免费| 中文字幕第一页国产在线| a v欧美一区=区三区| 91自产国产精品视频| 久久农村老妇乱69系列| 黑人变态深video特大巨大| 久久精品视频一区二区三区四区| 最近中文2019年在线看| 亚洲 中文 自拍 另类 欧美| 亚洲精品麻豆免费在线观看| 亚洲中文精品字幕在线观看 | 欧美香蕉人妻精品一区二区| 日本www中文字幕| 青青热久免费精品视频在线观看 | 亚洲一区自拍高清免费视频| 一区二区三区日韩久久| 亚洲中文精品人人免费| 日韩熟女系列一区二区三区| 国产一区二区在线欧美| 亚洲少妇高潮免费观看| 91精品国产观看免费| 一区二区视频在线观看免费观看 | 人妻丝袜精品中文字幕| 97人人模人人爽人人喊| 色综合久久无码中文字幕波多| 综合国产成人在线观看| 一二三中文乱码亚洲乱码one| 农村胖女人操逼视频| 91国产在线免费播放| 亚洲超碰97人人做人人爱| 99精品一区二区三区的区| 中文字幕日本人妻中出| 亚洲va国产va欧美va在线| 香蕉aⅴ一区二区三区| 亚洲一区二区三区av网站| 久久久噜噜噜久久熟女av| 自拍偷拍亚洲欧美在线视频| 日本黄色三级高清视频| 精品乱子伦一区二区三区免费播| 亚洲一级特黄特黄黄色录像片| 啪啪啪18禁一区二区三区 | 国产使劲操在线播放| 美女 午夜 在线视频| 美洲精品一二三产区区别| 日本韩国亚洲综合日韩欧美国产| 瑟瑟视频在线观看免费视频| 91she九色精品国产| 亚洲一区二区三区av网站| 国产精品探花熟女在线观看| 天天干天天爱天天色| 日本高清在线不卡一区二区| 亚洲av黄色在线网站| 日本xx片在线观看| 美女在线观看日本亚洲一区| 成人24小时免费视频| 亚洲av第国产精品| 91免费观看在线网站 | 亚洲精品国品乱码久久久久| 美女被肏内射视频网站| 99亚洲美女一区二区三区| 少妇人妻100系列| 亚洲专区激情在线观看视频| 亚洲精品福利网站图片| 在线不卡成人黄色精品| 天天操,天天干,天天射| 天天摸天天日天天操| 91麻豆精品传媒国产黄色片| 最新激情中文字幕视频| 婷婷六月天中文字幕| 国产精品中文av在线播放| 亚洲Av无码国产综合色区| 蜜桃色婷婷久久久福利在线| 中文字幕人妻av在线观看| 亚洲另类综合一区小说| 九九视频在线精品播放| 日本高清成人一区二区三区| 在线观看视频 你懂的| 亚洲精品成人网久久久久久小说| 夜色17s精品人妻熟女| 国产午夜亚洲精品麻豆| 性欧美激情久久久久久久| 午夜婷婷在线观看视频| 国产又大又黄免费观看| 精品av久久久久久久| 人妻3p真实偷拍一二区| 亚洲av日韩av第一区二区三区| 国产精品探花熟女在线观看| 免费观看理论片完整版| 亚洲最大黄了色网站| 97人人妻人人澡人人爽人人精品| 人妻少妇一区二区三区蜜桃| 天天日夜夜操天天摸 | 中文字幕一区二区自拍| 国产在线免费观看成人| 日本熟妇一区二区x x| 一区二区三区在线视频福利| 欧美一区二区三区在线资源| 亚洲少妇人妻无码精品| 亚洲精品欧美日韩在线播放| 11久久久久久久久久久| 57pao国产一区二区| 日本少妇精品免费视频| 密臀av一区在线观看| 一色桃子久久精品亚洲| 中文字幕在线第一页成人| 97人妻人人澡爽人人精品| 一区二区三区四区中文| 欧美精品欧美极品欧美视频| 中文字幕国产专区欧美激情| 在线网站你懂得老司机| 福利在线视频网址导航| 国产密臀av一区二区三| 婷婷综合蜜桃av在线| 亚洲麻豆一区二区三区| 久久久久久性虐视频| 天天日天天天天天天天天天天| 日本一区二区三区免费小视频| 亚洲色偷偷综合亚洲AV伊人| 4个黑人操素人视频网站精品91| 经典国语激情内射视频| av森泽佳奈在线观看| 黄色黄色黄片78在线| 都市激情校园春色狠狠| sw137 中文字幕 在线| 久草视频中文字幕在线观看| 久久久久久久精品老熟妇| 婷婷久久一区二区字幕网址你懂得| 人妻丰满熟妇综合网| 东京热男人的av天堂| 久精品人妻一区二区三区| 人妻另类专区欧美制服| 国产日韩欧美美利坚蜜臀懂色| 深田咏美亚洲一区二区| 99精品视频在线观看婷婷| 熟女国产一区亚洲中文字幕| 欧美特色aaa大片| 国产成人精品久久二区91| 美女被肏内射视频网站| AV无码一区二区三区不卡| 青青尤物在线观看视频网站| 大鸡吧插逼逼视频免费看| gogo国模私拍视频| 亚洲精品av在线观看| 99热久久极品热亚洲| av完全免费在线观看av| 在线视频免费观看网| 日本熟妇一区二区x x| 肏插流水妹子在线乐播下载| 欧美亚洲免费视频观看| 久久这里有免费精品| 欧美日韩熟女一区二区三区| 欧美亚洲少妇福利视频| 亚洲综合色在线免费观看| 动漫美女的小穴视频| 天天操夜夜操天天操天天操| 久久精品36亚洲精品束缚| 久久丁香婷婷六月天| 和邻居少妇愉情中文字幕| 黄色黄色黄片78在线| 亚洲综合一区成人在线| 久久丁香花五月天色婷婷| 亚洲成人国产av在线| 一区二区三区精品日本| 成人动漫大肉棒插进去视频| 91天堂精品一区二区| 亚洲 人妻 激情 中文| 非洲黑人一级特黄片| 大陆精品一区二区三区久久| 日本免费视频午夜福利视频| 91极品大一女神正在播放| 人人妻人人澡欧美91精品| 日韩三级黄色片网站| 中文字幕人妻熟女在线电影| 天天做天天干天天操天天射| 亚欧在线视频你懂的| 超碰公开大香蕉97| 国产a级毛久久久久精品| 中文字幕在线乱码一区二区 | 久草视频 久草视频2| 一区二区视频视频视频| 国产精品成人xxxx| 沙月文乃人妻侵犯中文字幕在线| 亚洲精品国产综合久久久久久久久| 欧美精品伦理三区四区| 国产精品人妻一区二区三区网站| 亚洲国产欧美一区二区丝袜黑人| 91中文字幕免费在线观看| 婷婷六月天中文字幕| 亚洲精品高清自拍av| 天堂v男人视频在线观看| 偷拍自拍视频图片免费| 午夜激情精品福利视频| 亚洲综合色在线免费观看| 日韩一区二区电国产精品| 二区中出在线观看老师| 天天日天天干天天搡| 亚洲免费视频欧洲免费视频| 免费岛国喷水视频在线观看| 美女大bxxxx内射| 1769国产精品视频免费观看| 亚洲国产欧美一区二区三区…| 国内自拍第一页在线观看| 丝袜国产专区在线观看| 日韩欧美高清免费在线| 日韩a级黄色小视频| 91‖亚洲‖国产熟女| 五十路人妻熟女av一区二区| 女同性ⅹxx女同h偷拍| 国产av国片精品一区二区| 亚洲人成精品久久久久久久| 午夜精品一区二区三区4| 亚洲精品av在线观看| 亚洲第一伊人天堂网| 精品一区二区三区在线观看| 天天躁夜夜躁日日躁a麻豆| 天堂av在线官网中文| 免费无毒热热热热热热久| 91麻豆精品秘密入口在线观看| 99久久久无码国产精品性出奶水| 新婚人妻聚会被中出| 北条麻妃高跟丝袜啪啪| 国产chinesehd精品麻豆| 精品人人人妻人人玩日产欧| 人妻3p真实偷拍一二区| 人妻爱爱 中文字幕| 高清成人av一区三区| 无码精品一区二区三区人 | 欧洲亚洲欧美日韩综合| 在线成人日韩av电影| 成年午夜免费无码区| 大鸡巴操娇小玲珑的女孩逼| 中文字幕无码一区二区免费| 亚洲伊人av天堂有码在线| 精品av国产一区二区三区四区| 又色又爽又黄的美女裸体| 精品人妻每日一部精品| 久久人人做人人妻人人玩精品vr| av天堂加勒比在线| 国产精品成人xxxx| 同居了嫂子在线播高清中文| 91精品视频在线观看免费| 亚洲2021av天堂| 中文字日产幕乱六区蜜桃| 亚洲人妻国产精品综合| 国产视频在线视频播放| 啪啪啪啪啪啪啪啪啪啪黄色| 久久久久久久精品成人热| 日韩亚国产欧美三级涩爱| 国产精品国产精品一区二区| 国产一级精品综合av| 国产自拍黄片在线观看| 最新97国产在线视频| 中文字幕在线欧美精品| 日本韩国免费福利精品| 一区二区三区综合视频| av老司机亚洲一区二区| 天天摸天天日天天操| 男人天堂最新地址av| 大鸡吧插入女阴道黄色片| 人妻自拍视频中国大陆| 18禁网站一区二区三区四区| 91亚洲精品干熟女蜜桃频道 | 人妻凌辱欧美丰满熟妇| 99re6热在线精品| 国产精品久久9999| 老师啊太大了啊啊啊尻视频| 国产一级麻豆精品免费| 久久麻豆亚洲精品av| 一区二区在线视频中文字幕| 男人的网址你懂的亚洲欧洲av| 亚洲黄色av网站免费播放| 天天日天天干天天干天天日| 国内自拍第一页在线观看| 国产午夜亚洲精品麻豆| 丝袜国产专区在线观看| 蜜臀av久久久久蜜臀av麻豆| 日韩精品中文字幕福利| av网址在线播放大全| 国产男女视频在线播放| 人人妻人人爽人人澡人人精品| 欧美精品激情在线最新观看视频 | 免费黄色成人午夜在线网站| 最新黄色av网站在线观看| 粉嫩欧美美人妻小视频| 成人av在线资源网站| 久久久制服丝袜中文字幕| 美女张开两腿让男人桶av| 大屁股熟女一区二区三区| 40道精品招牌菜特色| 日噜噜噜夜夜噜噜噜天天噜噜噜| 后入美女人妻高清在线| 亚洲av可乐操首页| 快点插进来操我逼啊视频| 青青青青青手机视频| 最新欧美一二三视频| 久久这里有免费精品| 美味人妻2在线播放| 亚洲成人av在线一区二区| 又粗又硬又猛又爽又黄的| 中文字幕 亚洲av| 国产日韩精品一二三区久久久| 一区二区视频在线观看免费观看| 中文字幕一区二区亚洲一区| 中文字幕一区二区人妻电影冢本| 熟女人妻在线中出观看完整版| 美女被肏内射视频网站| 精品人妻每日一部精品| 欧美视频中文一区二区三区| 午夜精品在线视频一区| a v欧美一区=区三区| 亚洲 欧美 精品 激情 偷拍| 亚洲激情唯美亚洲激情图片| 欧美另类重口味极品在线观看| 免费成人av中文字幕| 一区二区视频在线观看免费观看| 自拍偷拍一区二区三区图片| 风流唐伯虎电视剧在线观看| 青青在线视频性感少妇和隔壁黑丝| 精品91自产拍在线观看一区| 免费成人av中文字幕| 超碰97免费人妻麻豆 | 日本一道二三区视频久久| 夜夜操,天天操,狠狠操| 亚洲免费成人a v| 亚洲成av人无码不卡影片一| 大鸡八强奸视频在线观看| 美女av色播在线播放| 绝色少妇高潮3在线观看| 婷婷午夜国产精品久久久| 懂色av之国产精品| 亚洲国产40页第21页| 色偷偷伊人大杳蕉综合网| 精品成人午夜免费看| 91‖亚洲‖国产熟女| 无码国产精品一区二区高潮久久4| 不卡日韩av在线观看| 国产精品自拍视频大全| 亚洲午夜电影之麻豆| 国产大鸡巴大鸡巴操小骚逼小骚逼| 亚洲国产成人最新资源| 日本在线不卡免费视频| yy6080国产在线视频| 视频一区二区在线免费播放| 男人和女人激情视频| 日韩一个色综合导航| 欧美另类一区二区视频| 粉嫩av蜜乳av蜜臀| 久久农村老妇乱69系列| 性感美女高潮视频久久久| 国产视频一区在线观看| 久久麻豆亚洲精品av| 人人妻人人爱人人草| 99精品国产aⅴ在线观看| 香蕉av影视在线观看| 亚洲综合在线观看免费| 免费在线观看污污视频网站| 亚洲欧美精品综合图片小说| 91精品国产黑色丝袜| 2020国产在线不卡视频| 丰满熟女午夜福利视频| 亚洲高清自偷揄拍自拍| 成人激情文学网人妻| 中文字幕人妻一区二区视频| 专门看国产熟妇的网站| 成人免费公开视频无毒| 欧美中文字幕一区最新网址| 亚洲精品亚洲人成在线导航 | 久久精品亚洲国产av香蕉| 男大肉棒猛烈插女免费视频| 成年人免费看在线视频| 国产成人精品亚洲男人的天堂| 2022天天干天天操| 免费观看理论片完整版| 精产国品久久一二三产区区别| 国产视频一区二区午夜| 国产大学生援交正在播放| 国产乱子伦精品视频潮优女| 青青青aaaa免费| 天美传媒mv视频在线观看| 国产在线拍揄自揄视频网站| 一区国内二区日韩三区欧美| av在线免费观看亚洲天堂| 日韩人妻丝袜中文字幕| 久久久久只精品国产三级| 久久99久久99精品影院| 最新国产精品网址在线观看| 日韩精品中文字幕播放| 日韩三级黄色片网站| 97精品视频在线观看| 人妻久久无码中文成人| 男女第一次视频在线观看| 男人的天堂av日韩亚洲| 天天躁日日躁狠狠躁av麻豆| 国产一区二区视频观看| 国产日韩精品免费在线| 日本美女成人在线视频| 国内资源最丰富的网站| 国产精品探花熟女在线观看| 欧美色婷婷综合在线| 日韩人妻在线视频免费| 丝袜美腿欧美另类 中文字幕| 福利视频网久久91| 亚洲欧美综合在线探花| 啊慢点鸡巴太大了啊舒服视频| 午夜精品福利一区二区三区p| 国产激情av网站在线观看| 色97视频在线播放| 18禁美女无遮挡免费| av在线观看网址av| 免费在线看的黄网站| tube69日本少妇| 91老熟女连续高潮对白| 亚洲成人国产综合一区| 天天日天天摸天天爱| 亚洲福利午夜久久久精品电影网| 一区二区三区的久久的蜜桃的视频| 日韩美女精品视频在线观看网站| 521精品视频在线观看| 99国产精品窥熟女精品| 最新中文字幕免费视频| 亚洲色偷偷综合亚洲AV伊人| 丝袜肉丝一区二区三区四区在线| 涩爱综合久久五月蜜臀| 91欧美在线免费观看| 亚洲国产精品免费在线观看| 欧美偷拍亚洲一区二区| 亚洲欧美清纯唯美另类 | 欧美亚洲偷拍自拍色图| 91‖亚洲‖国产熟女| 最新91精品视频在线| 888欧美视频在线| 少妇被强干到高潮视频在线观看| 91亚洲手机在线视频播放| jiuse91九色视频| 九色精品视频在线播放| 久久综合老鸭窝色综合久久| 高清一区二区欧美系列| 中文字幕免费福利视频6| 色婷婷久久久久swag精品| 国产一区二区三免费视频| 日日爽天天干夜夜操| 亚洲图片欧美校园春色| 青青草成人福利电影| 日本xx片在线观看| 超碰97免费人妻麻豆| 日本黄在免费看视频| av在线观看网址av| 91免费放福利在线观看| 99精品视频在线观看免费播放| 性色蜜臀av一区二区三区| 中文字幕人妻一区二区视频| av天堂中文字幕最新| 99热这里只有国产精品6| 天天色天天操天天透| 国产大鸡巴大鸡巴操小骚逼小骚逼| 馒头大胆亚洲一区二区| 白白操白白色在线免费视频| 午夜精品亚洲精品五月色| 性感美女福利视频网站| 日本性感美女视频网站| 日本在线不卡免费视频| 青青热久免费精品视频在线观看| 一级A一级a爰片免费免会员| 国产精品午夜国产小视频| 99热碰碰热精品a中文| 亚洲av香蕉一区区二区三区犇| 天天干天天日天天谢综合156| 一区二区三区蜜臀在线| 国产精品系列在线观看一区二区| 国产精品入口麻豆啊啊啊| 欧美美女人体视频一区| 男人天堂最新地址av| 中文字幕一区二区亚洲一区| 国产亚洲欧美45p| 日韩欧美国产一区ab| 午夜久久香蕉电影网| 97国产福利小视频合集| 蜜臀av久久久久蜜臀av麻豆| 在线视频自拍第三页| 97人人妻人人澡人人爽人人精品| 天天干夜夜操啊啊啊| 亚洲欧美在线视频第一页| 国产高清在线在线视频| 精品久久婷婷免费视频| 美女日逼视频免费观看| 五十路熟女av天堂| 日本乱人一区二区三区| 激情国产小视频在线| 黑人大几巴狂插日本少妇| 在线不卡成人黄色精品| 91精品激情五月婷婷在线| 精品一区二区三区三区88 | 色综合天天综合网国产成人| 色偷偷伊人大杳蕉综合网| 2022国产综合在线干| 少妇高潮无套内谢麻豆| 日韩精品电影亚洲一区| 美女av色播在线播放| 亚洲激情,偷拍视频| 国产日韩av一区二区在线| 国产精品一区二区三区蜜臀av| 一区二区在线观看少妇| 久草电影免费在线观看| 国产真实乱子伦a视频| brazzers欧熟精品系列| 久久这里只有精品热视频| 五十路在线观看完整版| 2020av天堂网在线观看| 亚洲国际青青操综合网站| 久久亚洲天堂中文对白| 韩国黄色一级二级三级| 91中文字幕最新合集| 99久久激情婷婷综合五月天| 亚洲av日韩高清hd| 日韩美女精品视频在线观看网站 | 国产麻豆剧果冻传媒app| 一区二区三区四区视频| 精品一区二区三区三区88| 天天日夜夜干天天操| 三级av中文字幕在线观看| 久久久超爽一二三av| 免费看高清av的网站| 999九九久久久精品| 成人24小时免费视频| 老司机免费福利视频网| 狠狠操操操操操操操操操| 97精品视频在线观看| 一区二区三区精品日本| 不卡一不卡二不卡三| 久久h视频在线观看| 在线观看av观看av| 国产综合高清在线观看| 不卡日韩av在线观看| 日本啪啪啪啪啪啪啪| 中文字幕日韩无敌亚洲精品| 九色porny九色9l自拍视频| 玩弄人妻熟妇性色av少妇| 特一级特级黄色网片| 91chinese在线视频| 99热碰碰热精品a中文| 香港三日本三韩国三欧美三级| gay gay男男瑟瑟在线网站| 懂色av之国产精品| 亚洲另类综合一区小说| www日韩a级s片av| 人人妻人人爱人人草| 亚洲欧美清纯唯美另类| 欧美中国日韩久久精品| 精品乱子伦一区二区三区免费播| 99热色原网这里只有精品| 直接观看免费黄网站| 国产三级精品三级在线不卡| 巨乳人妻日下部加奈被邻居中出| 75国产综合在线视频| 夫妻在线观看视频91| 中文字幕 码 在线视频| 91极品大一女神正在播放| 亚洲成人激情av在线| 视频 一区二区在线观看| 韩国亚洲欧美超一级在线播放视频| 在线视频精品你懂的| 国产亚州色婷婷久久99精品| 97人妻色免费视频| 51国产成人精品视频| 婷婷午夜国产精品久久久| 女生自摸在线观看一区二区三区| 91天堂精品一区二区| 午夜国产福利在线观看| 亚洲欧美在线视频第一页| 瑟瑟视频在线观看免费视频| 2018最新中文字幕在线观看| 青青操免费日综合视频观看| 大胆亚洲av日韩av| 伊人综合aⅴ在线网| 成人av久久精品一区二区| 午夜在线精品偷拍一区二| 中文字幕在线乱码一区二区 | 国产91久久精品一区二区字幕| 51国产偷自视频在线播放| 日本韩国亚洲综合日韩欧美国产| 国产av一区2区3区| 91精品啪在线免费| 欧美激情电影免费在线| av视网站在线观看| 亚洲欧美激情中文字幕| 青青青视频自偷自拍38碰| 亚洲激情av一区二区| 成人H精品动漫在线无码播放| 一区国内二区日韩三区欧美| 亚洲天天干 夜夜操| 亚洲麻豆一区二区三区| 日本av熟女在线视频| 欧美黑人巨大性xxxxx猛交| www日韩毛片av| free性日本少妇| 在线观看国产免费麻豆| 91福利在线视频免费观看| 青青草精品在线视频观看| 青青青青青操视频在线观看| 91人妻精品一区二区久久| 中文字幕在线视频一区二区三区| 夫妻在线观看视频91| 最新91精品视频在线| 揄拍成人国产精品免费看视频| 制丝袜业一区二区三区| 夜夜嗨av蜜臀av| 国产1区,2区,3区| 在线观看视频网站麻豆| 91精品啪在线免费| 日韩不卡中文在线视频网站| av老司机精品在线观看| 极品粉嫩小泬白浆20p主播| 欧美日韩v中文在线| 美女在线观看日本亚洲一区| 日本18禁久久久久久| 成人30分钟免费视频| xxx日本hd高清| 中文字幕免费福利视频6| 亚洲av无女神免非久久| 人人爽亚洲av人人爽av| 五十路熟女人妻一区二区9933| av在线观看网址av| 性欧美激情久久久久久久| 国产精品日韩欧美一区二区| 黄色在线观看免费观看在线| 久久久极品久久蜜桃| 欧美亚洲中文字幕一区二区三区| 青春草视频在线免费播放| 日韩熟女av天堂系列| 999久久久久999| 欧美另类z0z变态| 亚洲av无乱一区二区三区性色| 青青操免费日综合视频观看| 一区二区三区综合视频| 欧洲欧美日韩国产在线| 最新国产亚洲精品中文在线| lutube在线成人免费看| 成人色综合中文字幕| 亚洲av可乐操首页| 巨乳人妻日下部加奈被邻居中出| 一区二区三区久久久91| 亚洲av色香蕉一区二区三区| 亚洲国产免费av一区二区三区| 99国产精品窥熟女精品| 中文字幕国产专区欧美激情| 香蕉av影视在线观看| 国产久久久精品毛片| 影音先锋女人av噜噜色| 欧美日韩熟女一区二区三区| 亚洲无码一区在线影院| 亚洲推理片免费看网站| 99av国产精品欲麻豆| 国产麻豆乱子伦午夜视频观看| 韩国爱爱视频中文字幕| 55夜色66夜色国产精品站| 粉嫩av懂色av蜜臀av| 自拍偷拍日韩欧美亚洲| 99一区二区在线观看| 国产在线观看黄色视频| 欧美成人小视频在线免费看| 可以免费看的www视频你懂的| 亚洲欧美清纯唯美另类| 538精品在线观看视频| 国产使劲操在线播放| 中文字幕日韩人妻在线三区| 午夜精品久久久久久99热| 极品丝袜一区二区三区| 99热这里只有精品中文| 亚洲av一妻不如妾| 日韩近亲视频在线观看| 91桃色成人网络在线观看| 国产黄色高清资源在线免费观看| 欧美80老妇人性视频| 黄片色呦呦视频免费看| 久久热久久视频在线观看| 人妻另类专区欧美制服| 亚洲嫩模一区二区三区| brazzers欧熟精品系列| 亚洲偷自拍高清视频| 伊人成人在线综合网| 人妻丝袜榨强中文字幕| 天堂av狠狠操蜜桃| 国产美女精品福利在线| 久碰精品少妇中文字幕av| 在线国产精品一区二区三区| 久久香蕉国产免费天天| 欧美老妇精品另类不卡片| 黄网十四区丁香社区激情五月天| 91天堂天天日天天操| 精品国产亚洲av一淫| 偷拍3456eee| 班长撕开乳罩揉我胸好爽| 天天躁日日躁狠狠躁av麻豆| 国产高清在线在线视频|