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

Java基于注解的Excel導(dǎo)出方式

 更新時間:2023年01月09日 08:45:59   作者:蒼穹之躍  
這篇文章主要介紹了Java基于注解的Excel導(dǎo)出方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Java注解的Excel導(dǎo)出

依賴:

?<dependency>
? ? ? ? ? ? <groupId>cn.afterturn</groupId>
? ? ? ? ? ? <artifactId>easypoi-base</artifactId>
? ? ? ? ? ? <version>4.1.2</version>
? ? ? ? </dependency>
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>cn.afterturn</groupId>
? ? ? ? ? ? <artifactId>easypoi-web</artifactId>
? ? ? ? ? ? <version>4.1.2</version>
? ? ? ? </dependency>
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>cn.afterturn</groupId>
? ? ? ? ? ? <artifactId>easypoi-annotation</artifactId>
? ? ? ? ? ? <version>4.1.2</version>
? ? ? ? </dependency>

注解配合工具類做了個小工具如下:

第一步:自定義注解:(讀者請直接復(fù)制)

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
?
/**
?* 自定義導(dǎo)出Excel數(shù)據(jù)注解
?*
?* @author sunziwen
?* @version 1.0
?* @date 2018-12-29 15:00
?**/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface Excel {
? ? /**
? ? ?* 導(dǎo)出到Excel中的名字.
? ? ?*/
? ? public String name();
?
? ? /**
? ? ?* 日期格式, 如: yyyy-MM-dd
? ? ?*/
? ? public String dateFormat() default "";
?
? ? /**
? ? ?* 讀取內(nèi)容轉(zhuǎn)表達式 (如: 0=男,1=女,2=未知)
? ? ?*/
? ? public String readConverterExp() default "";
?
? ? /**
? ? ?* 導(dǎo)出時在excel中每個列的高度 單位為字符
? ? ?*/
? ? public double height() default 14;
?
? ? /**
? ? ?* 導(dǎo)出時在excel中每個列的寬 單位為字符
? ? ?*/
? ? public double width() default 20;
?
? ? /**
? ? ?* 文字后綴,如% 90 變成90%
? ? ?*/
? ? public String suffix() default "";
?
? ? /**
? ? ?* 當(dāng)值為空時,字段的默認(rèn)值
? ? ?*/
? ? public String defaultValue() default "";
?
? ? /**
? ? ?* 提示信息
? ? ?*/
? ? public String prompt() default "";
?
? ? /**
? ? ?* 設(shè)置只能選擇不能輸入的列內(nèi)容.
? ? ?*/
? ? public String[] combo() default {};
?
? ? /**
? ? ?* 是否導(dǎo)出數(shù)據(jù),應(yīng)對需求:有時我們需要導(dǎo)出一份模板,這是標(biāo)題需要但內(nèi)容需要用戶手工填寫.
? ? ?*/
? ? public boolean isExport() default true;
}

第二步:實體類:(為每個需要的字段打上@Excel注解)

import java.time.LocalDateTime;
?
import com.ciih.authcenter.client.util.excel.Excel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
?
/**
?* (User)表實體類
?*
?* @author suzniwen
?* @since 2021-04-13 16:11:55
?*/
@SuppressWarnings("serial")
@EqualsAndHashCode(callSuper = true)
@Data
public class User {
? ? @Excel(name = "編號")
? ? @ApiModelProperty(value = "主鍵")
? ? private String id;
? ? @Excel(name = "賬號")
? ? @ApiModelProperty(value = "賬號")
? ? private String loginName;
? ? @Excel(name = "用戶名")
? ? @ApiModelProperty(value = "用戶名")
? ? private String userName;
? ? @ApiModelProperty(value = "用戶名拼音")
? ? private String namePinyin;
? ? @Excel(name = "性別", readConverterExp = "1=男,0=女")
? ? @ApiModelProperty(value = "性別")
? ? private String gender;
? ? @Excel(name = "證件類型",readConverterExp="1=居民身份證,2=香港居民來往內(nèi)地通行證,3=澳門居民來往內(nèi)地通行證,4=臺灣居民來往大陸通行證,6=護照")
? ? @ApiModelProperty(value = "證件類型")
? ? private String credType;
? ? @Excel(name = "證件號碼")
? ? @ApiModelProperty(value = "證件號碼")
? ? private String credNum;
? ? @ApiModelProperty(value = "機構(gòu)id")
? ? private String orgId;
? ? @Excel(name = "機構(gòu)名稱")
? ? @ApiModelProperty(value = "機構(gòu)名稱")
? ? private String orgName;
? ? @Excel(name = "電話")
? ? @ApiModelProperty(value = "電話")
? ? private String phone;
? ? @Excel(name = "郵箱")
? ? @ApiModelProperty(value = "郵箱")
? ? private String email;
? ? @Excel(name = "人員類型",readConverterExp = "student=學(xué)生,teacher=教師,parent=家長,system=系統(tǒng)人員,developers=開發(fā)者,manager=管理員")
? ? @ApiModelProperty(value = "人員類型")
? ? private String personType;
? ? @Excel(name = "應(yīng)用系統(tǒng)角色編碼")
? ? @ApiModelProperty(value = "應(yīng)用系統(tǒng)角色編碼")
? ? private String appRoleCode;
? ? @ApiModelProperty(value = "創(chuàng)建時間")
? ? private LocalDateTime createTime;
? ? @ApiModelProperty(value = "更新時間")
? ? private LocalDateTime updateTime;
}

第三步:解析工具類:(讀者請直接復(fù)制) 

import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Field;
import java.net.URLEncoder;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
?
import javax.servlet.http.HttpServletResponse;
?
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.hssf.usermodel.DVConstraint;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDataValidation;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellType;
import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.VerticalAlignment;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;
import org.apache.poi.ss.util.CellRangeAddressList;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
?
/**
?* Excel相關(guān)操作
?*
?* @author sunziwen
?* @version 1.0
?* @date 2022-03-25 15:20
?**/
public class ExcelUtil<T> {
? ? private static final Logger log = LoggerFactory.getLogger(ExcelUtil.class);
?
? ? private Class<T> clazz;
?
? ? public ExcelUtil(Class<T> clazz) {
? ? ? ? this.clazz = clazz;
? ? }
?
? ? /**
? ? ?* 對excel表單默認(rèn)第一個索引名轉(zhuǎn)換成list
? ? ?*
? ? ?* @param input 輸入流
? ? ?* @return 轉(zhuǎn)換后集合
? ? ?*/
? ? public List<T> importExcel(InputStream input) throws Exception {
? ? ? ? return importExcel(StringUtils.EMPTY, input);
? ? }
?
? ? /**
? ? ?* 對excel表單指定表格索引名轉(zhuǎn)換成list
? ? ?*
? ? ?* @param sheetName 表格索引名
? ? ?* @param input ? ? 輸入流
? ? ?* @return 轉(zhuǎn)換后集合
? ? ?*/
? ? public List<T> importExcel(String sheetName, InputStream input) throws Exception {
? ? ? ? List<T> list = new ArrayList<T>();
?
? ? ? ? Workbook workbook = WorkbookFactory.create(input);
? ? ? ? Sheet sheet = null;
? ? ? ? if (StringUtils.isNotEmpty(sheetName)) {
? ? ? ? ? ? // 如果指定sheet名,則取指定sheet中的內(nèi)容.
? ? ? ? ? ? sheet = workbook.getSheet(sheetName);
? ? ? ? } else {
? ? ? ? ? ? // 如果傳入的sheet名不存在則默認(rèn)指向第1個sheet.
? ? ? ? ? ? sheet = workbook.getSheetAt(0);
? ? ? ? }
?
? ? ? ? if (sheet == null) {
? ? ? ? ? ? throw new IOException("文件sheet不存在");
? ? ? ? }
?
? ? ? ? int rows = sheet.getPhysicalNumberOfRows();
?
? ? ? ? if (rows > 0) {
? ? ? ? ? ? // 默認(rèn)序號
// ? ? ? ? ? ?int serialNum = 0;
? ? ? ? ? ? // 有數(shù)據(jù)時才處理 得到類的所有field.
? ? ? ? ? ? Field[] allFields = clazz.getDeclaredFields();
?
? ? ? ? ? ? /**
? ? ? ? ? ? ?* 這里是要將實體類的屬性與excel表的列序號對應(yīng)上,有兩種方式:
? ? ? ? ? ? ?* 1.按照先后順序進行一一對應(yīng)。
? ? ? ? ? ? ?* 2.按照注解的name值與表頭對應(yīng)起來
? ? ? ? ? ? ?*/
?
? ? ? ? ? ? // 定義一個map用于存放列的序號和field.
? ? ? ? ? ? Map<Integer, Field> fieldsMap = new HashMap<Integer, Field>();
?
? ? ? ? ? ? //定義一個name到Excel表的index的映射Map
? ? ? ? ? ? HashMap<String, Integer> name2index = new HashMap<>();
?
? ? ? ? ? ? //默認(rèn)第一行是表頭
? ? ? ? ? ? Row r = sheet.getRow(0);
? ? ? ? ? ? for (int i = 0; i < allFields.length; i++) {
? ? ? ? ? ? ? ? Cell cell = r.getCell(i);
? ? ? ? ? ? ? ? if (cell == null) {
? ? ? ? ? ? ? ? ? ? continue;
? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? // 先設(shè)置Cell的類型,然后就可以把純數(shù)字作為String類型讀進來了
? ? ? ? ? ? ? ? ? ? r.getCell(i).setCellType(CellType.STRING);
? ? ? ? ? ? ? ? ? ? cell = r.getCell(i);
? ? ? ? ? ? ? ? ? ? String c = cell.getStringCellValue();
? ? ? ? ? ? ? ? ? ? if (StringUtils.isEmpty(c)) {
? ? ? ? ? ? ? ? ? ? ? ? continue;
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? name2index.put(c, i);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
?
? ? ? ? ? ? for (int col = 0; col < allFields.length; col++) {
? ? ? ? ? ? ? ? Field field = allFields[col];
? ? ? ? ? ? ? ? // 將有注解的field存放到map中.
? ? ? ? ? ? ? ? if (field.isAnnotationPresent(Excel.class)) {
? ? ? ? ? ? ? ? ? ? Excel excel = field.getAnnotation(Excel.class);
? ? ? ? ? ? ? ? ? ? String name = excel.name();
? ? ? ? ? ? ? ? ? ? Integer index = name2index.get(name);
? ? ? ? ? ? ? ? ? ? if (index != null) {
? ? ? ? ? ? ? ? ? ? ? ? field.setAccessible(true);
? ? ? ? ? ? ? ? ? ? ? ? fieldsMap.put(index, field);
? ? ? ? ? ? ? ? ? ? }
?
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ? //下面這個是按序號一一對應(yīng)的。不太友好,還是按照表頭名稱來對應(yīng)
// ? ? ? ? ? ?for (int col = 0; col < allFields.length; col++) {
// ? ? ? ? ? ? ? ?Field field = allFields[col];
// ? ? ? ? ? ? ? ?// 將有注解的field存放到map中.
// ? ? ? ? ? ? ? ?if (field.isAnnotationPresent(Excel.class)) {
// ? ? ? ? ? ? ? ? ? ?// 設(shè)置類的私有字段屬性可訪問.
// ? ? ? ? ? ? ? ? ? ?field.setAccessible(true);
// ? ? ? ? ? ? ? ? ? ?fieldsMap.put(++serialNum, field);
// ? ? ? ? ? ? ? ?}
// ? ? ? ? ? ?}
? ? ? ? ? ? for (int i = 1; i < rows; i++) {
? ? ? ? ? ? ? ? // 從第2行開始取數(shù)據(jù),默認(rèn)第一行是表頭.
? ? ? ? ? ? ? ? Row row = sheet.getRow(i);
? ? ? ? ? ? ? ? int cellNum = allFields.length;
? ? ? ? ? ? ? ? T entity = null;
? ? ? ? ? ? ? ? for (int j = 0; j < cellNum; j++) {
? ? ? ? ? ? ? ? ? ? Cell cell = row.getCell(j);
? ? ? ? ? ? ? ? ? ? if (cell == null) {
? ? ? ? ? ? ? ? ? ? ? ? continue;
? ? ? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? ? ? // 先設(shè)置Cell的類型,然后就可以把純數(shù)字作為String類型讀進來了
? ? ? ? ? ? ? ? ? ? ? ? row.getCell(j).setCellType(CellType.STRING);
? ? ? ? ? ? ? ? ? ? ? ? cell = row.getCell(j);
? ? ? ? ? ? ? ? ? ? }
?
? ? ? ? ? ? ? ? ? ? String c = cell.getStringCellValue();
? ? ? ? ? ? ? ? ? ? if (StringUtils.isEmpty(c)) {
? ? ? ? ? ? ? ? ? ? ? ? continue;
? ? ? ? ? ? ? ? ? ? }
?
? ? ? ? ? ? ? ? ? ? // 如果不存在實例則新建.
? ? ? ? ? ? ? ? ? ? entity = (entity == null ? clazz.newInstance() : entity);
? ? ? ? ? ? ? ? ? ? // 從map中得到對應(yīng)列的field.
? ? ? ? ? ? ? ? ? ? Field field = fieldsMap.get(j);
? ? ? ? ? ? ? ? ? ? // 取得類型,并根據(jù)對象類型設(shè)置值.
? ? ? ? ? ? ? ? ? ? Class<?> fieldType = field.getType();
? ? ? ? ? ? ? ? ? ? if (String.class == fieldType) {
? ? ? ? ? ? ? ? ? ? ? ? field.set(entity, String.valueOf(c));
? ? ? ? ? ? ? ? ? ? } else if ((Integer.TYPE == fieldType) || (Integer.class == fieldType)) {
? ? ? ? ? ? ? ? ? ? ? ? field.set(entity, Integer.parseInt(c));
? ? ? ? ? ? ? ? ? ? } else if ((Long.TYPE == fieldType) || (Long.class == fieldType)) {
? ? ? ? ? ? ? ? ? ? ? ? field.set(entity, Long.valueOf(c));
? ? ? ? ? ? ? ? ? ? } else if ((Float.TYPE == fieldType) || (Float.class == fieldType)) {
? ? ? ? ? ? ? ? ? ? ? ? field.set(entity, Float.valueOf(c));
? ? ? ? ? ? ? ? ? ? } else if ((Short.TYPE == fieldType) || (Short.class == fieldType)) {
? ? ? ? ? ? ? ? ? ? ? ? field.set(entity, Short.valueOf(c));
? ? ? ? ? ? ? ? ? ? } else if ((Double.TYPE == fieldType) || (Double.class == fieldType)) {
? ? ? ? ? ? ? ? ? ? ? ? field.set(entity, Double.valueOf(c));
? ? ? ? ? ? ? ? ? ? } else if (Character.TYPE == fieldType) {
? ? ? ? ? ? ? ? ? ? ? ? if ((c != null) && (c.length() > 0)) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? field.set(entity, Character.valueOf(c.charAt(0)));
? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? } else if (Date.class == fieldType) {
? ? ? ? ? ? ? ? ? ? ? ? //對字符串解析成日期
?
? ? ? ? ? ? ? ? ? ? ? ? SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
?
? ? ? ? ? ? ? ? ? ? ? ? String s = cell.getStringCellValue()
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? .replaceAll("/", "-")
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? .replaceAll("上午", "")
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? .replaceAll("下午", "")
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? .replaceAll(" ?", " ");
? ? ? ? ? ? ? ? ? ? ? ? System.out.println("----------------------------:" + s);
? ? ? ? ? ? ? ? ? ? ? ? Date parse = sdf.parse(s);
? ? ? ? ? ? ? ? ? ? ? ? field.set(entity, parse);
// ? ? ? ? ? ? ? ? ? ? ? ?if (cell.getCellTypeEnum() == CellType.NUMERIC) {
// ? ? ? ? ? ? ? ? ? ? ? ? ? ?SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
// ? ? ? ? ? ? ? ? ? ? ? ? ? ?cell.setCellValue(sdf.format(cell.getNumericCellValue()));
// ? ? ? ? ? ? ? ? ? ? ? ? ? ?c = sdf.format(cell.getNumericCellValue());
// ? ? ? ? ? ? ? ? ? ? ? ?} else {
// ? ? ? ? ? ? ? ? ? ? ? ? ? ?c = cell.getStringCellValue();
// ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ? ? ? ? ? } else if (java.math.BigDecimal.class == fieldType) {
? ? ? ? ? ? ? ? ? ? ? ? c = cell.getStringCellValue();
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? if (entity != null) {
? ? ? ? ? ? ? ? ? ? list.add(entity);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }
?
? ? ? ? return list;
? ? }
?
? ? /**
? ? ?* 對list數(shù)據(jù)源將其里面的數(shù)據(jù)導(dǎo)入到excel表單
? ? ?* 針對List<Map>類型的數(shù)據(jù)
? ? ?*
? ? ?* @param list ? ? ?導(dǎo)出數(shù)據(jù)集合
? ? ?* @param sheetName 工作表的名稱
? ? ?* @return 結(jié)果
? ? ?*/
? ? public static void exportMapExcel(List<Map> list, String[] title, String sheetName, HttpServletResponse response) {
? ? ? ? if (null == list || list.size() == 0) {
? ? ? ? ? ? return;
? ? ? ? }
?
? ? ? ? HSSFWorkbook workbook = null;
? ? ? ? try {
? ? ? ? ? ? // 產(chǎn)生工作薄對象
? ? ? ? ? ? workbook = new HSSFWorkbook();
? ? ? ? ? ? // excel2003中每個sheet中最多有65536行
? ? ? ? ? ? int sheetSize = 65536;
? ? ? ? ? ? // 取出一共有多少個sheet.
? ? ? ? ? ? double sheetNo = Math.ceil(list.size() / sheetSize);
? ? ? ? ? ? for (int index = 0; index <= sheetNo; index++) {
? ? ? ? ? ? ? ? // 產(chǎn)生工作表對象
? ? ? ? ? ? ? ? HSSFSheet sheet = workbook.createSheet();
? ? ? ? ? ? ? ? if (sheetNo == 0) {
? ? ? ? ? ? ? ? ? ? workbook.setSheetName(index, sheetName);
? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? // 設(shè)置工作表的名稱.
? ? ? ? ? ? ? ? ? ? workbook.setSheetName(index, sheetName + index);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? HSSFRow row;
? ? ? ? ? ? ? ? HSSFCell cell; // 產(chǎn)生單元格
?
? ? ? ? ? ? ? ? // 產(chǎn)生第一行,寫入標(biāo)題
? ? ? ? ? ? ? ? row = sheet.createRow(0);
? ? ? ? ? ? ? ? if (null == title || title.length == 0) {
? ? ? ? ? ? ? ? ? ? throw new RuntimeException("導(dǎo)出錯誤");
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? for (int i = 0; i < title.length; i++) {
? ? ? ? ? ? ? ? ? ? cell = row.createCell(i);
? ? ? ? ? ? ? ? ? ? cell.setCellType(CellType.STRING);
? ? ? ? ? ? ? ? ? ? cell.setCellValue(title[i]);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? int cell_idx = 0;
? ? ? ? ? ? ? ? int startNo = index * sheetSize;
? ? ? ? ? ? ? ? int endNo = Math.min(startNo + sheetSize, list.size());
? ? ? ? ? ? ? ? // 寫入各條記錄,每條記錄對應(yīng)excel表中的一行
? ? ? ? ? ? ? ? for (int i = startNo; i < endNo; i++) {
? ? ? ? ? ? ? ? ? ? row = sheet.createRow(i + 1 - startNo);
? ? ? ? ? ? ? ? ? ? // 得到導(dǎo)出對象.
? ? ? ? ? ? ? ? ? ? Map map = list.get(i);
? ? ? ? ? ? ? ? ? ? Set keySet = map.keySet();
? ? ? ? ? ? ? ? ? ? Iterator values = keySet.iterator();
? ? ? ? ? ? ? ? ? ? cell_idx = 0;
? ? ? ? ? ? ? ? ? ? while (values.hasNext()) {
? ? ? ? ? ? ? ? ? ? ? ? Object value = map.get(values.next());
? ? ? ? ? ? ? ? ? ? ? ? cell = row.createCell(cell_idx);
? ? ? ? ? ? ? ? ? ? ? ? cell.setCellValue(value.toString());
? ? ? ? ? ? ? ? ? ? ? ? cell_idx++;
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ? //String filename = encodingFilename(sheetName);
? ? ? ? ? ? response.setHeader("content-Type", "application/vnd.ms-excel");
? ? ? ? ? ? response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(sheetName, "UTF-8"));
// ? ? ? ? ? ?response.setContentType("application/octet-stream");
// ? ? ? ? ? ?response.setHeader("Content-disposition", "attachment;filename=" + URLEncoder.encode(filename, "UTF-8"));
? ? ? ? ? ? response.flushBuffer();
? ? ? ? ? ? workbook.write(response.getOutputStream());
? ? ? ? ? ? //return filename;
? ? ? ? } catch (Exception e) {
? ? ? ? ? ? log.error("導(dǎo)出Excel異常{}", e.getMessage());
? ? ? ? ? ? throw new RuntimeException("導(dǎo)出Excel失敗,請聯(lián)系網(wǎng)站管理員!");
? ? ? ? } finally {
? ? ? ? ? ? if (workbook != null) {
? ? ? ? ? ? ? ? try {
? ? ? ? ? ? ? ? ? ? workbook.close();
? ? ? ? ? ? ? ? } catch (IOException e1) {
? ? ? ? ? ? ? ? ? ? e1.printStackTrace();
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }
? ? }
?
? ? /**
? ? ?* 對list數(shù)據(jù)源將其里面的數(shù)據(jù)導(dǎo)入到excel表單
? ? ?*
? ? ?* @param list ? ? ?導(dǎo)出數(shù)據(jù)集合
? ? ?* @param sheetName 工作表的名稱
? ? ?* @return 結(jié)果
? ? ?*/
? ? public void exportExcel(List<?> list, String sheetName, HttpServletResponse response) {
? ? ? ? HSSFWorkbook workbook = null;
? ? ? ? try {
? ? ? ? ? ? // 得到所有定義字段
? ? ? ? ? ? Field[] allFields = clazz.getDeclaredFields();
? ? ? ? ? ? List<Field> fields = new ArrayList<Field>();
? ? ? ? ? ? // 得到所有field并存放到一個list中.
? ? ? ? ? ? for (Field field : allFields) {
? ? ? ? ? ? ? ? if (field.isAnnotationPresent(Excel.class)) {
? ? ? ? ? ? ? ? ? ? fields.add(field);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
?
? ? ? ? ? ? // 產(chǎn)生工作薄對象
? ? ? ? ? ? workbook = new HSSFWorkbook();
? ? ? ? ? ? // excel2003中每個sheet中最多有65536行
? ? ? ? ? ? int sheetSize = 65536;
? ? ? ? ? ? // 取出一共有多少個sheet.
? ? ? ? ? ? double sheetNo = Math.ceil(list.size() / sheetSize);
? ? ? ? ? ? for (int index = 0; index <= sheetNo; index++) {
? ? ? ? ? ? ? ? // 產(chǎn)生工作表對象
? ? ? ? ? ? ? ? HSSFSheet sheet = workbook.createSheet();
? ? ? ? ? ? ? ? if (sheetNo == 0) {
? ? ? ? ? ? ? ? ? ? workbook.setSheetName(index, sheetName);
? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? // 設(shè)置工作表的名稱.
? ? ? ? ? ? ? ? ? ? workbook.setSheetName(index, sheetName + index);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? HSSFRow row;
? ? ? ? ? ? ? ? HSSFCell cell; // 產(chǎn)生單元格
?
? ? ? ? ? ? ? ? // 產(chǎn)生一行
? ? ? ? ? ? ? ? row = sheet.createRow(0);
? ? ? ? ? ? ? ? // 寫入各個字段的列頭名稱
? ? ? ? ? ? ? ? for (int i = 0; i < fields.size(); i++) {
? ? ? ? ? ? ? ? ? ? Field field = fields.get(i);
? ? ? ? ? ? ? ? ? ? Excel attr = field.getAnnotation(Excel.class);
? ? ? ? ? ? ? ? ? ? // 創(chuàng)建列
? ? ? ? ? ? ? ? ? ? cell = row.createCell(i);
? ? ? ? ? ? ? ? ? ? // 設(shè)置列中寫入內(nèi)容為String類型
? ? ? ? ? ? ? ? ? ? cell.setCellType(CellType.STRING);
? ? ? ? ? ? ? ? ? ? HSSFCellStyle cellStyle = workbook.createCellStyle();
? ? ? ? ? ? ? ? ? ? cellStyle.setAlignment(HorizontalAlignment.CENTER);
? ? ? ? ? ? ? ? ? ? cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
? ? ? ? ? ? ? ? ? ? if (attr.name().indexOf("注:") >= 0) {
? ? ? ? ? ? ? ? ? ? ? ? HSSFFont font = workbook.createFont();
? ? ? ? ? ? ? ? ? ? ? ? font.setColor(HSSFFont.COLOR_RED);
// ? ? ? ? ? ? ? ? ? ? ? ?cellStyle.setFont(font);
? ? ? ? ? ? ? ? ? ? ? ? //設(shè)置顏色
// ? ? ? ? ? ? ? ? ? ? ? ?cellStyle.setFillForegroundColor(HSSFColor.HSSFColorPredefined.YELLOW.getIndex());
? ? ? ? ? ? ? ? ? ? ? ? sheet.setColumnWidth(i, 6000);
? ? ? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? ? ? HSSFFont font = workbook.createFont();
? ? ? ? ? ? ? ? ? ? ? ? // 粗體顯示
? ? ? ? ? ? ? ? ? ? ? ? font.setBold(true);
? ? ? ? ? ? ? ? ? ? ? ? // 選擇需要用到的字體格式
// ? ? ? ? ? ? ? ? ? ? ? ?cellStyle.setFont(font);
? ? ? ? ? ? ? ? ? ? ? ? //設(shè)置顏色
// ? ? ? ? ? ? ? ? ? ? ? ?cellStyle.setFillForegroundColor(HSSFColor.HSSFColorPredefined.LIGHT_YELLOW.getIndex());
? ? ? ? ? ? ? ? ? ? ? ? // 設(shè)置列寬
? ? ? ? ? ? ? ? ? ? ? ? sheet.setColumnWidth(i, (int) ((attr.width() + 0.72) * 256));
? ? ? ? ? ? ? ? ? ? ? ? row.setHeight((short) (attr.height() * 20));
? ? ? ? ? ? ? ? ? ? }
// ? ? ? ? ? ? ? ? ? ?cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
// ? ? ? ? ? ? ? ? ? ?cellStyle.setWrapText(true);
? ? ? ? ? ? ? ? ? ? cell.setCellStyle(cellStyle);
?
? ? ? ? ? ? ? ? ? ? // 寫入列名
? ? ? ? ? ? ? ? ? ? cell.setCellValue(attr.name());
?
? ? ? ? ? ? ? ? ? ? // 如果設(shè)置了提示信息則鼠標(biāo)放上去提示.
? ? ? ? ? ? ? ? ? ? if (StringUtils.isNotEmpty(attr.prompt())) {
? ? ? ? ? ? ? ? ? ? ? ? // 這里默認(rèn)設(shè)了2-101列提示.
? ? ? ? ? ? ? ? ? ? ? ? setHSSFPrompt(sheet, "", attr.prompt(), 1, 100, i, i);
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? // 如果設(shè)置了combo屬性則本列只能選擇不能輸入
? ? ? ? ? ? ? ? ? ? if (attr.combo().length > 0) {
? ? ? ? ? ? ? ? ? ? ? ? // 這里默認(rèn)設(shè)了2-101列只能選擇不能輸入.
? ? ? ? ? ? ? ? ? ? ? ? setHSSFValidation(sheet, attr.combo(), 1, 100, i, i);
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
?
? ? ? ? ? ? ? ? int startNo = index * sheetSize;
? ? ? ? ? ? ? ? int endNo = Math.min(startNo + sheetSize, list.size());
? ? ? ? ? ? ? ? // 寫入各條記錄,每條記錄對應(yīng)excel表中的一行
? ? ? ? ? ? ? ? HSSFCellStyle cs = workbook.createCellStyle();
? ? ? ? ? ? ? ? cs.setAlignment(HorizontalAlignment.CENTER);
? ? ? ? ? ? ? ? cs.setVerticalAlignment(VerticalAlignment.CENTER);
? ? ? ? ? ? ? ? for (int i = startNo; i < endNo; i++) {
? ? ? ? ? ? ? ? ? ? row = sheet.createRow(i + 1 - startNo);
? ? ? ? ? ? ? ? ? ? // 得到導(dǎo)出對象.
? ? ? ? ? ? ? ? ? ? T vo = (T) list.get(i);
? ? ? ? ? ? ? ? ? ? for (int j = 0; j < fields.size(); j++) {
? ? ? ? ? ? ? ? ? ? ? ? // 獲得field.
? ? ? ? ? ? ? ? ? ? ? ? Field field = fields.get(j);
? ? ? ? ? ? ? ? ? ? ? ? // 設(shè)置實體類私有屬性可訪問
? ? ? ? ? ? ? ? ? ? ? ? field.setAccessible(true);
? ? ? ? ? ? ? ? ? ? ? ? Excel attr = field.getAnnotation(Excel.class);
? ? ? ? ? ? ? ? ? ? ? ? try {
? ? ? ? ? ? ? ? ? ? ? ? ? ? // 設(shè)置行高
? ? ? ? ? ? ? ? ? ? ? ? ? ? row.setHeight((short) (attr.height() * 20));
? ? ? ? ? ? ? ? ? ? ? ? ? ? // 根據(jù)Excel中設(shè)置情況決定是否導(dǎo)出,有些情況需要保持為空,希望用戶填寫這一列.
? ? ? ? ? ? ? ? ? ? ? ? ? ? if (attr.isExport()) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? // 創(chuàng)建cell
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cell = row.createCell(j);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cell.setCellStyle(cs);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if (vo == null) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? // 如果數(shù)據(jù)存在就填入,不存在填入空格.
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cell.setCellValue("");
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? continue;
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? String dateFormat = attr.dateFormat();
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? String readConverterExp = attr.readConverterExp();
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if (StringUtils.isNotEmpty(dateFormat)) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cell.setCellValue(new SimpleDateFormat(dateFormat).format((Date) field.get(vo)));
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? } else if (StringUtils.isNotEmpty(readConverterExp)) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cell.setCellValue(convertByExp(String.valueOf(field.get(vo)), readConverterExp));
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cell.setCellType(CellType.STRING);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? // 如果數(shù)據(jù)存在就填入,不存在填入空格.
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cell.setCellValue(field.get(vo) == null ? attr.defaultValue() : field.get(vo) + attr.suffix());
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? } catch (Exception e) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? log.error("導(dǎo)出Excel失敗{}", e.getMessage());
? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ? //String filename = encodingFilename(sheetName);
? ? ? ? ? ? response.setContentType("application/octet-stream");
? ? ? ? ? ? response.setHeader("Content-disposition", "attachment;filename=" + URLEncoder.encode(sheetName, "UTF-8"));
? ? ? ? ? ? response.flushBuffer();
? ? ? ? ? ? workbook.write(response.getOutputStream());
? ? ? ? } catch (Exception e) {
? ? ? ? ? ? log.error("導(dǎo)出Excel異常{}", e.getMessage());
? ? ? ? ? ? throw new RuntimeException("導(dǎo)出Excel失敗,請聯(lián)系網(wǎng)站管理員!");
? ? ? ? } finally {
? ? ? ? ? ? if (workbook != null) {
? ? ? ? ? ? ? ? try {
? ? ? ? ? ? ? ? ? ? workbook.close();
? ? ? ? ? ? ? ? } catch (IOException e1) {
? ? ? ? ? ? ? ? ? ? e1.printStackTrace();
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }
? ? }
?
? ? /**
? ? ?* 設(shè)置單元格上提示
? ? ?*
? ? ?* @param sheet ? ? ? ? 要設(shè)置的sheet.
? ? ?* @param promptTitle ? 標(biāo)題
? ? ?* @param promptContent 內(nèi)容
? ? ?* @param firstRow ? ? ?開始行
? ? ?* @param endRow ? ? ? ?結(jié)束行
? ? ?* @param firstCol ? ? ?開始列
? ? ?* @param endCol ? ? ? ?結(jié)束列
? ? ?* @return 設(shè)置好的sheet.
? ? ?*/
? ? private static HSSFSheet setHSSFPrompt(HSSFSheet sheet, String promptTitle, String promptContent, int firstRow,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?int endRow, int firstCol, int endCol) {
? ? ? ? // 構(gòu)造constraint對象
? ? ? ? DVConstraint constraint = DVConstraint.createCustomFormulaConstraint("DD1");
? ? ? ? // 四個參數(shù)分別是:起始行、終止行、起始列、終止列
? ? ? ? CellRangeAddressList regions = new CellRangeAddressList(firstRow, endRow, firstCol, endCol);
? ? ? ? // 數(shù)據(jù)有效性對象
? ? ? ? HSSFDataValidation dataValidationView = new HSSFDataValidation(regions, constraint);
? ? ? ? dataValidationView.createPromptBox(promptTitle, promptContent);
? ? ? ? sheet.addValidationData(dataValidationView);
? ? ? ? return sheet;
? ? }
?
? ? /**
? ? ?* 設(shè)置某些列的值只能輸入預(yù)制的數(shù)據(jù),顯示下拉框.
? ? ?*
? ? ?* @param sheet ? ?要設(shè)置的sheet.
? ? ?* @param textlist 下拉框顯示的內(nèi)容
? ? ?* @param firstRow 開始行
? ? ?* @param endRow ? 結(jié)束行
? ? ?* @param firstCol 開始列
? ? ?* @param endCol ? 結(jié)束列
? ? ?* @return 設(shè)置好的sheet.
? ? ?*/
? ? private static HSSFSheet setHSSFValidation(HSSFSheet sheet, String[] textlist, int firstRow, int endRow,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?int firstCol, int endCol) {
? ? ? ? // 加載下拉列表內(nèi)容
? ? ? ? DVConstraint constraint = DVConstraint.createExplicitListConstraint(textlist);
? ? ? ? // 設(shè)置數(shù)據(jù)有效性加載在哪個單元格上,四個參數(shù)分別是:起始行、終止行、起始列、終止列
? ? ? ? CellRangeAddressList regions = new CellRangeAddressList(firstRow, endRow, firstCol, endCol);
? ? ? ? // 數(shù)據(jù)有效性對象
? ? ? ? HSSFDataValidation dataValidationList = new HSSFDataValidation(regions, constraint);
? ? ? ? sheet.addValidationData(dataValidationList);
? ? ? ? return sheet;
? ? }
?
? ? /**
? ? ?* 解析導(dǎo)出值 0=男,1=女,2=未知
? ? ?*
? ? ?* @param propertyValue 參數(shù)值
? ? ?* @param converterExp ?翻譯注解
? ? ?* @return 解析后值
? ? ?* @throws Exception
? ? ?*/
? ? private static String convertByExp(String propertyValue, String converterExp) throws Exception {
? ? ? ? try {
? ? ? ? ? ? String[] convertSource = converterExp.split(",");
? ? ? ? ? ? for (String item : convertSource) {
? ? ? ? ? ? ? ? String[] itemArray = item.split("=");
? ? ? ? ? ? ? ? if (itemArray[0].equals(propertyValue)) {
? ? ? ? ? ? ? ? ? ? return itemArray[1];
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? } catch (Exception e) {
? ? ? ? ? ? throw e;
? ? ? ? }
? ? ? ? return propertyValue;
? ? }
?
? ? /**
? ? ?* 編碼文件名
? ? ?*/
? ? /*private static String encodingFilename(String filename) {
? ? ? ? filename = UUID.randomUUID().toString() + "_" + filename + ".xls";
? ? ? ? return filename;
? ? }*/
}

第四步:無論導(dǎo)入導(dǎo)出,Excel表格的第一行都是跟實體類上@Excel注解的name屬性進行映射對應(yīng)的。

以下是示例:導(dǎo)出Excel表(該方法最好是返回void或者返回null),否則后臺會報錯(不影響運行)。   

? ? @PostMapping("/export")
? ? @ResponseBody
? ? public void export()
? ? {
? ? ? ? ExcelUtil<User> excelUtil = new ExcelUtil<>(User.class);
? ? ? ? //要導(dǎo)出的數(shù)據(jù)集
? ? ? ? List<User> list = getList();
? ? ? ? excelUtil.exportExcel(list, "userInformation.xlsx", ServletUtils.getResponse());
? ? }

附件:前端代碼:

exportExcel() {
? ? let link = document.createElement('a');
? ? link.style.display = 'none'
? ? axios({
? ? ? ? url: 'http://test.cih.net/user/pageExport',
? ? ? ? methods: "get",
? ? ? ? data: {},
? ? ? ? headers: {
? ? ? ? ? ? token: 'eyJ0eXB1234bklkIjoie1wiZWnm7jwkJtbvdcnqo'
? ? ? ? }
? ? }).then((res) => {
? ? ? ? let blob = new Blob([res.data], {
? ? ? ? ? ? type: "application/vnd.ms-excel"
? ? ? ? }); // 2.獲取請求返回的response對象中的blob 設(shè)置文件類型,這里以excel為例
? ? ? ? let url = window.URL.createObjectURL(blob); // 3.創(chuàng)建一個臨時的url指向blob對象
?
? ? ? ? // 4.創(chuàng)建url之后可以模擬對此文件對象的一系列操作,例如:預(yù)覽、下載
? ? ? ? let a = document.createElement("a");
? ? ? ? a.href = url;
? ? ? ? a.download = "導(dǎo)出表格.xlsx";
? ? ? ? a.click();
? ? ? ? // 5.釋放這個臨時的對象url
? ? ? ? window.URL.revokeObjectURL(url);
? ? })
}

java簡單的導(dǎo)出excel

1.pom 引入poi

 ? ? <!-- poi -->
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>org.apache.poi</groupId>
? ? ? ? ? ? <artifactId>poi</artifactId>
? ? ? ? </dependency>
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>org.apache.poi</groupId>
? ? ? ? ? ? <artifactId>poi-ooxml</artifactId>
? ? ? ? </dependency>

2.創(chuàng)建excel導(dǎo)出工具類

@Slf4j
public class ExportExcelUtils {
?
? ? /**
? ? ?* 導(dǎo)出Excel
? ? ?*
? ? ?* @param excelName 要導(dǎo)出的excel名稱
? ? ?* @param list ? ? ?要導(dǎo)出的數(shù)據(jù)集合
? ? ?* @param c ? ? ? ? 中英文字段對應(yīng)Map,即要導(dǎo)出的excel表頭
? ? ?* @param response ?使用response可以導(dǎo)出到瀏覽器
? ? ?* @param <T>
? ? ?*/
? ? public static <T> void export(String excelName, List<T> list, Class<T> c, HttpServletResponse response) {
? ? ? ? // 設(shè)置日期格式
? ? ? ? SimpleDateFormat df = new SimpleDateFormat("yyyyMMddHHmmss");
? ? ? ? // 設(shè)置默認(rèn)文件名為當(dāng)前時間:年月日時分秒
? ? ? ? if (excelName == null || excelName == "") {
? ? ? ? ? ? excelName = df.format(new Date());
? ? ? ? } else {
? ? ? ? ? ? excelName = excelName + df.format(new Date());
? ? ? ? }
?
? ? ? ? try {
? ? ? ? ? ? //創(chuàng)建一個WorkBook,對應(yīng)一個Excel文件
? ? ? ? ? ? HSSFWorkbook wb = new HSSFWorkbook();
? ? ? ? ? ? //在Workbook中,創(chuàng)建一個sheet,對應(yīng)Excel中的工作?。╯heet)
? ? ? ? ? ? HSSFSheet sheet = wb.createSheet(excelName);
? ? ? ? ? ? //設(shè)置 邊距、頁眉、頁腳
? ? ? ? ? ? HSSFPrintSetup printSetup = sheet.getPrintSetup();
? ? ? ? ? ? //打印方向,true:橫向,false:縱向(默認(rèn))
? ? ? ? ? ? printSetup.setLandscape(true);
? ? ? ? ? ? printSetup.setHeaderMargin(0.2);
? ? ? ? ? ? printSetup.setFooterMargin(0.2);
? ? ? ? ? ? //設(shè)置打印縮放為88%
? ? ? ? ? ? ///printSetup.setScale((short) 55);
? ? ? ? ? ? printSetup.setFitHeight((short) 0);
? ? ? ? ? ? printSetup.setFitWidth((short) 1);
? ? ? ? ? ? //列從左向右顯示②
? ? ? ? ? ? /// printSetup.setLeftToRight(true);
? ? ? ? ? ? // 紙張
? ? ? ? ? ? printSetup.setPaperSize(HSSFPrintSetup.A4_PAPERSIZE);
? ? ? ? ? ? // 頁邊距(下)
? ? ? ? ? ? sheet.setMargin(HSSFSheet.BottomMargin, 0.8);
? ? ? ? ? ? // 頁邊距(左)
? ? ? ? ? ? sheet.setMargin(HSSFSheet.LeftMargin, 0);
? ? ? ? ? ? // 頁邊距(右)
? ? ? ? ? ? sheet.setMargin(HSSFSheet.RightMargin, 0);
? ? ? ? ? ? // 頁邊距(上)
? ? ? ? ? ? sheet.setMargin(HSSFSheet.TopMargin, 0.8);
? ? ? ? ? ? //設(shè)置打印頁面為水平居中
? ? ? ? ? ? sheet.setHorizontallyCenter(true);
? ? ? ? ? ? sheet.setVerticallyCenter(true);
? ? ? ? ? ? sheet.setAutobreaks(false);
? ? ? ? ? ? sheet.setFitToPage(false);
? ? ? ? ? ? Footer footer = sheet.getFooter();
? ? ? ? ? ? //設(shè)置頁數(shù)
? ? ? ? ? ? footer.setCenter("第" + HeaderFooter.page() + "頁,共 " + HeaderFooter.numPages() + "頁");
? ? ? ? ? ? Header header = sheet.getHeader();
? ? ? ? ? ? //自定義頁眉,并設(shè)置頁眉 左中右顯示信息
? ? ? ? ? ? //居中
? ? ? ? ? ? ///header.setCenter("Center Header");
? ? ? ? ? ? //靠左
? ? ? ? ? ? header.setLeft(HSSFHeader.font("宋體", "") +
? ? ? ? ? ? ? ? ? ? HSSFHeader.fontSize((short) 16) + excelName + ".xlsx");
? ? ? ? ? ? //靠右
? ? ? ? ? ? ///header.setRight(HSSFHeader.font("Stencil-Normal", "Italic") +
? ? ? ? ? ? ///HSSFHeader.fontSize((short) 16) + "Right w/ Stencil-Normal Italic font and size 16");
?
? ? ? ? ? ? //創(chuàng)建單元格,并設(shè)置值表頭 設(shè)置表頭居中
? ? ? ? ? ? HSSFCellStyle style = wb.createCellStyle();
? ? ? ? ? ? //設(shè)置邊框
? ? ? ? ? ? //下邊框
? ? ? ? ? ? style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
? ? ? ? ? ? //左邊框
? ? ? ? ? ? style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
? ? ? ? ? ? //上邊框
? ? ? ? ? ? style.setBorderTop(HSSFCellStyle.BORDER_THIN);
? ? ? ? ? ? //右邊框
? ? ? ? ? ? style.setBorderRight(HSSFCellStyle.BORDER_THIN);
? ? ? ? ? ? //自動換行
? ? ? ? ? ? ///style.setWrapText(true);
? ? ? ? ? ? //創(chuàng)建一個居中格式
? ? ? ? ? ? style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
? ? ? ? ? ? //上下居中
? ? ? ? ? ? style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
? ? ? ? ? ? //設(shè)置字體
? ? ? ? ? ? HSSFFont font = wb.createFont();
? ? ? ? ? ? font.setFontName("宋體");
?
? ? ? ? ? ? style.setFont(font);
? ? ? ? ? ? // 填充工作表
? ? ? ? ? ? //獲取需要轉(zhuǎn)出的excel表頭的map字段
? ? ? ? ? ? LinkedHashMap<String, String> fieldMap = new LinkedHashMap<>();
? ? ? ? ? ? //循環(huán)注解里面的值 填入Link集合
? ? ? ? ? ? Field[] declaredFields = c.getDeclaredFields();
? ? ? ? ? ? //獲取屬性對應(yīng)的枚舉類
? ? ? ? ? ? LinkedHashMap<String, Class> converterMap = new LinkedHashMap<>();
?
? ? ? ? ? ? for (Field declaredField : declaredFields) {
? ? ? ? ? ? ? ? //獲取注解對象
? ? ? ? ? ? ? ? ExportEntityMap declaredAnnotation = declaredField.getDeclaredAnnotation(ExportEntityMap.class);
? ? ? ? ? ? ? ? ExportProperty converterAnnotation = declaredField.getDeclaredAnnotation(ExportProperty.class);
? ? ? ? ? ? ? ? if (declaredAnnotation != null) {
? ? ? ? ? ? ? ? ? ? fieldMap.put(declaredAnnotation.EnName(), declaredAnnotation.CnName());
? ? ? ? ? ? ? ? ? ? if (converterAnnotation != null) {
? ? ? ? ? ? ? ? ? ? ? ? converterMap.put(declaredAnnotation.EnName(), converterAnnotation.Converter());
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ? fillSheet(sheet, list, fieldMap, style, converterMap);
? ? ? ? ? ? // 設(shè)置response頭信息
? ? ? ? ? ? response.reset();
?
? ? ? ? ? ? try {
? ? ? ? ? ? ? ? log.info("excelName:{}", excelName);
? ? ? ? ? ? ? ? String fileName = URLEncoder.encode(excelName + ".xlsx", "UTF-8");
? ? ? ? ? ? ? ? response.setHeader("Content-disposition", "attachment; filename=" + fileName);
? ? ? ? ? ? } catch (UnsupportedEncodingException e1) {
? ? ? ? ? ? ? ? log.error("導(dǎo)出excel失敗,異常:", e1);
? ? ? ? ? ? }
? ? ? ? ? ? //將文件輸出
? ? ? ? ? ? OutputStream outputStream = new BufferedOutputStream(response.getOutputStream());
? ? ? ? ? ? response.setContentType("application/octet-stream");
? ? ? ? ? ? response.flushBuffer();
?
? ? ? ? ? ? wb.write(outputStream);
? ? ? ? ? ? outputStream.flush();
? ? ? ? ? ? outputStream.close();
? ? ? ? } catch (Exception e) {
? ? ? ? ? ? log.error("導(dǎo)出Excel失敗,異常:", e);
? ? ? ? }
? ? }
?
?
? ? /**
? ? ?* 根據(jù)字段名獲取字段對象
? ? ?*
? ? ?* @param fieldName 字段名
? ? ?* @param clazz ? ? 包含該字段的類
? ? ?* @return 字段
? ? ?*/
? ? public static Field getFieldByName(String fieldName, Class<?> clazz) {
? ? ? ? // 拿到本類的所有字段
? ? ? ? Field[] selfFields = clazz.getDeclaredFields();
? ? ? ? // 如果本類中存在該字段,則返回
? ? ? ? for (Field field : selfFields) {
? ? ? ? ? ? //如果本類中存在該字段,則返回
? ? ? ? ? ? if (field.getName().equals(fieldName)) {
? ? ? ? ? ? ? ? return field;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? // 否則,查看父類中是否存在此字段,如果有則返回
? ? ? ? Class<?> superClazz = clazz.getSuperclass();
? ? ? ? if (superClazz != null && superClazz != Object.class) {
? ? ? ? ? ? //遞歸
? ? ? ? ? ? return getFieldByName(fieldName, superClazz);
? ? ? ? }
? ? ? ? // 如果本類和父類都沒有,則返回空
? ? ? ? return null;
? ? }
?
? ? /**
? ? ?* 根據(jù)字段名獲取字段值
? ? ?*
? ? ?* @param fieldName 字段名
? ? ?* @param o ? ? ? ? 對象
? ? ?* @return 字段值
? ? ?* @throws Exception 異常
? ? ?*/
? ? public static String getFieldValueByName(String fieldName, Object o)
? ? ? ? ? ? throws Exception {
? ? ? ? String fieldValue = null;
? ? ? ? //根據(jù)字段名得到字段對象
? ? ? ? Field field = getFieldByName(fieldName, o.getClass());
? ? ? ? //如果該字段存在,則取出該字段的值
? ? ? ? if (field != null) {
? ? ? ? ? ? //類中的成員變量為private,在類外邊使用屬性值,故必須進行此操作
? ? ? ? ? ? field.setAccessible(true);
? ? ? ? ? ? //獲取當(dāng)前對象中當(dāng)前Field的value
? ? ? ? ? ? fieldValue = field.get(o) == null ? "" : field.get(o).toString();
? ? ? ? ? ? String fieldType = field.getGenericType().toString();
? ? ? ? ? ? if ("class java.math.BigDecimal".equals(fieldType) || "class java.lang.Double".equals(fieldType)) {
? ? ? ? ? ? ? ? fieldValue = new BigDecimal(fieldValue).setScale(2, BigDecimal.ROUND_HALF_UP).toString();
? ? ? ? ? ? } else if ("class java.time.LocalDateTime".equals(fieldType) || "class java.time.LocalDate".equals(fieldType)) {
? ? ? ? ? ? ? ? fieldValue = fieldValue.replace("T", " ");
? ? ? ? ? ? }
? ? ? ? } else {
? ? ? ? ? ? throw new Exception(o.getClass().getSimpleName() + "類不存在字段名 "
? ? ? ? ? ? ? ? ? ? + fieldName);
? ? ? ? }
? ? ? ? return fieldValue;
? ? }
?
? ? /**
? ? ?* 根據(jù)帶路徑或不帶路徑的屬性名獲取屬性值,即接受簡單屬性名, 如userName等,又接受帶路徑的屬性名,如student.department.name等
? ? ?*
? ? ?* @param fieldNameSequence 帶路徑的屬性名或簡單屬性名
? ? ?* @param o ? ? ? ? ? ? ? ? 對象
? ? ?* @return 屬性值
? ? ?* @throws Exception 異常
? ? ?*/
? ? public static String getFieldValueByNameSequence(String fieldNameSequence,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?Object o) throws Exception {
? ? ? ? String value = null;
? ? ? ? // 將fieldNameSequence進行拆分
? ? ? ? String[] attributes = fieldNameSequence.split("\\.");
? ? ? ? if (attributes.length == 1) {
? ? ? ? ? ? value = getFieldValueByName(fieldNameSequence, o);
? ? ? ? } else {
? ? ? ? ? ? // 根據(jù)數(shù)組中第一個連接屬性名獲取連接屬性對象,如student.department.name
? ? ? ? ? ? Object fieldObj = getFieldValueByName(attributes[0], o);
? ? ? ? ? ? //截取除第一個屬性名之后的路徑
? ? ? ? ? ? String subFieldNameSequence = fieldNameSequence
? ? ? ? ? ? ? ? ? ? .substring(fieldNameSequence.indexOf(".") + 1);
? ? ? ? ? ? //遞歸得到最終的屬性對象的值
? ? ? ? ? ? value = getFieldValueByNameSequence(subFieldNameSequence, fieldObj);
? ? ? ? }
? ? ? ? return value;
? ? }
?
? ? /**
? ? ?* 向工作表中填充數(shù)據(jù)
? ? ?*
? ? ?* @param sheet ? ? ? ?excel的工作表名稱
? ? ?* @param list ? ? ? ? 數(shù)據(jù)源
? ? ?* @param fieldMap ? ? 中英文字段對應(yīng)關(guān)系的Map
? ? ?* @param style ? ? ? ?表格中的格式
? ? ?* @param converterMap 屬性對應(yīng)轉(zhuǎn)化器的Map
? ? ?* @throws Exception 異常
? ? ?*/
? ? public static <T> void fillSheet(HSSFSheet sheet, List<T> list,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?LinkedHashMap<String, String> fieldMap, HSSFCellStyle style, LinkedHashMap<String, Class> converterMap) throws Exception {
? ? ? ? // 定義存放英文字段名和中文字段名的數(shù)組
? ? ? ? String[] enFields = new String[fieldMap.size()];
? ? ? ? String[] cnFields = new String[fieldMap.size()];
? ? ? ? // 填充數(shù)組
? ? ? ? int count = 0;
? ? ? ? for (Map.Entry<String, String> entry : fieldMap.entrySet()) {
? ? ? ? ? ? enFields[count] = entry.getKey();
? ? ? ? ? ? cnFields[count] = entry.getValue();
? ? ? ? ? ? count++;
? ? ? ? }
?
? ? ? ? //存儲最大列寬
? ? ? ? Map<Integer, Integer> maxWidth = new HashMap<>(16);
? ? ? ? HSSFRow row = sheet.createRow(0);
? ? ? ? HSSFCell cell = null;
? ? ? ? // 填充表頭
? ? ? ? for (int i = 0; i < cnFields.length; i++) {
? ? ? ? ? ? cell = row.createCell(i);
? ? ? ? ? ? cell.setCellValue(cnFields[i]);
? ? ? ? ? ? cell.setCellStyle(style);
? ? ? ? ? ? sheet.autoSizeColumn(i);
? ? ? ? ? ? //設(shè)置自適應(yīng)寬高
? ? ? ? ? ? maxWidth.put(i, cell.getStringCellValue().getBytes().length * 256 + 200);
? ? ? ? }
? ? ? ? // 填充內(nèi)容
? ? ? ? for (int index = 0; index < list.size(); index++) {
? ? ? ? ? ? row = sheet.createRow(index + 1);
? ? ? ? ? ? // 獲取單個對象
? ? ? ? ? ? T item = list.get(index);
? ? ? ? ? ? int j = 0;
? ? ? ? ? ? for (int i = 0; i < enFields.length; i++) {
? ? ? ? ? ? ? ? HSSFCell createCell = row.createCell(j);
? ? ? ? ? ? ? ? String objValue = getFieldValueByNameSequence(enFields[i], item);
? ? ? ? ? ? ? ? //獲取屬性對應(yīng)的枚舉類
? ? ? ? ? ? ? ? Class<Enum> converterClazz = converterMap.get(enFields[i]);
? ? ? ? ? ? ? ? objValue = convertFieldValue(objValue, converterClazz);
? ? ? ? ? ? ? ? String fieldValue = objValue == null ? "" : objValue;
? ? ? ? ? ? ? ? cell = row.createCell(i);
? ? ? ? ? ? ? ? createCell.setCellValue(fieldValue);
?
? ? ? ? ? ? ? ? int length = createCell.getStringCellValue().getBytes().length * 256 + 200;
? ? ? ? ? ? ? ? //這里把寬度最大限制到15000
? ? ? ? ? ? ? ? if (length > 15000) {
? ? ? ? ? ? ? ? ? ? length = 15000;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? maxWidth.put(j, Math.max(length, maxWidth.get(j)));
? ? ? ? ? ? ? ? j++;
? ? ? ? ? ? ? ? createCell.setCellStyle(style);
? ? ? ? ? ? }
? ? ? ? }
?
? ? ? ? // 列寬自適應(yīng)
? ? ? ? for (int i = 0; i < cnFields.length; i++) {
? ? ? ? ? ? sheet.setColumnWidth(i, maxWidth.get(i));
? ? ? ? }
? ? }
?
? ? /**
? ? ?* 轉(zhuǎn)換屬性值
? ? ?*
? ? ?* @param objValue ? ? ? :
? ? ?* @param converterClazz :
? ? ?* @return java.lang.String
? ? ?**/
? ? private static <T> String convertFieldValue(String objValue, Class<Enum> converterClazz) throws Exception {
? ? ? ? if (ObjectUtil.isNotNull(converterClazz)) {
? ? ? ? ? ? //獲取所有枚舉實例
? ? ? ? ? ? Enum[] enumConstants = converterClazz.getEnumConstants();
? ? ? ? ? ? //根據(jù)方法名獲取方法
? ? ? ? ? ? Method valueMethod = converterClazz.getMethod("getValue");
? ? ? ? ? ? if (ObjectUtil.isNull(valueMethod)) {
? ? ? ? ? ? ? ? throw new Exception(converterClazz.getSimpleName() + "類找不到getValue()方法");
? ? ? ? ? ? }
? ? ? ? ? ? Method descMethod = converterClazz.getMethod("getDescription");
? ? ? ? ? ? if (ObjectUtil.isNull(descMethod)) {
? ? ? ? ? ? ? ? throw new Exception(converterClazz.getSimpleName() + "類找不到getDescription()方法");
? ? ? ? ? ? }
? ? ? ? ? ? for (Enum enumFiled : enumConstants) {
? ? ? ? ? ? ? ? //執(zhí)行枚舉方法獲得枚舉實例對應(yīng)的值
? ? ? ? ? ? ? ? Object value = valueMethod.invoke(enumFiled);
? ? ? ? ? ? ? ? Object description = descMethod.invoke(enumFiled);
? ? ? ? ? ? ? ? if (ObjectUtil.equal(objValue, value.toString())) {
? ? ? ? ? ? ? ? ? ? objValue = description.toString();
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? return objValue;
? ? }
?
}

3.自定義標(biāo)簽Export標(biāo)簽

@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface ExportEntityMap {
? ? String EnName() default "實體屬性名稱";
?
? ? String CnName() default "excel標(biāo)題名稱";
}
@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface ExportProperty {
?
? ? Class<? extends Enum> Converter();
}

枚舉 

public enum SexEnum {
?
? ? /**
? ? ?* 男
? ? ?*/
? ? MALE(1, "MALE", "男"),
?
? ? /**
? ? ?* 女
? ? ?*/
? ? FEMALE(2, "FEMALE", "女");
?
? ? private int value;
?
? ? private String code;
?
? ? private String description;
?
? ? SexEnum(int value, String code, String description) {
? ? ? ? this.value = value;
? ? ? ? this.code = code;
? ? ? ? this.description = description;
? ? }
?
? ? public int getValue() {
? ? ? ? return value;
? ? }
?
? ? public String getDescription() {
? ? ? ? return description;
? ? }
?
? ? public String getCode() {
? ? ? ? return code;
? ? }
}

4. 實體類引入@ExportEntityMap標(biāo)簽

? ? /**
? ? ?* 性別
? ? ?*/
? ? @ExportEntityMap(CnName = "性別", EnName = "sex")
? ? //通過@ExportProperty來轉(zhuǎn)換枚舉字段
? ? @ExportProperty(Converter = SexEnum.class)
? ? private Integer sex;
? ? /**
? ? ?* 年齡
? ? ?*/
? ? @ExportEntityMap(CnName = "年齡", EnName = "age")
? ? private Integer age;

5.在Controller層中調(diào)用ExportExcelUtils方法即可

? ? @ApiOperation("xxxx")
? ? @PostMapping(value = "/xxxx")
? ? public void getExport(HttpServletResponse response, @RequestBody ListRo ro) {
? ? ? ? //導(dǎo)出數(shù)據(jù)
? ? ? ? ExportExcelUtils.export("name", list, EntityClass.class, response);
? ? }

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java基于反射得到對象屬性值的方法

    java基于反射得到對象屬性值的方法

    這篇文章主要介紹了java基于反射得到對象屬性值的方法,結(jié)合實例形式分析了java基于反射獲取對象屬性值的相關(guān)實現(xiàn)方法與操作技巧,需要的朋友可以參考下
    2017-03-03
  • springboot?如何解決yml沒有spring的小葉子標(biāo)志問題

    springboot?如何解決yml沒有spring的小葉子標(biāo)志問題

    這篇文章主要介紹了springboot?如何解決yml沒有spring的小葉子標(biāo)志問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Java重點之基于比較的七大排序

    Java重點之基于比較的七大排序

    最近幾天在研究排序算法,看了很多博客,發(fā)現(xiàn)網(wǎng)上有的文章中對排序算法解釋的并不是很透徹,而且有很多代碼都是錯誤的,所以我根據(jù)這幾天看的文章,整理了一個較為完整的排序算法總結(jié),本文中的所有算法均有JAVA實現(xiàn),經(jīng)本人調(diào)試無誤后才發(fā)出,如有錯誤,請各位前輩指出
    2021-10-10
  • 在eclipse中中文漢字亂碼的解決方案

    在eclipse中中文漢字亂碼的解決方案

    在本篇文章里小編給大家分享的是關(guān)于在eclipse中中文漢字亂碼的解決方案,有需要的朋友們可以學(xué)習(xí)下。
    2019-12-12
  • Java可以如何實現(xiàn)文件變動的監(jiān)聽的示例

    Java可以如何實現(xiàn)文件變動的監(jiān)聽的示例

    本篇文章主要介紹了Java可以如何實現(xiàn)文件變動的監(jiān)聽的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • Java中Function的使用及說明

    Java中Function的使用及說明

    這篇文章主要介紹了Java中Function的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Springboot+rabbitmq實現(xiàn)延時隊列的兩種方式

    Springboot+rabbitmq實現(xiàn)延時隊列的兩種方式

    這篇文章主要介紹了Springboot+rabbitmq實現(xiàn)延時隊列的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • Java技巧:快速獲取圖片拍攝時間

    Java技巧:快速獲取圖片拍攝時間

    想知道如何用Java讀取圖片的拍攝時間嗎?在這篇指南中,我將向你展示如何利用Java編程語言輕松獲取圖像的拍攝時間信息,不要錯過這個簡單而有用的技巧!
    2023-12-12
  • 一文搞懂Spring中Bean的生命周期

    一文搞懂Spring中Bean的生命周期

    這篇文章主要為大家介紹了Spring中Bean生命周期的使用及控制,文中的示例代碼講解詳細,對我們學(xué)習(xí)或工作有一定的參考價值,感興趣的可以學(xué)習(xí)一下
    2022-06-06
  • SpringBoot集成shiro,MyRealm中無法@Autowired注入Service的問題

    SpringBoot集成shiro,MyRealm中無法@Autowired注入Service的問題

    今天小編就為大家分享一篇關(guān)于SpringBoot集成shiro,MyRealm中無法@Autowired注入Service的問題,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03

最新評論

91精品国产91青青碰| 国产使劲操在线播放| 亚洲综合另类精品小说| 国产亚洲天堂天天一区| 午夜在线观看岛国av,com| 人妻丝袜精品中文字幕| 免费黄高清无码国产| 喷水视频在线观看这里只有精品| 涩爱综合久久五月蜜臀| aiss午夜免费视频| 久久这里只有精品热视频| 男人靠女人的逼视频| 国产亚洲天堂天天一区| 美女福利视频网址导航| 天天做天天干天天操天天射| 1区2区3区4区视频在线观看| 天天日天天舔天天射进去| 天天干天天操天天扣| 深夜男人福利在线观看| 黄色成人在线中文字幕| sejizz在线视频| 五月天色婷婷在线观看视频免费| 青青青视频自偷自拍38碰| 鸡巴操逼一级黄色气| 男女第一次视频在线观看| 欧美男人大鸡吧插女人视频| 在线免费观看日本片| 特级无码毛片免费视频播放| 美洲精品一二三产区区别| 三级av中文字幕在线观看| 国产精品久久久久久久女人18| 国产欧美日韩第三页| 亚洲成人熟妇一区二区三区| 日韩欧美在线观看不卡一区二区 | 91精品国产高清自在线看香蕉网| 亚洲精品无码色午夜福利理论片| 大鸡巴后入爆操大屁股美女 | 最近中文2019年在线看| 我想看操逼黄色大片| 五月天中文字幕内射| 中文字幕亚洲久久久| 精品高潮呻吟久久av| 成人av天堂丝袜在线观看| 2o22av在线视频| 久久精品国产23696| 国产精品一区二区av国| 在线免费观看黄页视频| 亚洲国产精品久久久久蜜桃| 视频一区 二区 三区 综合| 中文字幕人妻一区二区视频| 色偷偷伊人大杳蕉综合网| 青青青青爽手机在线| 色爱av一区二区三区| 日韩熟女系列一区二区三区| 亚洲精品国偷自产在线观看蜜桃| 亚洲国产40页第21页| 国产精品污污污久久| 免费观看理论片完整版| 91国产在线免费播放| 日本免费午夜视频网站| 视频久久久久久久人妻| 成人24小时免费视频| 97色视频在线观看| 黄色大片免费观看网站| 中文字幕在线视频一区二区三区| 日本免费午夜视频网站| 人人爽亚洲av人人爽av| 狍和女人的王色毛片| 在线新三级黄伊人网| 丝袜亚洲另类欧美变态| 亚洲熟女久久久36d| 中文字幕日韩人妻在线三区| 2018在线福利视频| 2022精品久久久久久中文字幕| 在线观看成人国产电影| 在线国产中文字幕视频| 可以免费看的www视频你懂的| 亚洲欧美成人综合视频| caoporm超碰国产| 欧美va亚洲va天堂va| 91九色porny国产在线| 91在线免费观看成人| 精产国品久久一二三产区区别| 日韩av免费观看一区| 免费看国产又粗又猛又爽又黄视频| 97人妻人人澡爽人人精品| 国产视频精品资源网站| 91久久国产成人免费网站| av高潮迭起在线观看| 午夜精品一区二区三区更新| 一个人免费在线观看ww视频| 97欧洲一区二区精品免费| 女警官打开双腿沦为性奴| 亚洲国产成人在线一区| 青青社区2国产视频| 久草视频 久草视频2| 天天日天天添天天爽| 久久久精品国产亚洲AV一| 午夜国产免费福利av| 国产第一美女一区二区三区四区 | 日本www中文字幕| 亚洲在线观看中文字幕av| 国产综合视频在线看片| 97小视频人妻一区二区| 人妻少妇av在线观看| 最近的中文字幕在线mv视频| 适合午夜一个人看的视频| 97超碰国语国产97超碰| 亚洲免费视频欧洲免费视频| 五十路在线观看完整版| 97超碰最新免费在线观看| 狠狠的往里顶撞h百合| av俺也去在线播放| 亚洲国产免费av一区二区三区| 青青草在观免费国产精品| 一级黄片久久久久久久久| 在线国产精品一区二区三区| 国产在线91观看免费观看| 欧美精品伦理三区四区| 51国产成人精品视频| 日韩少妇人妻精品无码专区| 女蜜桃臀紧身瑜伽裤| 中文字幕无码一区二区免费| 成人H精品动漫在线无码播放| 夫妻在线观看视频91| 福利片区一区二体验区| 亚洲 人妻 激情 中文| 加勒比视频在线免费观看| 一区二区三区四区中文| 天天艹天天干天天操| 蜜桃臀av蜜桃臀av| 日本一区精品视频在线观看| 国产精品亚洲а∨天堂免| 中文字幕在线一区精品| 午夜大尺度无码福利视频| 成人亚洲国产综合精品| gogo国模私拍视频| 大胸性感美女羞爽操逼毛片| 久久丁香花五月天色婷婷| 亚洲伊人色一综合网| 一区二区三区蜜臀在线| 免费十精品十国产网站| 制丝袜业一区二区三区| 久久久久久久久久性潮| 色天天天天射天天舔| 亚洲高清自偷揄拍自拍| 欧美怡红院视频在线观看| 人妻素人精油按摩中出| 中文字幕视频一区二区在线观看| 丰满的子国产在线观看| 一区二区三区av高清免费| 激情人妻校园春色亚洲欧美| 午夜频道成人在线91| 久久久精品999精品日本| 日本三极片中文字幕| 成年人啪啪视频在线观看| www久久久久久久久久久| 精品一区二区三区三区色爱| 精品人妻一二三区久久| 亚洲av香蕉一区区二区三区犇| 欧美区一区二区三视频| 一色桃子久久精品亚洲| 成年人该看的视频黄免费| 亚洲区欧美区另类最新章节| 99精品国自产在线人| 免费黄色成人午夜在线网站| 2020av天堂网在线观看| 亚洲一区二区三区久久受| 国产丰满熟女成人视频| 黄色大片男人操女人逼| 91香蕉成人app下载| 97黄网站在线观看| 亚洲少妇人妻无码精品| 青青青视频自偷自拍38碰| 欧美偷拍自拍色图片| 欧美一区二区三区乱码在线播放| 亚洲少妇人妻无码精品| 亚洲天堂成人在线观看视频网站| 在线观看免费岛国av| 亚洲高清自偷揄拍自拍| 久久精品36亚洲精品束缚| 啪啪啪18禁一区二区三区| 特级无码毛片免费视频播放 | 日本少妇人妻xxxxxhd| 欧美在线偷拍视频免费看| 黑人乱偷人妻中文字幕| 国产大鸡巴大鸡巴操小骚逼小骚逼| 91亚洲精品干熟女蜜桃频道| 久久久久久九九99精品| 黄色黄色黄片78在线| 91精品综合久久久久3d动漫 | 成人亚洲国产综合精品| 国产黑丝高跟鞋视频在线播放| 美女被肏内射视频网站| 色花堂在线av中文字幕九九| 在线观看国产网站资源| 一区二区三区精品日本| aⅴ精产国品一二三产品| 日本三极片中文字幕| 午夜成午夜成年片在线观看 | 喷水视频在线观看这里只有精品| 国产欧美日韩第三页| 91试看福利一分钟| 天堂女人av一区二区| xxx日本hd高清| 福利视频广场一区二区| 精品亚洲中文字幕av| 青青在线视频性感少妇和隔壁黑丝| 97人妻色免费视频| 天天夜天天日天天日| 91片黄在线观看喷潮| 欧美一区二区三区啪啪同性| 国产视频一区在线观看| 国产在线91观看免费观看| 亚洲熟女女同志女同| 孕妇奶水仑乱A级毛片免费看| 欧美精产国品一二三产品价格 | 天天干天天操天天扣| 大香蕉伊人国产在线| 66久久久久久久久久久| 亚洲激情唯美亚洲激情图片| 亚洲一区av中文字幕在线观看| 天天日天天天天天天天天天天| 制服丝袜在线人妻中文字幕| 国产精品国产精品一区二区| 国产熟妇乱妇熟色T区| 成年人黄色片免费网站| 免费在线播放a级片| 免费在线黄色观看网站| 大鸡巴操娇小玲珑的女孩逼| 五月婷婷在线观看视频免费| 亚洲午夜伦理视频在线| 黑人3p华裔熟女普通话| 欧洲黄页网免费观看| 同居了嫂子在线播高清中文| 欧美成人黄片一区二区三区| 在线视频免费观看网| 美女吃鸡巴操逼高潮视频| 瑟瑟视频在线观看免费视频| 内射久久久久综合网| 国产久久久精品毛片| 亚洲另类伦春色综合小| 综合国产成人在线观看| 97超碰免费在线视频| 国产黑丝高跟鞋视频在线播放| 强行扒开双腿猛烈进入免费版| 91大屁股国产一区二区| 久碰精品少妇中文字幕av| 久久久超爽一二三av| 欧美日韩情色在线观看| 一区二区三区的久久的蜜桃的视频| 久久精品在线观看一区二区| 亚洲中文字幕人妻一区| 成年人午夜黄片视频资源| 国产又粗又硬又大视频| tube69日本少妇| 国产女人被做到高潮免费视频| 自拍偷区二区三区麻豆| 在线观看免费岛国av| 性色蜜臀av一区二区三区| 天天干天天爱天天色| 色哟哟在线网站入口| 人人妻人人人操人人人爽| 欧美一区二区三区啪啪同性| 91 亚洲视频在线观看| 中文字幕之无码色多多| 国产aⅴ一线在线观看| 男女啪啪视频免费在线观看| 不卡一不卡二不卡三| 精品日产卡一卡二卡国色天香| 成人av久久精品一区二区| 成年人中文字幕在线观看| 熟女人妻三十路四十路人妻斩| 久久久制服丝袜中文字幕| 色婷婷综合激情五月免费观看 | 国产av欧美精品高潮网站| 亚洲高清国产自产av| 国产综合视频在线看片| 黄色视频在线观看高清无码| 欧美日韩v中文在线| 丝袜肉丝一区二区三区四区在线 | 二区中出在线观看老师| 美女福利写真在线观看视频| 日比视频老公慢点好舒服啊| 激情五月婷婷免费视频| 青青擦在线视频国产在线| 亚洲1069综合男同| 大鸡八强奸视频在线观看| 啪啪啪啪啪啪啪啪啪啪黄色| 日视频免费在线观看| 五十路熟女人妻一区二区9933| 中文字幕在线第一页成人| 亚洲蜜臀av一区二区三区九色| 色哟哟在线网站入口| 美女av色播在线播放| 在线可以看的视频你懂的 | 国产精品一二三不卡带免费视频| av在线免费观看亚洲天堂| 国产性感美女福利视频| 2022精品久久久久久中文字幕| 99精品国产自在现线观看| 午夜精品久久久久麻豆影视| 大陆胖女人与丈夫操b国语高清| 色爱av一区二区三区| 狠狠鲁狠狠操天天晚上干干| 亚洲成人激情av在线| 久草视频首页在线观看| 偷青青国产精品青青在线观看| 亚洲综合色在线免费观看| 国产在线观看免费人成短视频| ka0ri在线视频| 中文字幕av男人天堂| 熟女国产一区亚洲中文字幕| 91人妻精品一区二区在线看| 激情人妻校园春色亚洲欧美 | 老司机欧美视频在线看| 久久久久久久99精品| 岛国黄色大片在线观看| 日本精品一区二区三区在线视频。| 日本性感美女写真视频| 1000小视频在线| 91she九色精品国产| 亚洲精品国产在线电影| 亚洲欧美清纯唯美另类| 亚洲高清国产一区二区三区| av在线观看网址av| 黄网十四区丁香社区激情五月天| v888av在线观看视频| 日韩美女福利视频网| 少妇人妻100系列| 日本午夜久久女同精女女| 91精品啪在线免费| 欧洲精品第一页欧洲精品亚洲| 亚洲国产精品黑丝美女| 天堂av在线最新版在线| 秋霞午夜av福利经典影视| 2020中文字幕在线播放| 玖玖一区二区在线观看| 偷拍3456eee| 91av中文视频在线| 五十路熟女av天堂| 69精品视频一区二区在线观看| 欧美成人一二三在线网| 一区二区三区日本伦理| 区一区二区三国产中文字幕| 91免费福利网91麻豆国产精品 | 国产精品视频一区在线播放| 国产免费av一区二区凹凸四季| 国产成人自拍视频在线免费观看| 久久久久只精品国产三级| 2018在线福利视频| 国产综合视频在线看片| 91色秘乱一区二区三区| 含骚鸡巴玩逼逼视频| 国产视频在线视频播放| 日本一道二三区视频久久| 国产刺激激情美女网站| 国产视频网站国产视频| 欧美精品国产综合久久| 天天插天天狠天天操| 77久久久久国产精产品| 亚洲推理片免费看网站| 精品高潮呻吟久久av| 这里只有精品双飞在线播放| 黄色视频在线观看高清无码| 亚洲av无女神免非久久| 91极品大一女神正在播放 | 午夜久久香蕉电影网| 免费在线黄色观看网站| 超碰97人人澡人人| 亚洲青青操骚货在线视频| 白嫩白嫩美女极品国产在线观看| 黄色视频成年人免费观看| av高潮迭起在线观看| 国产精品手机在线看片| 蜜桃视频在线欧美一区| 青青青青青青青青青青草青青 | 欧美综合婷婷欧美综合| 欧美激情电影免费在线| 自拍偷拍日韩欧美亚洲| 亚洲人一区二区中文字幕| 一个色综合男人天堂| 天天干夜夜操啊啊啊| 亚洲va天堂va国产va久| 全国亚洲男人的天堂| 中文字幕亚洲中文字幕| 91老师蜜桃臀大屁股| 国产清纯美女al在线| 99婷婷在线观看视频| 亚洲 清纯 国产com| 国产九色91在线视频| 黄片大全在线观看观看| 班长撕开乳罩揉我胸好爽| 日本真人性生活视频免费看| 91 亚洲视频在线观看| 特一级特级黄色网片| 红杏久久av人妻一区| 欧洲黄页网免费观看| 青青在线视频性感少妇和隔壁黑丝| 欧美另类重口味极品在线观看| 成年人该看的视频黄免费| 曰本无码人妻丰满熟妇啪啪| 社区自拍揄拍尻屁你懂的| 国产女孩喷水在线观看| 美女张开两腿让男人桶av| 四川乱子伦视频国产vip| 久久人人做人人妻人人玩精品vr| 亚洲蜜臀av一区二区三区九色 | 97黄网站在线观看| 久久99久久99精品影院| 国产91嫩草久久成人在线视频| 综合一区二区三区蜜臀| 美女在线观看日本亚洲一区| 久久这里只有精彩视频免费| 国产日韩精品一二三区久久久| 日本a级视频老女人| 中文字幕在线一区精品| 亚洲乱码中文字幕在线| 嫩草aⅴ一区二区三区| 国产麻豆乱子伦午夜视频观看| 激情伦理欧美日韩中文字幕| 超黄超污网站在线观看| 精品一线二线三线日本| 日韩无码国产精品强奸乱伦| 端庄人妻堕落挣扎沉沦| 一区二区在线观看少妇| 五十路在线观看完整版| 一级黄片大鸡巴插入美女| 超污视频在线观看污污污| 中文字幕第1页av一天堂网| 亚洲最大黄了色网站| 久久丁香婷婷六月天| 韩国女主播精品视频网站| 全国亚洲男人的天堂| chinese国产盗摄一区二区 | 午夜场射精嗯嗯啊啊视频| 精品一区二区三区三区88| 黄页网视频在线免费观看| 偷拍自拍国产在线视频| 国产午夜亚洲精品不卡在线观看| 日韩在线视频观看有码在线| 最新日韩av传媒在线| 2025年人妻中文字幕乱码在线| 久久免费看少妇高潮完整版| 天天操,天天干,天天射| 91天堂精品一区二区| 少妇被强干到高潮视频在线观看 | 日本一二三中文字幕| 和邻居少妇愉情中文字幕| 亚洲码av无色中文| 扒开让我视频在线观看| 日本午夜福利免费视频| 国产在线免费观看成人| 19一区二区三区在线播放| 亚洲熟女女同志女同| 亚洲欧美在线视频第一页| av老司机亚洲一区二区| 亚洲激情唯美亚洲激情图片| 中文字幕 码 在线视频| 精品乱子伦一区二区三区免费播| 2022精品久久久久久中文字幕| 国产实拍勾搭女技师av在线| 天天草天天色天天干| 国产日韩精品电影7777| 亚洲精品成人网久久久久久小说 | 天天做天天干天天操天天射| gav成人免费播放| 97国产福利小视频合集| 超碰97人人做人人爱| 888欧美视频在线| 男人插女人视频网站| 成人久久精品一区二区三区| 日韩美女综合中文字幕pp| 午夜精品九一唐人麻豆嫩草成人| 日本午夜福利免费视频| 天堂av中文在线最新版| 亚洲欧美在线视频第一页| 无忧传媒在线观看视频| 日本中文字幕一二区视频| 日韩中文字幕福利av| 亚洲黄色av网站免费播放| 宅男噜噜噜666国产| 成人24小时免费视频| 欧美亚洲中文字幕一区二区三区| 天天做天天爽夜夜做少妇| 白嫩白嫩美女极品国产在线观看| 黑人变态深video特大巨大| wwwxxx一级黄色片| 91精品国产综合久久久蜜| 在线视频这里只有精品自拍| 久久www免费人成一看片| 久久久久久久精品老熟妇| 天天插天天狠天天操| 一级a看免费观看网站| 亚洲第17页国产精品| 大鸡吧插入女阴道黄色片| 美味人妻2在线播放| 把腿张开让我插进去视频| 最新91精品视频在线 | 国产三级影院在线观看| 中文乱理伦片在线观看| 欧美精产国品一二三区| 4个黑人操素人视频网站精品91| 午夜精品一区二区三区城中村| 狠狠躁夜夜躁人人爽天天久天啪| 乱亲女秽乱长久久久| 国产麻豆91在线视频| 91福利视频免费在线观看| 亚洲无线观看国产高清在线| 直接观看免费黄网站| 日韩二区视频一线天婷婷五| av亚洲中文天堂字幕网| 色97视频在线播放| 国产在线拍揄自揄视频网站| 91色老99久久九九爱精品| 青青青青青操视频在线观看| 自拍偷拍亚洲欧美在线视频| 超级碰碰在线视频免费观看| 久久久噜噜噜久久熟女av| 男大肉棒猛烈插女免费视频| 国产精品黄页网站视频| 蜜桃臀av蜜桃臀av| 欧美亚洲免费视频观看| 粉嫩av懂色av蜜臀av| 自拍偷区二区三区麻豆| 亚洲无线观看国产高清在线| 人妻熟女中文字幕aⅴ在线| 在线观看免费视频色97| 国产亚洲视频在线观看| 18禁美女无遮挡免费| 动漫精品视频在线观看| 香蕉片在线观看av| 又粗又硬又猛又爽又黄的| 国产在线观看免费人成短视频| AV天堂一区二区免费试看| 精品国产高潮中文字幕| 中文字幕免费在线免费| 色秀欧美视频第一页| 91精品高清一区二区三区| 丝袜美腿视频诱惑亚洲无| 无码中文字幕波多野不卡| 国产va精品免费观看| 色婷婷精品大在线观看| 可以在线观看的av中文字幕| 亚洲综合自拍视频一区| 国产熟妇一区二区三区av| 丝袜肉丝一区二区三区四区在线看| 人妻丝袜榨强中文字幕| 久久久久只精品国产三级| 亚洲一区二区三区五区 | 国产一区成人在线观看视频 | 国语对白xxxx乱大交| 亚洲熟女久久久36d| 天码人妻一区二区三区在线看 | 大鸡巴后入爆操大屁股美女| aⅴ精产国品一二三产品| 中国产一级黄片免费视频播放| 免费人成黄页网站在线观看国产| 国产一线二线三线的区别在哪| av线天堂在线观看| 91欧美在线免费观看| 国产在线一区二区三区麻酥酥| 国产黄色片蝌蚪九色91| 精品黑人巨大在线一区| 97精品成人一区二区三区| 免费一级特黄特色大片在线观看| 久久久精品国产亚洲AV一 | 亚洲欧美成人综合在线观看| 新婚人妻聚会被中出| 欧美乱妇无乱码一区二区| 久青青草视频手机在线免费观看| 日本一区美女福利视频| 任你操视频免费在线观看| 人妻激情图片视频小说| 3337p日本欧洲大胆色噜噜| 这里有精品成人国产99| 一区二区三区综合视频| 天天干天天插天天谢| 成人24小时免费视频| 一区二区三区毛片国产一区| 2021天天色天天干| 涩爱综合久久五月蜜臀| 在线观看的黄色免费网站| 国产又粗又硬又大视频| 在线观看一区二区三级| 午夜精品亚洲精品五月色| 亚欧在线视频你懂的| 人妻熟女中文字幕aⅴ在线| 91在线视频在线精品3| 又黄又刺激的午夜小视频| 日韩熟女系列一区二区三区| 亚洲成人国产av在线| 可以在线观看的av中文字幕| 天天日天天干天天干天天日| 亚洲一区自拍高清免费视频| 88成人免费av网站| 日本三极片中文字幕| 国产黑丝高跟鞋视频在线播放| 亚洲国产精品久久久久久6| 视频 国产 精品 熟女 | 狠狠躁夜夜躁人人爽天天久天啪| 中文字母永久播放1区2区3区| 91人妻精品久久久久久久网站| 国产精品黄大片在线播放| 视频一区二区在线免费播放| 久久久久久久久久一区二区三区 | yellow在线播放av啊啊啊| 鸡巴操逼一级黄色气| 999九九久久久精品| 国产又大又黄免费观看| 偷拍自拍视频图片免费| 香港三日本三韩国三欧美三级| 午夜久久久久久久99| 91chinese在线视频| 免费岛国喷水视频在线观看| 国产又粗又猛又爽又黄的视频美国| 午夜激情久久不卡一区二区| 2021最新热播中文字幕| 天天艹天天干天天操| 中文字幕午夜免费福利视频| 亚洲另类在线免费观看| 男人的天堂在线黄色| 日本免费一级黄色录像| 99的爱精品免费视频| 亚洲成高清a人片在线观看| 在线国产日韩欧美视频| 视频一区二区综合精品| 天堂av在线官网中文| 亚洲av在线观看尤物| 精品久久久久久高潮| 亚洲av极品精品在线观看| 中文字幕中文字幕 亚洲国产| 亚洲欧美另类自拍偷拍色图| 中国把吊插入阴蒂的视频| 美女av色播在线播放| 亚洲av自拍天堂网| 亚洲综合一区成人在线| 午夜久久久久久久精品熟女| 免费十精品十国产网站| 久久久噜噜噜久久熟女av| 欧美成人猛片aaaaaaa| 夏目彩春在线中文字幕| 99国内精品永久免费视频| 97超碰人人搞人人| 欧美爆乳肉感大码在线观看 | 超碰97免费人妻麻豆| heyzo蜜桃熟女人妻| 亚洲欧美清纯唯美另类| 人妻少妇av在线观看| 亚洲午夜伦理视频在线| 摧残蹂躏av一二三区| 操人妻嗷嗷叫视频一区二区| 韩国AV无码不卡在线播放| 欧美一区二区三区激情啪啪啪 | 超pen在线观看视频公开97| 日本av熟女在线视频| 天天躁夜夜躁日日躁a麻豆| 青青热久免费精品视频在线观看| 国产精品日韩欧美一区二区| 一区二区三区毛片国产一区| 天天艹天天干天天操| 成人在线欧美日韩国产| 国产+亚洲+欧美+另类| 亚洲精品在线资源站| av在线免费中文字幕| 免费在线观看污污视频网站| 18禁精品网站久久| 99热色原网这里只有精品| 国产免费高清视频视频| 大鸡巴后入爆操大屁股美女| 国产变态另类在线观看| 日噜噜噜夜夜噜噜噜天天噜噜噜| 精品区一区二区三区四区人妻| 偷拍自拍福利视频在线观看| 大屁股熟女一区二区三区| 天天操天天干天天艹| 摧残蹂躏av一二三区| 日本成人一区二区不卡免费在线| 在线视频国产欧美日韩| 直接观看免费黄网站| av黄色成人在线观看| 精品欧美一区二区vr在线观看| xxx日本hd高清| 国产污污污污网站在线| 欧美一区二区三区激情啪啪啪| 国产+亚洲+欧美+另类| 91久久人澡人人添人人爽乱| 中文字幕日韩精品就在这里| 日韩亚洲高清在线观看| 久久久噜噜噜久久熟女av| 欧洲日韩亚洲一区二区三区 | 2021最新热播中文字幕| 日本后入视频在线观看| 天天干狠狠干天天操| 日韩在线视频观看有码在线| 1769国产精品视频免费观看| 亚洲av午夜免费观看| 国产精品探花熟女在线观看| 久久久久只精品国产三级| 护士特殊服务久久久久久久| 国产欧美日韩在线观看不卡| 一区二区三区久久久91| 日韩中文字幕在线播放第二页| 亚洲免费福利一区二区三区| 亚洲精品无码久久久久不卡| 大屁股肉感人妻中文字幕在线| 亚洲一级 片内射视正片| 日韩国产乱码中文字幕| 丝袜肉丝一区二区三区四区在线看| 国产之丝袜脚在线一区二区三区| 自拍偷拍一区二区三区图片| 天天摸天天亲天天舔天天操天天爽| 中文字幕AV在线免费看 | 唐人色亚洲av嫩草| 日本熟女精品一区二区三区| 欧美亚洲国产成人免费在线| 国产黄色片在线收看| asmr福利视频在线观看| 日本www中文字幕| 久久99久久99精品影院| 青青青青视频在线播放| 98视频精品在线观看| 成年人该看的视频黄免费| 青青草视频手机免费在线观看| 国产免费高清视频视频| 欧美成人综合视频一区二区| 91免费放福利在线观看| 熟女人妻在线中出观看完整版| 久久精品亚洲国产av香蕉| 免费观看理论片完整版| 91欧美在线免费观看| 一区二区三区 自拍偷拍| www日韩毛片av| 偷青青国产精品青青在线观看 | 成人亚洲精品国产精品| 午夜精品亚洲精品五月色| 久久久久久久一区二区三| 欧美在线一二三视频| 久久久久久久精品成人热| 成人精品在线观看视频| 欧美亚洲少妇福利视频| 亚洲成人熟妇一区二区三区| 2018最新中文字幕在线观看| 天干天天天色天天日天天射| 国产黑丝高跟鞋视频在线播放| 欧美精产国品一二三区| 男人插女人视频网站| 欧美区一区二区三视频| 欧美精品亚洲精品日韩在线| 天天摸天天干天天操科普| 亚洲午夜电影之麻豆| 婷婷久久一区二区字幕网址你懂得| 免费成人va在线观看| 人妻少妇av在线观看| 大香蕉伊人国产在线| 老熟妇xxxhd老熟女| 夜夜嗨av一区二区三区中文字幕| 女蜜桃臀紧身瑜伽裤| 天天操,天天干,天天射| 久草视频在线看免费| 91久久国产成人免费网站| 丰满的子国产在线观看| 亚洲欧美人精品高清| av在线shipin| 国产成人精品一区在线观看| 2018最新中文字幕在线观看| 2020av天堂网在线观看| 在线制服丝袜中文字幕| 亚洲一区二区三区在线高清| 99热99re在线播放| 最新的中文字幕 亚洲| 午夜精品亚洲精品五月色| 国产97视频在线精品| 天天操,天天干,天天射| 色婷婷综合激情五月免费观看 | 天天操天天干天天日狠狠插| 91精品国产91青青碰| 在线国产中文字幕视频| 男人插女人视频网站| 99热碰碰热精品a中文| 亚洲乱码中文字幕在线| 亚洲免费av在线视频| 一个人免费在线观看ww视频| 大鸡八强奸视频在线观看| 极品粉嫩小泬白浆20p主播| 大香蕉大香蕉在线看| 日本在线一区二区不卡视频| 欧美乱妇无乱码一区二区| 日韩av中文在线免费观看 | 99久久成人日韩欧美精品| 欧洲精品第一页欧洲精品亚洲| 午夜激情久久不卡一区二区| 色综合久久久久久久久中文| 免费高清自慰一区二区三区网站| 扒开腿挺进肉嫩小18禁视频| 日韩激情文学在线视频| 中文字幕之无码色多多| 亚洲综合另类欧美久久| 嫩草aⅴ一区二区三区| 中文字幕av熟女人妻| 国产精品视频男人的天堂| 福利在线视频网址导航| 亚洲欧美福利在线观看| 91精品国产黑色丝袜| 新婚人妻聚会被中出| 91人妻精品一区二区在线看| 日韩写真福利视频在线观看| 婷婷久久久综合中文字幕| 老鸭窝在线观看一区| 五十路在线观看完整版| 中文字幕人妻被公上司喝醉在线| 亚洲成人线上免费视频观看| 特黄老太婆aa毛毛片| 91精品国产91久久自产久强| 久久久噜噜噜久久熟女av| 好了av中文字幕在线| 天天干天天插天天谢| 高清成人av一区三区| 成人精品视频99第一页| 国产亚洲国产av网站在线| 免费一级特黄特色大片在线观看| 色伦色伦777国产精品| 天堂中文字幕翔田av| 国产成人一区二区三区电影网站| 18禁污污污app下载| jul—619中文字幕在线| 77久久久久国产精产品| 中国熟女@视频91| 日本黄在免费看视频| 最新国产精品网址在线观看| 亚洲av日韩精品久久久| 18禁美女羞羞免费网站| 亚洲av日韩av第一区二区三区| 91精品啪在线免费| 免费在线观看污污视频网站| 亚洲国产第一页在线观看| 国产精品自拍视频大全| 和邻居少妇愉情中文字幕| 好吊操视频这里只有精品| 1区2区3区4区视频在线观看| 亚洲一区av中文字幕在线观看| www久久久久久久久久久| 午夜在线精品偷拍一区二| 欧美精品资源在线观看| 啪啪啪啪啪啪啪免费视频| 亚洲 色图 偷拍 欧美| 亚洲自拍偷拍综合色| 老有所依在线观看完整版| 天天日天天干天天插舔舔| 国产av一区2区3区| 精品国产成人亚洲午夜| 日本啪啪啪啪啪啪啪| 18禁免费av网站| 2025年人妻中文字幕乱码在线| 男人的天堂av日韩亚洲| 久久永久免费精品人妻专区| 日本脱亚入欧是指什么| 91福利视频免费在线观看| av日韩在线免费播放| 国产精品手机在线看片| 日本三极片视频网站观看| 人人妻人人人操人人人爽| 少妇高潮无套内谢麻豆| 亚洲av成人免费网站| 自拍 日韩 欧美激情| 人妻久久久精品69系列| 亚洲一区自拍高清免费视频| 又粗又长 明星操逼小视频| 综合国产成人在线观看| 亚洲福利精品福利精品福利| 日本在线不卡免费视频| 日本午夜福利免费视频| 亚洲福利精品视频在线免费观看| 88成人免费av网站| 国产1区,2区,3区| 香蕉aⅴ一区二区三区| 欧美国品一二三产区区别| 啊慢点鸡巴太大了啊舒服视频| 搞黄色在线免费观看| 大陆胖女人与丈夫操b国语高清| 日本黄色三级高清视频| 福利视频一区二区三区筱慧| 亚洲综合另类精品小说| 国产va精品免费观看| 亚洲乱码中文字幕在线| av高潮迭起在线观看| 又色又爽又黄的美女裸体| 老有所依在线观看完整版 | 99久久中文字幕一本人| 香港三日本三韩国三欧美三级| 亚洲区欧美区另类最新章节| 最新97国产在线视频| 亚洲成人精品女人久久久| 一级黄色片夫妻性生活| 国际av大片在线免费观看| 亚洲一级 片内射视正片| 亚洲一区二区三区久久午夜| 国产91久久精品一区二区字幕| 欧美怡红院视频在线观看| 91精品免费久久久久久| 亚洲人一区二区中文字幕| 国产伊人免费在线播放| 国产chinesehd精品麻豆| 国产视频网站一区二区三区| 中文字幕国产专区欧美激情| 免费国产性生活视频| 成人色综合中文字幕| 亚洲天堂av最新网址| 国产精品手机在线看片| 国产精品一区二区三区蜜臀av| 爆乳骚货内射骚货内射在线| 性感美女诱惑福利视频| 888亚洲欧美国产va在线播放| 国产午夜男女爽爽爽爽爽视频 | 91麻豆精品久久久久| 91九色porny国产在线| 少妇ww搡性bbb91| 日韩少妇人妻精品无码专区| 国产亚洲视频在线二区| 男人的网址你懂的亚洲欧洲av| 一区二区免费高清黄色视频| 中文字幕av第1页中文字幕| 最新日韩av传媒在线| 日韩美av高清在线| 3344免费偷拍视频| 国产高潮无码喷水AV片在线观看| 97国产在线av精品| 日视频免费在线观看| 抽查舔水白紧大视频| 日日操夜夜撸天天干| 精品久久久久久久久久久99| 午夜国产免费福利av| 亚洲熟妇x久久av久久| 久久农村老妇乱69系列| 新97超碰在线观看| 久久丁香婷婷六月天| 中文字幕成人日韩欧美| 操操网操操伊剧情片中文字幕网| 中文字幕+中文字幕| 亚洲伊人av天堂有码在线| 91大屁股国产一区二区| av高潮迭起在线观看| 日韩亚国产欧美三级涩爱| 日本在线一区二区不卡视频| 无码日韩人妻精品久久| 日本一二三区不卡无| 熟女在线视频一区二区三区| 亚洲变态另类色图天堂网| 大屁股肉感人妻中文字幕在线| 国产精品久久久久国产三级试频| 黄色成年网站午夜在线观看| 精品一区二区三区午夜| 热久久只有这里有精品| 亚洲一区二区激情在线| 521精品视频在线观看| 亚洲伊人久久精品影院一美女洗澡 | 国产一区二区视频观看| 日本美女性生活一级片| 日本性感美女三级视频| 99热这里只有精品中文| 91九色国产porny蝌蚪| 一区二区三区四区视频在线播放| 女警官打开双腿沦为性奴| 在线观看av亚洲情色| 啪啪啪啪啪啪啪啪啪啪黄色| 亚洲超碰97人人做人人爱| 天天操天天干天天插| 国产综合高清在线观看| 久久久久久国产精品| 欧美视频综合第一页| 91小伙伴中女熟女高潮| 国产性感美女福利视频| 91大神福利视频网| 亚洲无码一区在线影院| 亚洲图库另类图片区| 日视频免费在线观看| av乱码一区二区三区| 九一传媒制片厂视频在线免费观看| 一区二区三区四区五区性感视频 | 水蜜桃国产一区二区三区| 一区二区三区久久久91| 成人亚洲国产综合精品| 乱亲女秽乱长久久久| 99久久99一区二区三区| 白嫩白嫩美女极品国产在线观看| 亚洲福利午夜久久久精品电影网| 亚洲 中文 自拍 无码| 91精品激情五月婷婷在线| 一区二区在线观看少妇| 欧美成人综合视频一区二区| 亚洲欧美成人综合在线观看| 青青草原网站在线观看| 欧美亚洲自偷自拍 在线| 亚洲成人三级在线播放| 欧美男同性恋69视频| 人妻丝袜诱惑我操她视频| 97资源人妻免费在线视频| 97人妻色免费视频| 久久综合老鸭窝色综合久久| 北条麻妃av在线免费观看| 青青青青爽手机在线| 男人天堂最新地址av| 黄色片年轻人在线观看| 在线不卡成人黄色精品| 国产视频一区在线观看| 成年人黄色片免费网站| 女同久久精品秋霞网| 日韩av免费观看一区| 97人人模人人爽人人喊| 青青青青草手机在线视频免费看| 欧美男同性恋69视频| 92福利视频午夜1000看| 国产日韩欧美视频在线导航| 亚洲午夜精品小视频| 97国产在线av精品| 黄色成人在线中文字幕| 欧美乱妇无乱码一区二区| 人妻少妇av在线观看| 在线观看av2025| 日韩av有码一区二区三区4 | 亚洲精品福利网站图片| 日韩美女精品视频在线观看网站| 丝袜肉丝一区二区三区四区在线 | 青青青青青青青青青国产精品视频| 沈阳熟妇28厘米大战黑人| 午夜激情精品福利视频| 日韩欧美国产一区ab| 欧美aa一级一区三区四区| 欧美亚洲一二三区蜜臀| 亚洲变态另类色图天堂网| 日曰摸日日碰夜夜爽歪歪| 日韩精品中文字幕播放| 蜜桃精品久久久一区二区| 天天日天天天天天天天天天天| 国产欧美日韩第三页| 超碰97免费人妻麻豆| 男女啪啪视频免费在线观看| 绯色av蜜臀vs少妇| 亚洲欧美久久久久久久久| 日本黄在免费看视频| 懂色av蜜桃a v| 91久久精品色伊人6882| 超碰97人人澡人人| 亚洲va天堂va国产va久| 粉嫩av蜜乳av蜜臀| 国产成人精品久久二区91| 欧美色呦呦最新网址| 91自产国产精品视频| 久久精品视频一区二区三区四区| 日美女屁股黄邑视频| 日韩黄色片在线观看网站| 欧洲国产成人精品91铁牛tv| 亚洲美女自偷自拍11页| 韩国男女黄色在线观看| 精品国产乱码一区二区三区乱| 亚洲精品国偷自产在线观看蜜桃| 日本福利午夜电影在线观看| 男生舔女生逼逼的视频| 中文字幕1卡1区2区3区| 亚洲老熟妇日本老妇| 少妇人妻100系列| 国产精品人妻熟女毛片av久| 成人综合亚洲欧美一区| av在线免费资源站| 亚洲老熟妇日本老妇| 青青草原色片网站在线观看| 欧美日韩一区二区电影在线观看| 人妻少妇av在线观看| 成年美女黄网站18禁久久| 水蜜桃一区二区三区在线观看视频 | 在线观看欧美黄片一区二区三区 | 99精品免费观看视频| 水蜜桃一区二区三区在线观看视频 | 2018在线福利视频| 欧美成人一二三在线网| 91色网站免费在线观看| 亚洲欧洲av天堂综合| 中文字幕在线第一页成人| 国产福利在线视频一区| 成人蜜臀午夜久久一区| 天天色天天爱天天爽| 在线制服丝袜中文字幕| 青草久久视频在线观看| 亚洲av第国产精品| 人妻少妇av在线观看| 亚洲一区制服丝袜美腿| 天堂av中文在线最新版| 中文字幕熟女人妻久久久| 五十路息与子猛烈交尾视频 | 精品少妇一二三视频在线| av久久精品北条麻妃av观看| 性色蜜臀av一区二区三区| 色哟哟国产精品入口| 青青青青青操视频在线观看| 91自产国产精品视频| 38av一区二区三区| 亚洲国产香蕉视频在线播放| 天美传媒mv视频在线观看| 国内资源最丰富的网站| 中出中文字幕在线观看| 午夜大尺度无码福利视频 | 国产普通话插插视频| 一级黄片大鸡巴插入美女 | 亚洲国产精品黑丝美女| 人妻在线精品录音叫床| 人妻少妇中文有码精品| 成人av久久精品一区二区| 欧美日韩情色在线观看| 午夜福利人人妻人人澡人人爽| 黑人3p华裔熟女普通话| 粉嫩欧美美人妻小视频| 婷婷五月亚洲综合在线| 美女张开两腿让男人桶av| 国产亚洲成人免费在线观看| 综合精品久久久久97| 制服丝袜在线人妻中文字幕| 青青青视频自偷自拍38碰| 中文字幕人妻一区二区视频 | 日韩一区二区电国产精品| 女生被男生插的视频网站| 亚洲av色香蕉一区二区三区| 在线网站你懂得老司机| 天天想要天天操天天干| 久久综合老鸭窝色综合久久| 欧美黑人性猛交xxxxⅹooo| av俺也去在线播放| 91超碰青青中文字幕| 9国产精品久久久久老师| 成人久久精品一区二区三区| 黑人3p华裔熟女普通话| 亚洲精品久久视频婷婷| av日韩在线观看大全| 国产又色又刺激在线视频| 天天躁日日躁狠狠躁躁欧美av| 久久99久久99精品影院| 中文字幕+中文字幕| 精品久久久久久久久久久久人妻 | 91av中文视频在线| 国产成人自拍视频在线免费观看| 国产精品视频欧美一区二区| 狍和女人的王色毛片| chinese国产盗摄一区二区| 免费看国产av网站| 大屁股肉感人妻中文字幕在线| 亚洲一区二区三区久久午夜| 亚洲av日韩精品久久久久久hd| 91精品免费久久久久久| 操人妻嗷嗷叫视频一区二区| 色狠狠av线不卡香蕉一区二区| 免费啪啪啪在线观看视频| 亚洲第一黄色在线观看| 免费在线观看污污视频网站| 午夜久久香蕉电影网| 免费成人va在线观看| 超碰公开大香蕉97| 中文字幕最新久久久| 2020韩国午夜女主播在线| 精品av国产一区二区三区四区| 亚洲超碰97人人做人人爱| 欧美交性又色又爽又黄麻豆| 11久久久久久久久久久| a v欧美一区=区三区| 大香蕉玖玖一区2区| 一色桃子人妻一区二区三区| 中文亚洲欧美日韩无线码| 日韩欧美一级黄片亚洲| 老司机免费福利视频网| 欧美日韩国产一区二区三区三州| 啪啪啪啪啪啪啪啪av| 91色老99久久九九爱精品| 欧美女同性恋免费a| 三级av中文字幕在线观看| 天天操天天污天天射| 精品区一区二区三区四区人妻| 亚洲 欧美 自拍 偷拍 在线| 国产一区二区在线欧美| 精品一区二区三区三区色爱| 黄色大片男人操女人逼| 66久久久久久久久久久| 93精品视频在线观看| 1024久久国产精品| 大陆胖女人与丈夫操b国语高清| 亚洲卡1卡2卡三卡四老狼| 护士特殊服务久久久久久久| 亚洲欧美人精品高清| av新中文天堂在线网址| 午夜美女福利小视频| 亚洲精品国产久久久久久| 欧美成人精品欧美一级黄色| 大鸡巴操b视频在线| 国产性生活中老年人视频网站| 青青青青青操视频在线观看| 日韩人妻丝袜中文字幕| 亚洲1卡2卡三卡4卡在线观看| 成人资源在线观看免费官网| 黄色片黄色片wyaa| 国产精品一二三不卡带免费视频| 日韩午夜福利精品试看| 国产性生活中老年人视频网站| 欧美亚洲偷拍自拍色图| 视频一区 二区 三区 综合| 欧美日韩熟女一区二区三区| 精品美女久久久久久| 国产一级麻豆精品免费| 在线视频精品你懂的| 2o22av在线视频| 久久久久久97三级| 大陆av手机在线观看| 国产精品福利小视频a| 欧美一区二区三区久久久aaa| 国产刺激激情美女网站| 91亚洲国产成人精品性色| 亚洲欧美激情人妻偷拍| 91桃色成人网络在线观看| 2o22av在线视频| 少妇ww搡性bbb91| 18禁美女无遮挡免费| 动色av一区二区三区| 亚洲护士一区二区三区| 青娱乐最新视频在线| 日本最新一二三区不卡在线 | 国产黄色片蝌蚪九色91| 久精品人妻一区二区三区 | 美女骚逼日出水来了| 91久久综合男人天堂| 国产又色又刺激在线视频| 社区自拍揄拍尻屁你懂的| 亚洲第一伊人天堂网| 精产国品久久一二三产区区别| 精品黑人巨大在线一区| 国产真实乱子伦a视频| 成人激情文学网人妻| 国产一区二区火爆视频| 888欧美视频在线| 男人和女人激情视频| 亚洲一区二区三区在线高清 | 国产精品女邻居小骚货| 国产精品视频一区在线播放| 国产日本精品久久久久久久| 最新欧美一二三视频| 国产精选一区在线播放| 亚洲精品精品国产综合| 中文字幕AV在线免费看 | 国产精品熟女久久久久浪潮| 久久久麻豆精亚洲av麻花| 2022中文字幕在线| 2017亚洲男人天堂| 男人的网址你懂的亚洲欧洲av| 又大又湿又爽又紧A视频| 精品91自产拍在线观看一区| 巨乳人妻日下部加奈被邻居中出| 成人国产影院在线观看| 日韩av免费观看一区| 亚洲一区二区三区精品视频在线| 337p日本大胆欧美人| 国产黄色片蝌蚪九色91| 欧美日本在线观看一区二区| 99国内小视频在现欢看| 午夜av一区二区三区| 日韩三级电影华丽的外出| 亚洲精品精品国产综合| 晚上一个人看操B片| 成人影片高清在线观看| 日本免费午夜视频网站| 亚洲国际青青操综合网站| 2022精品久久久久久中文字幕| 91精品一区二区三区站长推荐| 中文字幕午夜免费福利视频| 国产精彩福利精品视频| 久久久久久久亚洲午夜综合福利| 天天色天天爱天天爽| 日韩av大胆在线观看| 亚洲精品 欧美日韩| 2020国产在线不卡视频| 小泽玛利亚视频在线观看| 国产真实乱子伦a视频| 晚上一个人看操B片| 春色激情网欧美成人| 国产精品视频男人的天堂| 人人妻人人澡欧美91精品| 天天射夜夜操综合网| 青娱乐极品视频青青草| 91chinese在线视频| 在线观看的黄色免费网站| 天天做天天干天天舔| 91人妻精品久久久久久久网站 | 三级等保密码要求条款| gogo国模私拍视频| 黄片三级三级三级在线观看| 国产女人被做到高潮免费视频| 91精品国产麻豆国产| 亚洲粉嫩av一区二区三区| 欧美亚洲偷拍自拍色图| 91九色porny蝌蚪国产成人| 亚洲av成人免费网站| 同居了嫂子在线播高清中文| 亚洲成人国产综合一区| 风流唐伯虎电视剧在线观看| 日曰摸日日碰夜夜爽歪歪| 免费福利av在线一区二区三区| 中文字幕最新久久久| 国产欧美精品不卡在线| 天堂av中文在线最新版| 最新国产亚洲精品中文在线| 99re久久这里都是精品视频| 亚洲欧美色一区二区| 97年大学生大白天操逼| 国产熟妇一区二区三区av| 欧美精品资源在线观看| av俺也去在线播放| 在线观看日韩激情视频| 天天想要天天操天天干| 日本性感美女写真视频| 婷婷六月天中文字幕| 国产精品一区二区久久久av| 人妻激情图片视频小说| 唐人色亚洲av嫩草| 亚洲区欧美区另类最新章节| 护士小嫩嫩又紧又爽20p| 99热久久极品热亚洲| 93人妻人人揉人人澡人人| 性生活第二下硬不起来| 亚洲精品在线资源站| av大全在线播放免费| 欧美一区二区三区久久久aaa| av在线观看网址av| 亚洲国产精品免费在线观看| 狠狠嗨日韩综合久久| 亚洲国产精品黑丝美女| ka0ri在线视频| 66久久久久久久久久久| 大香蕉伊人国产在线| 国产成人精品福利短视频| 经典亚洲伊人第一页| 2022天天干天天操| 后入美女人妻高清在线| 午夜在线观看岛国av,com| 福利午夜视频在线观看| 大香蕉伊人国产在线| 无码精品一区二区三区人| 女同性ⅹxx女同hd| 沈阳熟妇28厘米大战黑人| 免费十精品十国产网站| 大香蕉伊人中文字幕| 五十路熟女人妻一区二区9933| 福利片区一区二体验区| av在线资源中文字幕| 喷水视频在线观看这里只有精品| 亚洲精品高清自拍av| 蜜桃臀av蜜桃臀av| 青青青青草手机在线视频免费看| 日本一区二区三区免费小视频| 日本高清撒尿pissing| 3337p日本欧洲大胆色噜噜| 日本少妇人妻xxxxxhd| 日本乱人一区二区三区| 熟女俱乐部一二三区| 五月天中文字幕内射| 国产精品3p和黑人大战| 免费观看国产综合视频| 人妻3p真实偷拍一二区| 91精品啪在线免费| 老司机99精品视频在线观看| 男人的天堂一区二区在线观看| 日本熟女50视频免费| 不卡一不卡二不卡三| 中文字幕AV在线免费看 | 日本真人性生活视频免费看| 国产一级精品综合av| 2019av在线视频| 91色老99久久九九爱精品| 国产日韩一区二区在线看| 黄色av网站免费在线| 嫩草aⅴ一区二区三区| 91亚洲国产成人精品性色| 成人动漫大肉棒插进去视频| 国产成人一区二区三区电影网站| 亚洲av色图18p| 欧美一级色视频美日韩| 成人av免费不卡在线观看| 99精品视频之69精品视频| 亚洲 色图 偷拍 欧美| 久草电影免费在线观看| 亚洲成人黄色一区二区三区| 欧美精品一二三视频| 91超碰青青中文字幕| 欧美日韩国产一区二区三区三州| 小泽玛利亚视频在线观看| 国内资源最丰富的网站| 国产精品日韩欧美一区二区| 丁香花免费在线观看中文字幕| 天天干狠狠干天天操 | 97色视频在线观看| 男人在床上插女人视频| 中文字幕日本人妻中出| 午夜精品一区二区三区城中村| 亚洲av第国产精品| 美女日逼视频免费观看| 国产精品入口麻豆啊啊啊| 欧美成人精品欧美一级黄色| 大陆胖女人与丈夫操b国语高清| 日韩写真福利视频在线观看| av成人在线观看一区| 国产av一区2区3区| av日韩在线免费播放| 天天操天天操天天碰| 一区二区在线视频中文字幕 | 少妇深喉口爆吞精韩国| 日韩中文字幕在线播放第二页| 久久精品国产999| 亚洲午夜高清在线观看| 国产精品黄片免费在线观看| 日日夜夜大香蕉伊人| 国产精品熟女久久久久浪潮| 国产自拍在线观看成人| 动漫av网站18禁| 经典国语激情内射视频| 91精品国产高清自在线看香蕉网| 青娱乐最新视频在线| 黄色视频在线观看高清无码| 欲满人妻中文字幕在线| 亚洲中文精品字幕在线观看| 精品少妇一二三视频在线| 在线免费观看日本片| 中国黄片视频一区91| 2012中文字幕在线高清| 日本一区二区三区免费小视频| 亚洲老熟妇日本老妇| 国产+亚洲+欧美+另类| 国产又色又刺激在线视频 | 91p0rny九色露脸熟女| 特级无码毛片免费视频播放| 久久久久久久久久久久久97| 日韩欧美亚洲熟女人妻| 国产伦精品一区二区三区竹菊| 在线观看911精品国产| 欧美国品一二三产区区别| 亚洲高清一区二区三区视频在线| 一个人免费在线观看ww视频| 又黄又刺激的午夜小视频| 日本韩国亚洲综合日韩欧美国产| 久久精品36亚洲精品束缚| 欧洲黄页网免费观看| 亚洲男人在线天堂网| 国产卡一卡二卡三乱码手机| 最新91九色国产在线观看| 在线国产精品一区二区三区| 97精品综合久久在线| 在线观看欧美黄片一区二区三区| 3D动漫精品啪啪一区二区下载| 白白操白白色在线免费视频| 免费在线看的黄网站| 天天操夜夜骑日日摸| 粉嫩av蜜乳av蜜臀| 爱爱免费在线观看视频| 四虎永久在线精品免费区二区 | 可以免费看的www视频你懂的| 青青尤物在线观看视频网站| 亚洲成人av一区久久| 男人的网址你懂的亚洲欧洲av| 亚洲美女美妇久久字幕组| 精品亚洲在线免费观看| 五色婷婷综合狠狠爱| 精品久久久久久久久久中文蒉| tube69日本少妇| 久久热久久视频在线观看| 青青在线视频性感少妇和隔壁黑丝 | 免费看高清av的网站| 亚洲码av无色中文| 另类av十亚洲av| 成年人黄色片免费网站| 热99re69精品8在线播放| 亚洲图片欧美校园春色| 九色视频在线观看免费| 亚洲国际青青操综合网站| 动漫黑丝美女的鸡巴| 婷婷综合亚洲爱久久| 天天综合天天综合天天网 | 国产真实灌醉下药美女av福利| aaa久久久久久久久| 超黄超污网站在线观看| 免费无毒热热热热热热久| 丰满少妇翘臀后进式| 福利视频一区二区三区筱慧| 日视频免费在线观看| 亚洲精品福利网站图片| 岛国黄色大片在线观看| 日本午夜福利免费视频| 一区二区三区久久中文字幕| 啊啊好慢点插舔我逼啊啊啊视频| 亚欧在线视频你懂的| 美味人妻2在线播放| 五十路av熟女松本翔子| 九一传媒制片厂视频在线免费观看| 不卡精品视频在线观看| 888亚洲欧美国产va在线播放| 国产视频网站一区二区三区| 开心 色 六月 婷婷| 大鸡巴后入爆操大屁股美女| 国产janese在线播放| 日韩a级黄色小视频| 亚洲va国产va欧美va在线| 日韩av有码一区二区三区4| 亚洲欧美另类自拍偷拍色图| 亚洲男人在线天堂网| 亚洲另类在线免费观看| 亚洲最大黄 嗯色 操 啊| 偷拍自拍亚洲美腿丝袜| 黄色大片免费观看网站| 在线免费观看黄页视频| 日本免费视频午夜福利视频| 成人影片高清在线观看| 欧美精产国品一二三产品价格| 人妻丝袜精品中文字幕| 黑人进入丰满少妇视频| 人人妻人人爱人人草| 亚洲国产40页第21页| 色吉吉影音天天干天天操| 欧亚日韩一区二区三区观看视频| av视网站在线观看| 亚洲国际青青操综合网站| 漂亮 人妻被中出中文| 99国产精品窥熟女精品| 欧美国产亚洲中英文字幕| 老司机在线精品福利视频| 青青青青青免费视频| 老司机99精品视频在线观看| 黄页网视频在线免费观看| 女警官打开双腿沦为性奴| 成人18禁网站在线播放| 日本脱亚入欧是指什么| 国产精品一区二区三区蜜臀av | 欧美亚洲牲夜夜综合久久| 国产美女一区在线观看| 午夜成午夜成年片在线观看| 97超碰国语国产97超碰| 午夜久久久久久久精品熟女| 99精品亚洲av无码国产另类 | 色偷偷伊人大杳蕉综合网| 欧美在线一二三视频| 亚洲一区二区三区精品视频在线| 日韩亚洲高清在线观看| 日韩亚国产欧美三级涩爱| 日本熟女精品一区二区三区| 男人的天堂在线黄色| 成人sm视频在线观看| 亚洲2021av天堂| 蜜臀成人av在线播放| 国产综合视频在线看片| 国产又粗又黄又硬又爽| 午夜毛片不卡免费观看视频 | 99久久超碰人妻国产| 在线观看免费视频色97| 欧美怡红院视频在线观看| 日日操夜夜撸天天干| 特一级特级黄色网片| 人人人妻人人澡人人| 99热久久这里只有精品| 手机看片福利盒子日韩在线播放| 国产日韩精品免费在线| 99久久中文字幕一本人| 777奇米久久精品一区| 青青在线视频性感少妇和隔壁黑丝| 2021国产一区二区| 午夜在线观看岛国av,com| eeuss鲁片一区二区三区| 天天干天天爱天天色| 亚洲 国产 成人 在线| 日韩a级精品一区二区| 亚洲欧美激情中文字幕| 一区二区三区四区视频在线播放 | 亚洲丝袜老师诱惑在线观看| av高潮迭起在线观看| 欧美视频中文一区二区三区| 和邻居少妇愉情中文字幕| 日韩近亲视频在线观看| 日日操综合成人av| 亚洲另类综合一区小说| 日本性感美女三级视频| 一区二区三区久久久91| www日韩毛片av| 十八禁在线观看地址免费| 午夜精品一区二区三区城中村| 中文字幕高清在线免费播放 | 亚洲1069综合男同| 麻豆性色视频在线观看| 国产性生活中老年人视频网站| 亚洲图片偷拍自拍区| japanese日本熟妇另类| nagger可以指黑人吗| 久草视频首页在线观看| 在线观看视频 你懂的| 男人的天堂一区二区在线观看| 91天堂天天日天天操| 宅男噜噜噜666国产| 19一区二区三区在线播放| 青草亚洲视频在线观看| 干逼又爽又黄又免费的视频| 又粗又硬又猛又爽又黄的| 亚洲成a人片777777| 在线观看av亚洲情色| 91欧美在线免费观看| 亚洲熟色妇av日韩熟色妇在线| 国产视频一区在线观看| 99人妻视频免费在线| 国产福利小视频二区| 一级黄片大鸡巴插入美女| 青青青艹视频在线观看| 黄色视频成年人免费观看| 乱亲女秽乱长久久久| 亚洲美女美妇久久字幕组| 亚洲欧美色一区二区| 北条麻妃av在线免费观看| 日本裸体熟妇区二区欧美| 成人动漫大肉棒插进去视频| 青青草成人福利电影| 岛国免费大片在线观看| 99热久久极品热亚洲| av中文字幕电影在线看| 黄工厂精品视频在线观看 | 大鸡巴操娇小玲珑的女孩逼| 性欧美日本大妈母与子| 亚洲精品亚洲人成在线导航| 日韩三级电影华丽的外出| 97小视频人妻一区二区| 亚洲日产av一区二区在线 | 亚洲第17页国产精品| 熟女人妻一区二区精品视频| 人妻少妇亚洲一区二区| 啪啪啪啪啪啪啪免费视频| 亚洲av日韩av第一区二区三区| 视频 一区二区在线观看| 日韩av有码一区二区三区4| 91香蕉成人app下载| av在线观看网址av| 真实国产乱子伦一区二区| 黄色成人在线中文字幕| 激情国产小视频在线| 人人人妻人人澡人人| 国产黄色a级三级三级三级| av网址国产在线观看| 国产美女午夜福利久久| 免费在线看的黄片视频| 天天干天天搞天天摸| 大黑人性xxxxbbbb| 成人av免费不卡在线观看| 加勒比视频在线免费观看| 婷婷综合蜜桃av在线| xxx日本hd高清| 亚洲欧美国产麻豆综合| 成人午夜电影在线观看 久久| 国产黑丝高跟鞋视频在线播放| 亚洲av香蕉一区区二区三区犇| 熟女少妇激情五十路| 中文字幕一区的人妻欧美日韩| 日本一二三区不卡无| 青青青视频手机在线观看| 国产va在线观看精品| 久久热久久视频在线观看| 成人亚洲国产综合精品| 青青草国内在线视频精选| 91老师蜜桃臀大屁股| 888欧美视频在线| 在线国产中文字幕视频| 欧美80老妇人性视频| 亚洲日产av一区二区在线| 亚洲中文字幕乱码区| 午夜场射精嗯嗯啊啊视频| 久久麻豆亚洲精品av| 男生舔女生逼逼的视频| 无套猛戳丰满少妇人妻| 啪啪啪啪啪啪啪免费视频| 成人国产小视频在线观看| 天堂资源网av中文字幕| 91免费放福利在线观看| 风流唐伯虎电视剧在线观看| 在线观看欧美黄片一区二区三区| 国产内射中出在线观看| 国产chinesehd精品麻豆| 噜噜色噜噜噜久色超碰| 久久一区二区三区人妻欧美| 欲乱人妻少妇在线视频裸| 91国内精品自线在拍白富美| 精品亚洲在线免费观看| 国产欧美精品一区二区高清 | 视频一区二区三区高清在线| 欧亚乱色一区二区三区| 成人综合亚洲欧美一区| 人人人妻人人澡人人| 精品人妻伦一二三区久| 久草福利电影在线观看| 人妻av无码专区久久绿巨人| 亚洲免费在线视频网站| 亚洲人人妻一区二区三区| 高清一区二区欧美系列| 日韩精品啪啪视频一道免费| 中文字幕日韩91人妻在线| 免费看美女脱光衣服的视频| 狠狠躁夜夜躁人人爽天天天天97| 超碰97人人做人人爱| 午夜激情久久不卡一区二区 | 丰满的子国产在线观看| 欧美视频中文一区二区三区| av中文字幕在线观看第三页| 久草视频福利在线首页| 特级欧美插插插插插bbbbb| 毛片av在线免费看| 欧美viboss性丰满| 老司机免费福利视频网| 一区国内二区日韩三区欧美| 天天日天天舔天天射进去| 一区二区久久成人网| 色97视频在线播放| 在线免费观看日本伦理| 天天射夜夜操狠狠干| 国产真实乱子伦a视频| 超级av免费观看一区二区三区| 人人超碰国字幕观看97| 亚洲图库另类图片区| 久久这里只有精品热视频| 欧美精产国品一二三产品区别大吗| 免费大片在线观看视频网站| 天天艹天天干天天操| 天天躁夜夜躁日日躁a麻豆| 亚洲国产免费av一区二区三区| 色哟哟国产精品入口| 免费成人va在线观看| 一区二区视频视频视频| 亚洲国产中文字幕啊啊啊不行了| free性日本少妇| 国内精品在线播放第一页| 国产精品一区二区av国| 欧美成人综合视频一区二区| 亚国产成人精品久久久| 免费69视频在线看| 97色视频在线观看| 美洲精品一二三产区区别| 污污小视频91在线观看| av视屏免费在线播放| 偷拍自拍 中文字幕| 少妇人妻100系列| 国产午夜亚洲精品不卡在线观看| 亚洲午夜高清在线观看| 亚洲va国产va欧美va在线| 日噜噜噜夜夜噜噜噜天天噜噜噜| 九一传媒制片厂视频在线免费观看| 成年人黄视频在线观看| 偷拍3456eee| av森泽佳奈在线观看| 91香蕉成人app下载| 国产品国产三级国产普通话三级| 第一福利视频在线观看| 黄色av网站免费在线| 性感美女福利视频网站| 国产夫妻视频在线观看免费| 亚洲一区二区三区五区| 黄色片一级美女黄色片| 中文字幕在线观看极品视频| 日韩一个色综合导航| 懂色av之国产精品| 粉嫩av蜜乳av蜜臀| 日本啪啪啪啪啪啪啪| av在线免费观看亚洲天堂| 亚洲男人的天堂a在线| 亚洲成人av一区久久| 大学生A级毛片免费视频| 中文字幕网站你懂的| 日本成人不卡一区二区| 国产老熟女伦老熟妇ⅹ| 9l人妻人人爽人人爽| 成人综合亚洲欧美一区| 亚洲特黄aaaa片| 天天干天天插天天谢| 国产久久久精品毛片| 亚洲区欧美区另类最新章节| 国产精品自偷自拍啪啪啪| 91啪国自产中文字幕在线| 亚洲国产精品免费在线观看| av久久精品北条麻妃av观看| 女生自摸在线观看一区二区三区| 亚洲人妻国产精品综合| 最新激情中文字幕视频| 天天日天天透天天操| 亚洲熟妇久久无码精品| 天天干天天操天天扣| 日本韩国免费福利精品| 99精品视频在线观看婷婷| 天天干天天操天天扣| 热思思国产99re| 亚洲一区二区激情在线| 精品成人午夜免费看| 中文字幕日韩无敌亚洲精品| 粉嫩av蜜乳av蜜臀| 99精品免费观看视频| 密臀av一区在线观看| 亚洲综合在线视频可播放| 新97超碰在线观看| 国产综合视频在线看片| 扒开让我视频在线观看| 久久免费看少妇高潮完整版| 在线观看av2025| 97精品综合久久在线| 在线观看免费岛国av| 婷婷六月天中文字幕| 天天干夜夜操天天舔| 韩国一级特黄大片做受| 最新97国产在线视频| 天天干天天操天天插天天日| 91人妻精品久久久久久久网站| 亚洲男人在线天堂网| 久久机热/这里只有| 亚洲一区制服丝袜美腿| 99久久久无码国产精品性出奶水| 福利午夜视频在线观看| sspd152中文字幕在线| 国产精品久久久久久久精品视频| 91福利视频免费在线观看| 欧美在线一二三视频| 亚洲一区av中文字幕在线观看| 一区二区三区另类在线| 日本高清撒尿pissing| h国产小视频福利在线观看| 人人爱人人妻人人澡39| 中文字幕一区二区三区人妻大片 | 懂色av之国产精品| 在线观看黄色成年人网站| 五月色婷婷综合开心网4438| 老熟妇凹凸淫老妇女av在线观看| 色综合色综合色综合色| 伊人精品福利综合导航| 亚洲国产精品美女在线观看| 国产在线自在拍91国语自产精品 | 亚洲欧美精品综合图片小说| 国产自拍在线观看成人| 一区二区熟女人妻视频| 男人和女人激情视频| 日本熟女50视频免费| 日韩不卡中文在线视频网站| 2017亚洲男人天堂| 国产成人精品一区在线观看| 九色porny九色9l自拍视频| 91国偷自产一区二区三区精品| 乱亲女秽乱长久久久| 啊啊啊想要被插进去视频| 亚欧在线视频你懂的| 中文字幕在线观看国产片| 亚洲 中文 自拍 无码| 极品性荡少妇一区二区色欲| av中文字幕国产在线观看| 日本高清撒尿pissing| 国产福利小视频大全| 一个人免费在线观看ww视频| 欧美视频一区免费在线| 在线免费91激情四射| 久久永久免费精品人妻专区 | 午夜精品久久久久麻豆影视| 欧美黑人与人妻精品| 五十路丰满人妻熟妇| 成人24小时免费视频| 红杏久久av人妻一区| h国产小视频福利在线观看| 国产日本精品久久久久久久| 国产综合视频在线看片| 在线免费观看国产精品黄色| 亚洲一区二区三区久久午夜| 天天操天天射天天操天天天| 国产黄色大片在线免费播放| 免费观看污视频网站| 亚洲综合在线观看免费| 看一级特黄a大片日本片黑人| 久久久极品久久蜜桃| 在线免费观看日本伦理| 午夜精品福利91av| www久久久久久久久久久| 国产伊人免费在线播放| 一区二区三区日韩久久| 免费看美女脱光衣服的视频| 超级av免费观看一区二区三区| 欧美国品一二三产区区别| 亚洲欧洲av天堂综合| 又粗又长 明星操逼小视频| 夜色福利视频在线观看| 大学生A级毛片免费视频| 全国亚洲男人的天堂| 国产成人无码精品久久久电影| 蜜臀av久久久久久久| 欧美一区二区三区乱码在线播放| 青青社区2国产视频| 夜夜操,天天操,狠狠操| 视频一区二区综合精品| 日本高清成人一区二区三区| 人妻熟女在线一区二区| av中文字幕在线观看第三页| 国产精品欧美日韩区二区| 亚洲Av无码国产综合色区| 91 亚洲视频在线观看| 日本美女成人在线视频| 九色视频在线观看免费| 成人免费做爰高潮视频| 欧美日本国产自视大全| 国产黄网站在线观看播放| 亚洲伊人久久精品影院一美女洗澡| 中文字幕一区二区人妻电影冢本 | 亚洲成人情色电影在线观看| 美女被肏内射视频网站| 黄页网视频在线免费观看| 99av国产精品欲麻豆| av在线资源中文字幕| 丝袜肉丝一区二区三区四区在线看| 中国黄色av一级片| 免费无码人妻日韩精品一区二区| 久久丁香花五月天色婷婷| 国产在线自在拍91国语自产精品| 91精品国产黑色丝袜| 亚洲一区自拍高清免费视频| 2019av在线视频| 欧美一级色视频美日韩| 一区二区三区四区五区性感视频| 亚洲 中文 自拍 另类 欧美| 80电影天堂网官网| 免费在线观看污污视频网站| 亚洲国产精品久久久久久6| 97小视频人妻一区二区| 成人免费公开视频无毒| 五月激情婷婷久久综合网| 国产91久久精品一区二区字幕| 中文字幕亚洲久久久| 一区二区三区激情在线| 国产精品人妻一区二区三区网站| 欧美日韩一区二区电影在线观看| 老司机福利精品免费视频一区二区| 少妇高潮一区二区三区| 黄工厂精品视频在线观看| 丝袜亚洲另类欧美变态| jiujiure精品视频在线| 国产a级毛久久久久精品| 久久久久久久久久一区二区三区 | 亚洲综合一区二区精品久久| 岛国黄色大片在线观看| 91精品综合久久久久3d动漫| 青春草视频在线免费播放| 日日夜夜精品一二三| 人人妻人人人操人人人爽| 精品国产成人亚洲午夜| 三上悠亚和黑人665番号| 美日韩在线视频免费看| 天天综合天天综合天天网| 成人av天堂丝袜在线观看| 天天夜天天日天天日| 91精品国产91久久自产久强| 国产综合视频在线看片| 无套猛戳丰满少妇人妻| aⅴ精产国品一二三产品| 丝袜长腿第一页在线| 日本人妻少妇18—xx| 自拍偷拍vs一区二区三区| 成人网18免费视频版国产| 一区二区免费高清黄色视频| 天天干天天操天天摸天天射| 欧美视频不卡一区四区| 日本av高清免费网站| 手机看片福利盒子日韩在线播放| 人人妻人人爱人人草| 国产精彩对白一区二区三区| 女人精品内射国产99| 久久一区二区三区人妻欧美| 亚洲av色图18p| 成人精品在线观看视频| 99精品视频在线观看婷婷| 在线免费观看99视频| 大鸡吧插逼逼视频免费看 | 亚洲精品国偷自产在线观看蜜桃| 日本韩国免费福利精品| 男人的天堂在线黄色| asmr福利视频在线观看| 岛国毛片视频免费在线观看| 久久99久久99精品影院| 高清成人av一区三区| 亚洲欧美另类手机在线| 绝色少妇高潮3在线观看| 伊拉克及约旦宣布关闭领空| 国产无遮挡裸体免费直播视频| 青青青青青青草国产| 阿v天堂2014 一区亚洲| brazzers欧熟精品系列| 欧美成一区二区三区四区| 老司机免费视频网站在线看| 久久机热/这里只有| 亚洲狠狠婷婷综合久久app | 亚洲av极品精品在线观看| 韩国一级特黄大片做受| 国产精品久久久久久美女校花| 亚洲伊人久久精品影院一美女洗澡| 偷拍美女一区二区三区| 一区二区三区av高清免费| 日韩剧情片电影在线收看| 国产在线91观看免费观看| 日韩北条麻妃一区在线| 亚洲欧洲一区二区在线观看| 天天色天天舔天天射天天爽| 88成人免费av网站| 一区二区三区 自拍偷拍| 北条麻妃av在线免费观看| 91综合久久亚洲综合| 清纯美女在线观看国产| 中文字幕高清在线免费播放| 日日操综合成人av| 亚洲欧美激情人妻偷拍| 麻豆性色视频在线观看| 天堂av在线播放免费| 天天日天天玩天天摸| 亚洲视频在线观看高清| 超碰97免费人妻麻豆| 超pen在线观看视频公开97| 粉嫩欧美美人妻小视频| 狠狠地躁夜夜躁日日躁| 一个人免费在线观看ww视频| 亚洲天堂av最新网址| 国产一线二线三线的区别在哪| 老司机深夜免费福利视频在线观看| 后入美女人妻高清在线| 国产一线二线三线的区别在哪| av中文字幕在线观看第三页| 黄页网视频在线免费观看| 欧美xxx成人在线| 日日夜夜狠狠干视频| 日韩北条麻妃一区在线| 在线观看日韩激情视频| 欧美成人黄片一区二区三区| 大香蕉大香蕉大香蕉大香蕉大香蕉| 亚洲 色图 偷拍 欧美| 丝袜美腿欧美另类 中文字幕| 日本一区精品视频在线观看| 粉嫩小穴流水视频在线观看| 端庄人妻堕落挣扎沉沦| 中文字幕欧美日韩射射一| 在线可以看的视频你懂的| 人妻av无码专区久久绿巨人| 亚洲蜜臀av一区二区三区九色 | 国产欧美精品不卡在线| 国产视频网站国产视频| 国产中文精品在线观看| 国产在线一区二区三区麻酥酥| 亚洲国产香蕉视频在线播放| 蜜臀成人av在线播放| 班长撕开乳罩揉我胸好爽| 天天操,天天干,天天射| sejizz在线视频| 福利午夜视频在线观看| 国产九色91在线视频| 亚洲欧美激情国产综合久久久 | 中文字幕在线观看国产片| 国产美女精品福利在线| 2o22av在线视频| 午夜精品亚洲精品五月色| 自拍偷区二区三区麻豆| 人妻另类专区欧美制服| 一二三区在线观看视频| av俺也去在线播放| 日本av在线一区二区三区| 毛片av在线免费看| 国产精品一区二区av国| 欧美日韩在线精品一区二区三| 天堂av中文在线最新版| 亚洲精品成人网久久久久久小说| 黄片色呦呦视频免费看| 综合精品久久久久97| 青青青青青青青在线播放视频| 69精品视频一区二区在线观看| 中文字幕日韩精品就在这里| 久草视频中文字幕在线观看| 国产真实灌醉下药美女av福利| 78色精品一区二区三区| 夫妻在线观看视频91| 欧美精产国品一二三区| 好男人视频在线免费观看网站| 亚洲成人av一区久久| 性欧美日本大妈母与子| 日韩国产乱码中文字幕| 大屁股熟女一区二区三区| 色av色婷婷人妻久久久精品高清| 亚洲无码一区在线影院| 超碰97人人做人人爱| 精品人妻一二三区久久| 天天日天天敢天天干| 一区二区三区在线视频福利| 日韩精品一区二区三区在线播放| 婷婷久久一区二区字幕网址你懂得 | 人妻少妇性色欲欧美日韩| 精品视频中文字幕在线播放| 男女啪啪视频免费在线观看| 欧美一区二区三区四区性视频| 国内精品在线播放第一页| 亚洲欧美激情中文字幕| 欧美一区二区三区高清不卡tv| 精品国产高潮中文字幕| 天码人妻一区二区三区在线看| 黑人解禁人妻叶爱071| 伊拉克及约旦宣布关闭领空| 91人妻精品久久久久久久网站| 男生用鸡操女生视频动漫 | 91人妻精品一区二区在线看| 成年人啪啪视频在线观看| 在线观看av2025| 欧美亚洲免费视频观看| 国产大学生援交正在播放| 国产九色91在线视频| 日韩欧美国产一区不卡| 91欧美在线免费观看| heyzo蜜桃熟女人妻| 国产视频在线视频播放| 丝袜亚洲另类欧美变态| av中文字幕在线导航| 午夜在线观看一区视频| 久久这里只有精彩视频免费| 在线观看视频 你懂的| 国产美女午夜福利久久| 色婷婷久久久久swag精品| 高潮喷水在线视频观看| 一级黄色片夫妻性生活| 国产在线观看黄色视频| 日韩美av高清在线| 亚洲美女自偷自拍11页| 国产大鸡巴大鸡巴操小骚逼小骚逼| 操日韩美女视频在线免费看| 天天日天天做天天日天天做| 18禁美女黄网站色大片下载| 日本性感美女三级视频| 国产一级麻豆精品免费| 激情五月婷婷综合色啪| 一区二区久久成人网| 精品日产卡一卡二卡国色天香| 经典国语激情内射视频| 日本一区美女福利视频| 任你操视频免费在线观看| 日本一二三中文字幕| 五月天中文字幕内射| 久久免看30视频口爆视频| 精品一区二区三区午夜| 大香蕉大香蕉大香蕉大香蕉大香蕉 | 中文人妻AV久久人妻水| 色噜噜噜噜18禁止观看| 日本在线一区二区不卡视频| 日韩欧美一级精品在线观看| 免费观看成年人视频在线观看| 亚洲精品一区二区三区老狼| 少妇与子乱在线观看| 九九视频在线精品播放| 五十路在线观看完整版| 极品性荡少妇一区二区色欲| 人妻少妇性色欲欧美日韩| 中文字幕之无码色多多| 丰满的继坶3中文在线观看| 在线不卡日韩视频播放| 五十路在线观看完整版| 国产欧美精品不卡在线| 日韩av中文在线免费观看| okirakuhuhu在线观看| rct470中文字幕在线| 国产日韩欧美美利坚蜜臀懂色| 激情五月婷婷综合色啪| av在线观看网址av| 成人蜜臀午夜久久一区| 国产普通话插插视频| 色综合久久久久久久久中文| 成人久久精品一区二区三区| 成人30分钟免费视频| 蜜桃专区一区二区在线观看| 亚洲综合另类欧美久久| 国产精品视频一区在线播放| 都市家庭人妻激情自拍视频| 免费黄高清无码国产| 精品亚洲中文字幕av| 无套猛戳丰满少妇人妻| 午夜婷婷在线观看视频| 93人妻人人揉人人澡人人| 欧美日韩中文字幕欧美| 91快播视频在线观看| 青娱乐极品视频青青草| av在线观看网址av| 五月精品丁香久久久久福利社 | 国产又粗又黄又硬又爽| 自拍 日韩 欧美激情| 黄网十四区丁香社区激情五月天| 精品一区二区三区欧美| 三级黄色亚洲成人av| 在线观看一区二区三级| 青娱乐蜜桃臀av色| 在线观看的a站 最新| 99精品视频之69精品视频 | chinese国产盗摄一区二区| 色婷婷六月亚洲综合香蕉| 99国内小视频在现欢看| 日本啪啪啪啪啪啪啪| 久久艹在线观看视频| 天天射夜夜操综合网| 五十路人妻熟女av一区二区| 中文字幕1卡1区2区3区| 午夜精品福利一区二区三区p| 午夜美女少妇福利视频| 天天日天天鲁天天操| 国产精品久久综合久久| 欧美地区一二三专区| 老师让我插进去69AV| AV天堂一区二区免费试看| 日本一二三区不卡无| 国产精品一区二区av国| 午夜91一区二区三区| 91大屁股国产一区二区| 国内资源最丰富的网站| 日本少妇的秘密免费视频| 综合激情网激情五月天| 欧美美女人体视频一区| 亚洲av成人免费网站| 中文字幕一区二区三区蜜月| 久久久精品精品视频视频| 77久久久久国产精产品| 女蜜桃臀紧身瑜伽裤| 把腿张开让我插进去视频| 国产成人精品久久二区91| 五十路息与子猛烈交尾视频| 日韩激情文学在线视频| 综合色区亚洲熟妇shxstz| 亚洲熟女女同志女同| 精品人妻伦一二三区久| 亚洲一区二区三区精品乱码| 99久久超碰人妻国产| 精品老妇女久久9g国产| 中文字幕一区二区人妻电影冢本| 国产日韩欧美视频在线导航| 日韩精品激情在线观看| 中文字幕第三十八页久久| 精品人人人妻人人玩日产欧| gogo国模私拍视频| 精品高潮呻吟久久av| 日韩av熟妇在线观看| 国产黄色大片在线免费播放| 2021久久免费视频| 日韩中文字幕精品淫| 免费黄页网站4188| 天天日天天干天天爱| 2022中文字幕在线| 天堂中文字幕翔田av| 日韩美女精品视频在线观看网站 | 偷拍3456eee| 大香蕉福利在线观看| 精品少妇一二三视频在线| 国产露脸对白在线观看| 岛国青草视频在线观看| 啪啪啪啪啪啪啪免费视频| 日本熟妇喷水xxx| 国产精品久久久久久久精品视频| 午夜精品福利一区二区三区p| 2025年人妻中文字幕乱码在线| 老司机午夜精品视频资源| 狍和女人的王色毛片| 国产精品中文av在线播放| 婷婷六月天中文字幕| 巨乳人妻日下部加奈被邻居中出| 精品美女福利在线观看| 欧美成人精品欧美一级黄色| 91极品新人『兔兔』精品新作| 一区二区三区av高清免费| japanese日本熟妇另类| av视网站在线观看| 国产精品视频男人的天堂| 女同互舔一区二区三区| 在线视频免费观看网| 国产一区二区视频观看| 天天干天天日天天干天天操| 日韩精品电影亚洲一区| 另类av十亚洲av| 99精品视频在线观看婷婷| 专门看国产熟妇的网站| 日本av在线一区二区三区| 国产性生活中老年人视频网站| 最新中文字幕免费视频| 97人妻无码AV碰碰视频| v888av在线观看视频| 五月天久久激情视频| 日韩欧美一级aa大片| 日曰摸日日碰夜夜爽歪歪| 97人妻人人澡爽人人精品| 早川濑里奈av黑人番号| 亚洲人成精品久久久久久久| 美女av色播在线播放| 免费观看理论片完整版| 精品91自产拍在线观看一区| 欧美3p在线观看一区二区三区| 午夜极品美女福利视频| 亚洲视频在线观看高清| 欧美伊人久久大香线蕉综合| av在线资源中文字幕| 国产又粗又猛又爽又黄的视频在线| 欧美偷拍自拍色图片| 国产女人露脸高潮对白视频| 蝴蝶伊人久久中文娱乐网| 99热久久这里只有精品| 天美传媒mv视频在线观看| 欧美日本国产自视大全| 日本啪啪啪啪啪啪啪| 国产1区,2区,3区| 国产变态另类在线观看| 插小穴高清无码中文字幕| 亚洲欧美激情中文字幕| 男生用鸡操女生视频动漫| 777奇米久久精品一区| 国产激情av网站在线观看| 欧美国品一二三产区区别| 国产性生活中老年人视频网站| asmr福利视频在线观看| 动色av一区二区三区| 日本又色又爽又黄又粗| 欧美va不卡视频在线观看 | 不卡一区一区三区在线| 日噜噜噜夜夜噜噜噜天天噜噜噜| 黄色录像鸡巴插进去| 干逼又爽又黄又免费的视频| 免费费一级特黄真人片| 亚洲高清视频在线不卡| 欧美日本国产自视大全| 中国熟女@视频91| 日韩美女搞黄视频免费| 国产精品久久久黄网站| 精品黑人巨大在线一区| 国产成人无码精品久久久电影| 97超碰免费在线视频| 成人午夜电影在线观看 久久| 福利视频一区二区三区筱慧| 一区二区三区四区中文| 国产真实乱子伦a视频| 青娱乐极品视频青青草| 在线 中文字幕 一区| 国产乱弄免费视频观看| 二区中出在线观看老师| 五十路在线观看完整版| 国产一线二线三线的区别在哪| 91快播视频在线观看| 女同性ⅹxx女同hd| 国产av自拍偷拍盛宴| 青青青aaaa免费| 日本人妻精品久久久久久| 视频一区二区在线免费播放| 福利片区一区二体验区| 国产极品精品免费视频 | 青青社区2国产视频| 国产麻豆剧传媒精品国产av蜜桃| 国产精品三级三级三级| 亚洲国产中文字幕啊啊啊不行了| 亚洲色偷偷综合亚洲AV伊人| 中文字幕高清在线免费播放 | 丰满的继坶3中文在线观看| 中文字幕在线视频一区二区三区 | 91中文字幕免费在线观看| 亚洲成人午夜电影在线观看| 国产精品伦理片一区二区| 青青草精品在线视频观看| 超碰在线观看免费在线观看| 中字幕人妻熟女人妻a62v网| 欧美亚洲中文字幕一区二区三区| 19一区二区三区在线播放| 国产精品视频男人的天堂| 在线免费观看av日韩| 精品日产卡一卡二卡国色天香 | 日本韩国亚洲综合日韩欧美国产| 亚洲2021av天堂| 亚洲av无乱一区二区三区性色| av在线资源中文字幕| 鸡巴操逼一级黄色气| 一区国内二区日韩三区欧美| 青青草原网站在线观看| 女生自摸在线观看一区二区三区| 老司机福利精品视频在线| 欧美亚洲一二三区蜜臀| 国产成人精品久久二区91| 日韩伦理短片在线观看| 日韩在线中文字幕色| 97精品人妻一区二区三区精品| 欧美黑人巨大性xxxxx猛交| 国产亚洲精品欧洲在线观看| 一区二区三区四区视频在线播放| 性色av一区二区三区久久久| 新婚人妻聚会被中出| 五十路人妻熟女av一区二区| 精品一区二区三区三区色爱| 中文字幕午夜免费福利视频| 久久国产精品精品美女| 丝袜肉丝一区二区三区四区在线| 国产精品久久久久久久久福交| 亚洲欧美一区二区三区爱爱动图| 中文字幕一区二区三区人妻大片| 99热国产精品666| 91一区精品在线观看| av中文在线天堂精品| 国产精品久久久久国产三级试频| 视频一区 视频二区 视频| 自拍偷拍亚洲欧美在线视频| 99热99这里精品6国产| 亚洲一区二区三区精品视频在线 | 在线观看视频污一区| 不卡一不卡二不卡三| 日韩亚国产欧美三级涩爱| 含骚鸡巴玩逼逼视频| 欧美成人精品在线观看| 欧美日韩熟女一区二区三区| 国产黄色大片在线免费播放| 综合激情网激情五月天| 成人av电影免费版| 国产激情av网站在线观看| 午夜久久久久久久精品熟女| 香港三日本三韩国三欧美三级| 亚洲国产欧美一区二区丝袜黑人| 欧美韩国日本国产亚洲| 青草亚洲视频在线观看| 91国产在线视频免费观看| 久久三久久三久久三久久| 午夜激情精品福利视频| 国产免费高清视频视频| 国产精品国产精品一区二区| 日日夜夜精品一二三| 自拍偷拍一区二区三区图片| 国产精品久久综合久久| 人妻少妇av在线观看| 男人的天堂一区二区在线观看| 57pao国产一区二区| 日本最新一二三区不卡在线 | 亚洲Av无码国产综合色区| 日本少妇高清视频xxxxx| 激情小视频国产在线|