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

Java實(shí)現(xiàn)excel大數(shù)據(jù)量導(dǎo)入

 更新時(shí)間:2020年08月25日 09:43:54   作者:王紹樺  
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)excel大數(shù)據(jù)量導(dǎo)入,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了Java實(shí)現(xiàn)excel大數(shù)據(jù)量導(dǎo)入的具體代碼,供大家參考,具體內(nèi)容如下

情景分析:

通常我們通過(guò)poi讀取excel文件時(shí),若在用戶模式下,由于數(shù)據(jù)量較大、Sheet較多,很容易出現(xiàn)內(nèi)存溢出的情況

用戶模式讀取excel的典型代碼如下:

FileInputStream file = new FileInputStream("c:\\test.xlsx");
Workbook wb=new XSSFWorkbook(file);

而03版(xls)excel文件每個(gè)sheet最大長(zhǎng)度為 65536行,07版(xlsx)excel文件每個(gè)sheet最大長(zhǎng)度為 1048576行,因此我們主要解決07版(xlsx)excel大數(shù)據(jù)量導(dǎo)入出現(xiàn)內(nèi)存溢出的問題

由于讀取cvs文件效率高且占用內(nèi)存少,所以我們采用xlsx轉(zhuǎn)換為cvs的方式來(lái)解決

讀取xlsx格式數(shù)據(jù):

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
 
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.openxml4j.opc.PackageAccess;
import org.apache.poi.ss.usermodel.BuiltinFormats;
import org.apache.poi.ss.usermodel.DataFormatter;
import org.apache.poi.xssf.eventusermodel.ReadOnlySharedStringsTable;
import org.apache.poi.xssf.eventusermodel.XSSFReader;
import org.apache.poi.xssf.model.StylesTable;
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
import org.apache.poi.xssf.usermodel.XSSFRichTextString;
import org.xml.sax.Attributes;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.DefaultHandler;
 
public class XLSX2CSV {
 
 enum xssfDataType {
 BOOL, ERROR, FORMULA, INLINESTR, SSTINDEX, NUMBER,
 }
 
 /**
 * 使用xssf_sax_API處理Excel,請(qǐng)參考: http://poi.apache.org/spreadsheet/how-to.html#xssf_sax_api
 */
 class MyXSSFSheetHandler extends DefaultHandler {
 
 private StylesTable stylesTable;
 
 private ReadOnlySharedStringsTable sharedStringsTable;
 
 private final PrintStream output;
 
 private final int minColumnCount;
 
 private boolean vIsOpen;
 
 private xssfDataType nextDataType;
 
 private short formatIndex;
 private String formatString;
 private final DataFormatter formatter;
 
 private int thisColumn = -1;
 private int lastColumnNumber = -1;
 
 private StringBuffer value;
 private String[] record;
 private List<String[]> rows = new ArrayList<String[]>();
 private boolean isCellNull = false;
 
 public MyXSSFSheetHandler(StylesTable styles,ReadOnlySharedStringsTable strings, int cols, PrintStream target) {
 this.stylesTable = styles;
 this.sharedStringsTable = strings;
 this.minColumnCount = cols;
 this.output = target;
 this.value = new StringBuffer();
 this.nextDataType = xssfDataType.NUMBER;
 this.formatter = new DataFormatter();
 record = new String[this.minColumnCount];
 rows.clear();// 每次讀取都清空行集合
 }
 
 public void startElement(String uri, String localName, String name,Attributes attributes) throws SAXException {
 if ("inlineStr".equals(name) || "v".equals(name)) {
 vIsOpen = true;
 // Clear contents cache
 value.setLength(0);
 }
 // c => cell
 else if ("c".equals(name)) {
 // Get the cell reference
 String r = attributes.getValue("r");
 int firstDigit = -1;
 for (int c = 0; c < r.length(); ++c) {
  if (Character.isDigit(r.charAt(c))) {
  firstDigit = c;
  break;
  }
 }
 thisColumn = nameToColumn(r.substring(0, firstDigit));
 
 // Set up defaults.
 this.nextDataType = xssfDataType.NUMBER;
 this.formatIndex = -1;
 this.formatString = null;
 String cellType = attributes.getValue("t");
 String cellStyleStr = attributes.getValue("s");
 if ("b".equals(cellType))
  nextDataType = xssfDataType.BOOL;
 else if ("e".equals(cellType))
  nextDataType = xssfDataType.ERROR;
 else if ("inlineStr".equals(cellType))
  nextDataType = xssfDataType.INLINESTR;
 else if ("s".equals(cellType))
  nextDataType = xssfDataType.SSTINDEX;
 else if ("str".equals(cellType))
  nextDataType = xssfDataType.FORMULA;
 else if (cellStyleStr != null) {
  // It's a number, but almost certainly one
  // with a special style or format
  int styleIndex = Integer.parseInt(cellStyleStr);
  XSSFCellStyle style = stylesTable.getStyleAt(styleIndex);
  this.formatIndex = style.getDataFormat();
  this.formatString = style.getDataFormatString();
  if (this.formatString == null)
  this.formatString = BuiltinFormats
  .getBuiltinFormat(this.formatIndex);
 }
 }
 
 }
 
 public void endElement(String uri, String localName, String name)throws SAXException {
 
 String thisStr = null;
 
 // v => contents of a cell
 if ("v".equals(name)) {
 // Process the value contents as required.
 // Do now, as characters() may be called more than once
 switch (nextDataType) {
 
 case BOOL:
  char first = value.charAt(0);
  thisStr = first == '0' ? "FALSE" : "TRUE";
  break;
 
 case ERROR:
  thisStr = "\"ERROR:" + value.toString() + '"';
  break;
 
 case FORMULA:
  // A formula could result in a string value,
  // so always add double-quote characters.
  thisStr = '"' + value.toString() + '"';
  break;
 
 case INLINESTR:
  // TODO: have seen an example of this, so it's untested.
  XSSFRichTextString rtsi = new XSSFRichTextString(value.toString());
  thisStr = '"' + rtsi.toString() + '"';
  break;
 
 case SSTINDEX:
  String sstIndex = value.toString();
  try {
  int idx = Integer.parseInt(sstIndex);
  XSSFRichTextString rtss = new XSSFRichTextString(sharedStringsTable.getEntryAt(idx));
  thisStr = rtss.toString();
  } catch (NumberFormatException ex) {
  output.println("Failed to parse SST index '" + sstIndex
  + "': " + ex.toString());
  }
  break;
 
 case NUMBER:
  String n = value.toString();
  // 判斷是否是日期格式
  if (HSSFDateUtil.isADateFormat(this.formatIndex, n)) {
  Double d = Double.parseDouble(n);
  Date date=HSSFDateUtil.getJavaDate(d);
  thisStr=formateDateToString(date);
  } else if (this.formatString != null)
  thisStr = formatter.formatRawCellContents(
  Double.parseDouble(n), this.formatIndex,
  this.formatString);
  else
  thisStr = n;
  break;
 
 default:
  thisStr = "(TODO: Unexpected type: " + nextDataType + ")";
  break;
 }
 
 // Output after we've seen the string contents
 // Emit commas for any fields that were missing on this row
 if (lastColumnNumber == -1) {
  lastColumnNumber = 0;
 }
 //判斷單元格的值是否為空
 if (thisStr == null || "".equals(isCellNull)) {
  isCellNull = true;// 設(shè)置單元格是否為空值
 }
 record[thisColumn] = thisStr;
 // Update column
 if (thisColumn > -1)
  lastColumnNumber = thisColumn;
 
 } else if ("row".equals(name)) {
 // Print out any missing commas if needed
 if (minColumns > 0) {
  // Columns are 0 based
  if (lastColumnNumber == -1) {
  lastColumnNumber = 0;
  }
  if (isCellNull == false && record[0] != null
  && record[1] != null)// 判斷是否空行
  {
  rows.add(record.clone());
  isCellNull = false;
  for (int i = 0; i < record.length; i++) {
  record[i] = null;
  }
  }
 }
 lastColumnNumber = -1;
 }
 
 }
 
 public List<String[]> getRows() {
 return rows;
 }
 
 public void setRows(List<String[]> rows) {
 this.rows = rows;
 }
 
 /**
 * Captures characters only if a suitable element is open. Originally
 * was just "v"; extended for inlineStr also.
 */
 public void characters(char[] ch, int start, int length)throws SAXException {
 if (vIsOpen)
 value.append(ch, start, length);
 }
 
 /**
 * Converts an Excel column name like "C" to a zero-based index.
 * @param name
 * @return Index corresponding to the specified name
 */
 private int nameToColumn(String name) {
 int column = -1;
 for (int i = 0; i < name.length(); ++i) {
 int c = name.charAt(i);
 column = (column + 1) * 26 + c - 'A';
 }
 return column;
 }
 
 private String formateDateToString(Date date) {
 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//格式化日期
 return sdf.format(date);
 
 }
 
 }
 
 private OPCPackage xlsxPackage;
 private int minColumns;
 private PrintStream output;
 
 /**
 * Creates a new XLSX -> CSV converter
 * 
 * @param pkg
 *   The XLSX package to process
 * @param output
 *   The PrintStream to output the CSV to
 * @param minColumns
 *   The minimum number of columns to output, or -1 for no minimum
 */
 public XLSX2CSV(OPCPackage pkg, PrintStream output,int minColumns) {
 this.xlsxPackage = pkg;
 this.output = output;
 this.minColumns = minColumns;
 }
 
 /**
 * Parses and shows the content of one sheet using the specified styles and
 * shared-strings tables.
 * @param styles
 * @param strings
 * @param sheetInputStream
 */
 public List<String[]> processSheet(StylesTable styles,
 ReadOnlySharedStringsTable strings, InputStream sheetInputStream)
 throws IOException, ParserConfigurationException, SAXException {
 InputSource sheetSource = new InputSource(sheetInputStream);
 SAXParserFactory saxFactory = SAXParserFactory.newInstance();
 SAXParser saxParser = saxFactory.newSAXParser();
 XMLReader sheetParser = saxParser.getXMLReader();
 MyXSSFSheetHandler handler = new MyXSSFSheetHandler(styles, strings,this.minColumns, this.output);
 sheetParser.setContentHandler(handler);
 sheetParser.parse(sheetSource);
 return handler.getRows();
 }
 
 /**
 * 初始化這個(gè)處理程序 
 * @throws IOException
 * @throws OpenXML4JException
 * @throws ParserConfigurationException
 * @throws SAXException
 */
 public List<String[]> process() throws IOException, OpenXML4JException,ParserConfigurationException, SAXException {
 ReadOnlySharedStringsTable strings = new ReadOnlySharedStringsTable(this.xlsxPackage);
 XSSFReader xssfReader = new XSSFReader(this.xlsxPackage);
 List<String[]> list = null;
 StylesTable styles = xssfReader.getStylesTable();
 XSSFReader.SheetIterator iter = (XSSFReader.SheetIterator) xssfReader.getSheetsData();
 int index = 0;
 while (iter.hasNext()) {
 InputStream stream = iter.next();
 index++;
 //默認(rèn)取第一個(gè)工作薄
 if(index == 1){
 list = processSheet(styles, strings, stream);
 stream.close();
 }
 }
 return list;
 }
 
 /**
 * 讀取Excel
 * 
 * @param path
 *   文件路徑
 * @param sheetName
 *   sheet名稱
 * @param minColumns
 *   列總數(shù)
 * @return
 * @throws SAXException
 * @throws ParserConfigurationException
 * @throws OpenXML4JException
 * @throws IOException
 */
 private static List<String[]> readerExcel(String path,int minColumns) throws IOException, OpenXML4JException,ParserConfigurationException, SAXException {
 OPCPackage p = OPCPackage.open(path, PackageAccess.READ);
 XLSX2CSV xlsx2csv = new XLSX2CSV(p, System.out, minColumns);
 List<String[]> list = xlsx2csv.process();
 p.close();
 return list;
 }
 
 /**
 * 讀取Excel
 * 
 * @param file
 *   File
 * @param sheetName
 *   sheet名稱
 * @param minColumns
 *   列總數(shù)
 * @return
 * @throws SAXException
 * @throws ParserConfigurationException
 * @throws OpenXML4JException
 * @throws IOException
 */
 private static List<String[]> readerExcelInputStream(File file,int minColumns) throws IOException, OpenXML4JException, ParserConfigurationException, SAXException {
 OPCPackage p = OPCPackage.openOrCreate(file);
 XLSX2CSV xlsx2csv = new XLSX2CSV(p, System.out, minColumns);
 List<String[]> list = xlsx2csv.process();
 p.close();
 return list;
 }
 
 //獲取表頭及數(shù)據(jù)內(nèi)容,可在業(yè)務(wù)層調(diào)用
 public static Map<String,Object> getTableDate(InputStream in) throws IOException, OpenXML4JException, ParserConfigurationException, SAXException{ 
 File out = new File("C:\\date.xlsx");//默認(rèn)在C盤生成date.xlsx文件
 OutputStream output = null;
 try {
 output = new FileOutputStream(out);
 byte[] buf = new byte[1024];
 int bytesRead;
 while ((bytesRead = in.read(buf)) > 0) {
 output.write(buf, 0, bytesRead);
 }
 } finally {
 in.close();
 output.close();
 }
 Map<String,Object> map = new HashMap<String,Object>();
 List<String> headresult = new ArrayList<String>();//表頭集合
 List<List<String>> dataresult = new ArrayList<List<String>>();//表數(shù)據(jù)集合
 List<String[]> list = readerExcelInputStream(out,30);//默認(rèn)讀取30列
 for(int i=0;i<list.size();i++){
 if(i == 0){
 for(String cell : list.get(i)){
  if(cell != null){  
  headresult.add(cell);
  }
 }
 }else{
 List<String> dataList = new ArrayList<String>();
 for(String cell : list.get(i)){
  dataList.add(cell == null ? "" : cell);
 }
 dataresult.add(dataList);
 }
 }
 map.put("headresult", headresult);
 map.put("dataresult", dataresult);
 return map;
 }
 
 public static void main(String[] args) throws Exception {
 File file = new File("C:/Users/Administrator/Desktop/測(cè)試.xlsx");
 System.out.println("開始讀取...");
 List<String[]> list = XLSX2CSV.readerExcelInputStream(file, 30);//默認(rèn)讀取30列
 System.out.println("數(shù)據(jù)量:"+list.size());
 for(int i=0;i<list.size();i++){
 if(i > 0){
 for (String cell : list.get(i)) {
  System.out.print(cell + ",");
 }
 System.out.println();
 }
 }
 }
 
}

說(shuō)明:

代碼中的加載excel的核心方法:

OPCPackage pkg = OPCPackage.open(path);//文件路徑
OPCPackage pkg = OPCPackage.openOrCreate(file);//文件
OPCPackage pkg = OPCPackage.open(InputStream);//文件流

文件流方式對(duì)內(nèi)存依賴極大,所以實(shí)際應(yīng)用時(shí),如果只能獲取文件流的話,可以先將文件通過(guò)流拷貝到本地再解析代碼中的

若上傳文件大小超過(guò)限制,可在配置文件中設(shè)置,SpringBoot2項(xiàng)目application.properties中設(shè)置:

spring.servlet.multipart.maxFileSize=50MB
spring.servlet.multipart.maxRequestSize=100MB

實(shí)際業(yè)務(wù)數(shù)據(jù)入庫(kù)的話也可采用異步任務(wù)@Async的方式來(lái)提高入庫(kù)效率:

import java.util.Map;
 
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
 
import cn.com.app.dao.JkconfigDao;
 
@Service
public class JkrzService {
 
 @Autowired
 private JkconfigDao jkconfigDao;
 
 @Async("myTaskAsyncPool")
 public void transJkrz(Map<String, Object> m) {
 jkconfigDao.insert(m);
 }
}

線程池配置:

import java.util.concurrent.Executor;
import java.util.concurrent.ThreadPoolExecutor;
 
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
 
@Configuration
@EnableAsync
public class AsyncTaskConfig {
 
 @Autowired 
 private TaskThreadPoolConfig config;
 
 // ThredPoolTaskExcutor的處理流程
 // 當(dāng)池子大小小于corePoolSize,就新建線程,并處理請(qǐng)求
 // 當(dāng)池子大小等于corePoolSize,把請(qǐng)求放入workQueue中,池子里的空閑線程就去workQueue中取任務(wù)并處理
 // 當(dāng)workQueue放不下任務(wù)時(shí),就新建線程入池,并處理請(qǐng)求,如果池子大小撐到了maximumPoolSize,就用RejectedExecutionHandler來(lái)做拒絕處理
 // 當(dāng)池子的線程數(shù)大于corePoolSize時(shí),多余的線程會(huì)等待keepAliveTime長(zhǎng)時(shí)間,如果無(wú)請(qǐng)求可處理就自行銷毀
 // 當(dāng)threadNamePrefix設(shè)置為true,則核心線程也會(huì)超時(shí)關(guān)閉 
 @Bean
 public Executor myTaskAsyncPool() {
  ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); 
   executor.setCorePoolSize(config.getCorePoolSize()); 
   executor.setMaxPoolSize(config.getMaxPoolSize()); 
   executor.setQueueCapacity(config.getQueueCapacity()); 
   executor.setKeepAliveSeconds(config.getKeepAliveSeconds()); 
   executor.setAllowCoreThreadTimeOut(true);
   executor.setThreadNamePrefix("MyExecutor-"); 
 
   // rejection-policy:當(dāng)pool已經(jīng)達(dá)到max size的時(shí)候,如何處理新任務(wù) 
   // CALLER_RUNS:不在新線程中執(zhí)行任務(wù),而是由調(diào)用者所在的線程來(lái)執(zhí)行 
   executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); 
   executor.initialize(); 
  return executor;
 }
 
}

參數(shù)配置:

#核心線程數(shù),當(dāng)線程數(shù)小于核心線程數(shù)時(shí),即使有線程空閑,線程池也會(huì)優(yōu)先創(chuàng)建新線程,設(shè)置allowCoreThreadTimeout=true(默認(rèn)false)時(shí),核心線程會(huì)超時(shí)退出
spring.task.pool.corePoolSize=20
#最大線程數(shù),當(dāng)線程數(shù)大于等于corePoolSize,且任務(wù)隊(duì)列已滿時(shí),線程池會(huì)創(chuàng)建新線程來(lái)處理任務(wù)
spring.task.pool.maxPoolSize=60
#線程空閑時(shí)間,當(dāng)線程空閑時(shí)間達(dá)到keepAliveSeconds(秒)時(shí),線程會(huì)退出,直到線程數(shù)量等于corePoolSize,如果allowCoreThreadTimeout=true,則會(huì)直到線程數(shù)量等于0
spring.task.pool.keepAliveSeconds=1
#任務(wù)隊(duì)列容量,當(dāng)核心線程數(shù)達(dá)到最大時(shí),新任務(wù)會(huì)放在隊(duì)列中排隊(duì)等待執(zhí)行
spring.task.pool.queueCapacity=400

讀取xls格式數(shù)據(jù):

import org.apache.poi.hssf.eventusermodel.*;
import org.apache.poi.hssf.eventusermodel.dummyrecord.LastCellOfRowDummyRecord;
import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingCellDummyRecord;
import org.apache.poi.hssf.model.HSSFFormulaParser;
import org.apache.poi.hssf.record.*;
import org.apache.poi.hssf.usermodel.HSSFDataFormatter;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
 
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
 
/**
 * @desc 用于解決.xls2003版本大數(shù)據(jù)量問題
 **/
public class ExcelXlsReader implements HSSFListener {
 
 //存儲(chǔ)所有數(shù)據(jù)
 private List<List<String>> dataList = new ArrayList<List<String>>();
 
 private int minColums = -1;
 
 private POIFSFileSystem fs;
 
 /**
  * 總行數(shù)
  */
 private int totalRows=0;
 
 /**
  * 上一行row的序號(hào)
  */
 private int lastRowNumber;
 
 /**
  * 上一單元格的序號(hào)
  */
 private int lastColumnNumber;
 
 /**
  * 是否輸出formula,還是它對(duì)應(yīng)的值
  */
 private boolean outputFormulaValues = true;
 
 /**
  * 用于轉(zhuǎn)換formulas
  */
 private EventWorkbookBuilder.SheetRecordCollectingListener workbookBuildingListener;
 
 //excel2003工作簿
 private HSSFWorkbook stubWorkbook;
 
 private SSTRecord sstRecord;
 
 private FormatTrackingHSSFListener formatListener;
 
 private final HSSFDataFormatter formatter = new HSSFDataFormatter();
 
 /**
  * 文件的絕對(duì)路徑
  */
 private String filePath = "";
 
 //表索引
 private int sheetIndex = 0;
 
 private BoundSheetRecord[] orderedBSRs;
 
 @SuppressWarnings("unchecked")
 private ArrayList boundSheetRecords = new ArrayList();
 
 private int nextRow;
 
 private int nextColumn;
 
 private boolean outputNextStringRecord;
 
 //當(dāng)前行
 private int curRow = 0;
 
 //存儲(chǔ)一行記錄所有單元格的容器
 private List<String> cellList = new ArrayList<String>();
 
 /**
  * 判斷整行是否為空行的標(biāo)記
  */
 private boolean flag = false;
 
 @SuppressWarnings("unused")
 private String sheetName;
 
 /**
  * 遍歷excel下所有的sheet
  *
  * @param fileName
  * @throws Exception
  */
 public int process(String fileName) throws Exception {
  filePath = fileName;
  this.fs = new POIFSFileSystem(new FileInputStream(fileName));
  MissingRecordAwareHSSFListener listener = new MissingRecordAwareHSSFListener(this);
  formatListener = new FormatTrackingHSSFListener(listener);
  HSSFEventFactory factory = new HSSFEventFactory();
  HSSFRequest request = new HSSFRequest();
  if (outputFormulaValues) {
   request.addListenerForAllRecords(formatListener);
  } else {
   workbookBuildingListener = new EventWorkbookBuilder.SheetRecordCollectingListener(formatListener);
   request.addListenerForAllRecords(workbookBuildingListener);
  }
  factory.processWorkbookEvents(request, fs);
 
  return totalRows; //返回該excel文件的總行數(shù),不包括首列和空行
 }
 
 public List<List<String>> process(InputStream in) throws Exception {
  //filePath = fileName;
  this.fs = new POIFSFileSystem(in);
  MissingRecordAwareHSSFListener listener = new MissingRecordAwareHSSFListener(this);
  formatListener = new FormatTrackingHSSFListener(listener);
  HSSFEventFactory factory = new HSSFEventFactory();
  HSSFRequest request = new HSSFRequest();
  if (outputFormulaValues) {
   request.addListenerForAllRecords(formatListener);
  } else {
   workbookBuildingListener = new EventWorkbookBuilder.SheetRecordCollectingListener(formatListener);
   request.addListenerForAllRecords(workbookBuildingListener);
  }
  factory.processWorkbookEvents(request, fs);
 
  return dataList; //返回該excel文件的總行數(shù),不包括首列和空行
 }
 
 /**
  * HSSFListener 監(jiān)聽方法,處理Record
  * 處理每個(gè)單元格
  * @param record
  */
 @SuppressWarnings("unchecked")
 public void processRecord(Record record) {
  int thisRow = -1;
  int thisColumn = -1;
  String thisStr = null;
  String value = null;
  switch (record.getSid()) {
   case BoundSheetRecord.sid:
    boundSheetRecords.add(record);
    break;
   case BOFRecord.sid: //開始處理每個(gè)sheet
    BOFRecord br = (BOFRecord) record;
    if (br.getType() == BOFRecord.TYPE_WORKSHEET) {
     //如果有需要,則建立子工作簿
     if (workbookBuildingListener != null && stubWorkbook == null) {
      stubWorkbook = workbookBuildingListener.getStubHSSFWorkbook();
     }
 
     if (orderedBSRs == null) {
      orderedBSRs = BoundSheetRecord.orderByBofPosition(boundSheetRecords);
     }
     sheetName = orderedBSRs[sheetIndex].getSheetname();
     sheetIndex++;
    }
    break;
   case SSTRecord.sid:
    sstRecord = (SSTRecord) record;
    break;
   case BlankRecord.sid: //單元格為空白
    BlankRecord brec = (BlankRecord) record;
    thisRow = brec.getRow();
    thisColumn = brec.getColumn();
    thisStr = "";
    cellList.add(thisColumn, thisStr);
    break;
   case BoolErrRecord.sid: //單元格為布爾類型
    BoolErrRecord berec = (BoolErrRecord) record;
    thisRow = berec.getRow();
    thisColumn = berec.getColumn();
    thisStr = berec.getBooleanValue() + "";
    cellList.add(thisColumn, thisStr);
    checkRowIsNull(thisStr); //如果里面某個(gè)單元格含有值,則標(biāo)識(shí)該行不為空行
    break;
   case FormulaRecord.sid://單元格為公式類型
    FormulaRecord frec = (FormulaRecord) record;
    thisRow = frec.getRow();
    thisColumn = frec.getColumn();
    if (outputFormulaValues) {
     if (Double.isNaN(frec.getValue())) {
      outputNextStringRecord = true;
      nextRow = frec.getRow();
      nextColumn = frec.getColumn();
     } else {
      thisStr = '"' + HSSFFormulaParser.toFormulaString(stubWorkbook, frec.getParsedExpression()) + '"';
     }
    } else {
     thisStr = '"' + HSSFFormulaParser.toFormulaString(stubWorkbook, frec.getParsedExpression()) + '"';
    }
    cellList.add(thisColumn, thisStr);
    checkRowIsNull(thisStr); //如果里面某個(gè)單元格含有值,則標(biāo)識(shí)該行不為空行
    break;
   case StringRecord.sid: //單元格中公式的字符串
    if (outputNextStringRecord) {
     StringRecord srec = (StringRecord) record;
     thisStr = srec.getString();
     thisRow = nextRow;
     thisColumn = nextColumn;
     outputNextStringRecord = false;
    }
    break;
   case LabelRecord.sid:
    LabelRecord lrec = (LabelRecord) record;
    curRow = thisRow = lrec.getRow();
    thisColumn = lrec.getColumn();
    value = lrec.getValue().trim();
    value = value.equals("") ? "" : value;
    cellList.add(thisColumn, value);
    checkRowIsNull(value); //如果里面某個(gè)單元格含有值,則標(biāo)識(shí)該行不為空行
    break;
   case LabelSSTRecord.sid: //單元格為字符串類型
    LabelSSTRecord lsrec = (LabelSSTRecord) record;
    curRow = thisRow = lsrec.getRow();
    thisColumn = lsrec.getColumn();
    if (sstRecord == null) {
     cellList.add(thisColumn, "");
    } else {
     value = sstRecord.getString(lsrec.getSSTIndex()).toString().trim();
     value = value.equals("") ? "" : value;
     cellList.add(thisColumn, value);
     checkRowIsNull(value); //如果里面某個(gè)單元格含有值,則標(biāo)識(shí)該行不為空行
    }
    break;
   case NumberRecord.sid: //單元格為數(shù)字類型
    NumberRecord numrec = (NumberRecord) record;
    curRow = thisRow = numrec.getRow();
    thisColumn = numrec.getColumn();
 
    //第一種方式
    //value = formatListener.formatNumberDateCell(numrec).trim();//這個(gè)被寫死,采用的m/d/yy h:mm格式,不符合要求
 
    //第二種方式,參照f(shuō)ormatNumberDateCell里面的實(shí)現(xiàn)方法編寫
    Double valueDouble=((NumberRecord)numrec).getValue();
    String formatString=formatListener.getFormatString(numrec);
    if (formatString.contains("m/d/yy")){
     formatString="yyyy-MM-dd hh:mm:ss";
    }
    int formatIndex=formatListener.getFormatIndex(numrec);
    value=formatter.formatRawCellContents(valueDouble, formatIndex, formatString).trim();
 
    value = value.equals("") ? "" : value;
    //向容器加入列值
    cellList.add(thisColumn, value);
    checkRowIsNull(value); //如果里面某個(gè)單元格含有值,則標(biāo)識(shí)該行不為空行
    break;
   default:
    break;
  }
 
  //遇到新行的操作
  if (thisRow != -1 && thisRow != lastRowNumber) {
   lastColumnNumber = -1;
  }
 
  //空值的操作
  if (record instanceof MissingCellDummyRecord) {
   MissingCellDummyRecord mc = (MissingCellDummyRecord) record;
   curRow = thisRow = mc.getRow();
   thisColumn = mc.getColumn();
   cellList.add(thisColumn, "");
  }
 
  //更新行和列的值
  if (thisRow > -1)
   lastRowNumber = thisRow;
  if (thisColumn > -1)
   lastColumnNumber = thisColumn;
 
  //行結(jié)束時(shí)的操作
  if (record instanceof LastCellOfRowDummyRecord) {
   if (minColums > 0) {
    //列值重新置空
    if (lastColumnNumber == -1) {
     lastColumnNumber = 0;
    }
   }
   lastColumnNumber = -1;
 
   if (flag&&curRow!=0) { //該行不為空行且該行不是第一行,發(fā)送(第一行為列名,不需要)
    //ExcelReaderUtil.sendRows(filePath, sheetName, sheetIndex, curRow + 1, cellList); //每行結(jié)束時(shí),調(diào)用sendRows()方法
    totalRows++;
    //添加到數(shù)據(jù)集合中
    dataList.add(cellList);
   }
   //清空容器
   cellList = new ArrayList<String>(); 
   //cellList.clear();
   flag=false;
  }
 }
 
 /**
  * 如果里面某個(gè)單元格含有值,則標(biāo)識(shí)該行不為空行
  * @param value
  */
 public void checkRowIsNull(String value){
  if (value != null && !"".equals(value)) {
   flag = true;
  }
 }
}

讀取xlsx格式數(shù)據(jù)(自動(dòng)獲取表頭長(zhǎng)度方式):

import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.ss.usermodel.BuiltinFormats;
import org.apache.poi.ss.usermodel.DataFormatter;
import org.apache.poi.xssf.eventusermodel.XSSFReader;
import org.apache.poi.xssf.model.SharedStringsTable;
import org.apache.poi.xssf.model.StylesTable;
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
import org.apache.poi.xssf.usermodel.XSSFRichTextString;
import org.xml.sax.Attributes;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.DefaultHandler;
import org.xml.sax.helpers.XMLReaderFactory;
 
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
 
/**
 * @desc POI讀取excel有兩種模式,一種是用戶模式,一種是事件驅(qū)動(dòng)模式
 * 采用SAX事件驅(qū)動(dòng)模式解決XLSX文件,可以有效解決用戶模式內(nèi)存溢出的問題,
 * 該模式是POI官方推薦的讀取大數(shù)據(jù)的模式,
 * 在用戶模式下,數(shù)據(jù)量較大,Sheet較多,或者是有很多無(wú)用的空行的情況下,容易出現(xiàn)內(nèi)存溢出
 * <p>
 * 用于解決.xlsx2007版本大數(shù)據(jù)量問題
 **/
public class ExcelXlsxReader extends DefaultHandler {
 
 //存儲(chǔ)所有數(shù)據(jù)
 private List<List<String>> dataList = new ArrayList<List<String>>();
 
 /**
  * 單元格中的數(shù)據(jù)可能的數(shù)據(jù)類型
  */
 enum CellDataType {
  BOOL, ERROR, FORMULA, INLINESTR, SSTINDEX, NUMBER, DATE, NULL
 }
 
 /**
  * 共享字符串表
  */
 private SharedStringsTable sst;
 
 /**
  * 上一次的索引值
  */
 private String lastIndex;
 
 /**
  * 文件的絕對(duì)路徑
  */
 private String filePath = "";
 
 /**
  * 工作表索引
  */
 private int sheetIndex = 0;
 
 /**
  * sheet名
  */
 private String sheetName = "";
 
 /**
  * 總行數(shù)
  */
 private int totalRows=0;
 
 /**
  * 一行內(nèi)cell集合
  */
 private List<String> cellList = new ArrayList<String>();
 
 /**
  * 判斷整行是否為空行的標(biāo)記
  */
 private boolean flag = false;
 
 /**
  * 當(dāng)前行
  */
 private int curRow = 1;
 
 /**
  * 當(dāng)前列
  */
 private int curCol = 0;
 
 /**
  * T元素標(biāo)識(shí)
  */
 private boolean isTElement;
 
 /**
  * 判斷上一單元格是否為文本空單元格
  */
 private boolean startElementFlag = true;
 private boolean endElementFlag = false;
 private boolean charactersFlag = false;
 
 /**
  * 異常信息,如果為空則表示沒有異常
  */
 private String exceptionMessage;
 
 /**
  * 單元格數(shù)據(jù)類型,默認(rèn)為字符串類型
  */
 private CellDataType nextDataType = CellDataType.SSTINDEX;
 
 private final DataFormatter formatter = new DataFormatter();
 
 /**
  * 單元格日期格式的索引
  */
 private short formatIndex;
 
 /**
  * 日期格式字符串
  */
 private String formatString;
 
 //定義前一個(gè)元素和當(dāng)前元素的位置,用來(lái)計(jì)算其中空的單元格數(shù)量,如A6和A8等
 private String prePreRef = "A", preRef = null, ref = null;
 
 //定義該文檔一行最大的單元格數(shù),用來(lái)補(bǔ)全一行最后可能缺失的單元格
 private String maxRef = null;
 
 /**
  * 單元格
  */
 private StylesTable stylesTable;
 
 /**
  * 遍歷工作簿中所有的電子表格
  * 并緩存在mySheetList中
  *
  * @param filename
  * @throws Exception
  */
 public int process(String filename) throws Exception {
  filePath = filename;
  OPCPackage pkg = OPCPackage.open(filename);
  XSSFReader xssfReader = new XSSFReader(pkg);
  stylesTable = xssfReader.getStylesTable();
  SharedStringsTable sst = xssfReader.getSharedStringsTable();
  XMLReader parser = XMLReaderFactory.createXMLReader("org.apache.xerces.parsers.SAXParser");
  this.sst = sst;
  parser.setContentHandler(this);
  XSSFReader.SheetIterator sheets = (XSSFReader.SheetIterator) xssfReader.getSheetsData();
  while (sheets.hasNext()) { //遍歷sheet
   curRow = 1; //標(biāo)記初始行為第一行
   sheetIndex++;
   InputStream sheet = sheets.next(); //sheets.next()和sheets.getSheetName()不能換位置,否則sheetName報(bào)錯(cuò)
   sheetName = sheets.getSheetName();
   InputSource sheetSource = new InputSource(sheet);
   parser.parse(sheetSource); //解析excel的每條記錄,在這個(gè)過(guò)程中startElement()、characters()、endElement()這三個(gè)函數(shù)會(huì)依次執(zhí)行
   sheet.close();
  }
  return totalRows; //返回該excel文件的總行數(shù),不包括首列和空行
 }
 
 public List<List<String>> process(InputStream in) throws Exception {
  //filePath = filename;
  OPCPackage pkg = OPCPackage.open(in);
  XSSFReader xssfReader = new XSSFReader(pkg);
  stylesTable = xssfReader.getStylesTable();
  SharedStringsTable sst = xssfReader.getSharedStringsTable();
  //XMLReader parser = XMLReaderFactory.createXMLReader("org.apache.xerces.parsers.SAXParser");
  XMLReader parser = XMLReaderFactory.createXMLReader();
  this.sst = sst;
  parser.setContentHandler(this);
  XSSFReader.SheetIterator sheets = (XSSFReader.SheetIterator) xssfReader.getSheetsData();
  while (sheets.hasNext()) { //遍歷sheet
   curRow = 1; //標(biāo)記初始行為第一行
   sheetIndex++;
   InputStream sheet = sheets.next(); //sheets.next()和sheets.getSheetName()不能換位置,否則sheetName報(bào)錯(cuò)
   sheetName = sheets.getSheetName();
   InputSource sheetSource = new InputSource(sheet);
   parser.parse(sheetSource); //解析excel的每條記錄,在這個(gè)過(guò)程中startElement()、characters()、endElement()這三個(gè)函數(shù)會(huì)依次執(zhí)行
   sheet.close();
  }
  return dataList;
 }
 
 /**
  * 第一個(gè)執(zhí)行
  *
  * @param uri
  * @param localName
  * @param name
  * @param attributes
  * @throws SAXException
  */
 @Override
 public void startElement(String uri, String localName, String name, Attributes attributes) throws SAXException {
  //c => 單元格
  if ("c".equals(name)) {
 
   //前一個(gè)單元格的位置
   if (preRef == null) {
    preRef = attributes.getValue("r");
 
   } else {
    //中部文本空單元格標(biāo)識(shí) ‘endElementFlag' 判斷前一次是否為文本空字符串,true則表明不是文本空字符串,false表明是文本空字符串跳過(guò)把空字符串的位置賦予preRef
    if (endElementFlag){
     preRef = ref;
    }
   }
 
   //當(dāng)前單元格的位置
   ref = attributes.getValue("r");
   //首部文本空單元格標(biāo)識(shí) ‘startElementFlag' 判斷前一次,即首部是否為文本空字符串,true則表明不是文本空字符串,false表明是文本空字符串, 且已知當(dāng)前格,即第二格帶“B”標(biāo)志,則ref賦予preRef
   if (!startElementFlag && !flag){ //上一個(gè)單元格為文本空單元格,執(zhí)行下面的,使ref=preRef;flag為true表明該單元格之前有數(shù)據(jù)值,即該單元格不是首部空單元格,則跳過(guò)
    // 這里只有上一個(gè)單元格為文本空單元格,且之前的幾個(gè)單元格都沒有值才會(huì)執(zhí)行
    preRef = ref;
   }
 
   //設(shè)定單元格類型
   this.setNextDataType(attributes);
   endElementFlag = false;
   charactersFlag = false;
   startElementFlag = false;
  }
 
  //當(dāng)元素為t時(shí)
  if ("t".equals(name)) {
   isTElement = true;
  } else {
   isTElement = false;
  }
 
  //置空
  lastIndex = "";
 }
 
 
 
 /**
  * 第二個(gè)執(zhí)行
  * 得到單元格對(duì)應(yīng)的索引值或是內(nèi)容值
  * 如果單元格類型是字符串、INLINESTR、數(shù)字、日期,lastIndex則是索引值
  * 如果單元格類型是布爾值、錯(cuò)誤、公式,lastIndex則是內(nèi)容值
  * @param ch
  * @param start
  * @param length
  * @throws SAXException
  */
 @Override
 public void characters(char[] ch, int start, int length) throws SAXException {
  startElementFlag = true;
  charactersFlag = true;
  lastIndex += new String(ch, start, length);
 }
 
 /**
  * 第三個(gè)執(zhí)行
  *
  * @param uri
  * @param localName
  * @param name
  * @throws SAXException
  */
 @Override
 public void endElement(String uri, String localName, String name) throws SAXException {
  //t元素也包含字符串
  if (isTElement) {
   //將單元格內(nèi)容加入rowlist中,在這之前先去掉字符串前后的空白符
   String value = lastIndex.trim();
   cellList.add(curCol, value);
   endElementFlag = true;
   curCol++;
   isTElement = false;
   //如果里面某個(gè)單元格含有值,則標(biāo)識(shí)該行不為空行
   if (value != null && !"".equals(value)) {
    flag = true;
   }
  } else if ("v".equals(name)) {
   //v => 單元格的值,如果單元格是字符串,則v標(biāo)簽的值為該字符串在SST中的索引
   String value = this.getDataValue(lastIndex.trim(), "");//根據(jù)索引值獲取對(duì)應(yīng)的單元格值
 
   //補(bǔ)全單元格之間的空單元格
   if (!ref.equals(preRef)) {
    int len = countNullCell(ref, preRef);
    for (int i = 0; i < len; i++) {
     cellList.add(curCol, "");
     curCol++;
    }
   } else if (ref.equals(preRef) && !ref.startsWith("A")){ //ref等于preRef,且以B或者C...開頭,表明首部為空格
    int len = countNullCell(ref, "A");
    for (int i = 0; i <= len; i++) {
     cellList.add(curCol, "");
     curCol++;
    }
   }
   cellList.add(curCol, value);
   curCol++;
   endElementFlag = true;
   //如果里面某個(gè)單元格含有值,則標(biāo)識(shí)該行不為空行
   if (value != null && !"".equals(value)) {
    flag = true;
   }
  } else {
   //如果標(biāo)簽名稱為row,這說(shuō)明已到行尾,調(diào)用optRows()方法
   if ("row".equals(name)) {
    //默認(rèn)第一行為表頭,以該行單元格數(shù)目為最大數(shù)目
    if (curRow == 1) {
     maxRef = ref;
    }
    //補(bǔ)全一行尾部可能缺失的單元格
    if (maxRef != null) {
     int len = -1;
     //前一單元格,true則不是文本空字符串,false則是文本空字符串
     if (charactersFlag){
      len = countNullCell(maxRef, ref);
     }else {
      len = countNullCell(maxRef, preRef);
     }
     for (int i = 0; i <= len; i++) {
      cellList.add(curCol, "");
      curCol++;
     }
    }
 
    if (flag&&curRow!=1){ //該行不為空行且該行不是第一行,則發(fā)送(第一行為列名,不需要)
     //ExcelReaderUtil.sendRows(filePath, sheetName, sheetIndex, curRow, cellList);
     totalRows++;
     //添加到數(shù)據(jù)集合中
     dataList.add(cellList);
    }
 
    //清空容器
    cellList = new ArrayList<String>(); 
    //cellList.clear();
    curRow++;
    curCol = 0;
    preRef = null;
    prePreRef = null;
    ref = null;
    flag=false;
   }
  }
 }
 
 /**
  * 處理數(shù)據(jù)類型
  *
  * @param attributes
  */
 public void setNextDataType(Attributes attributes) {
  nextDataType = CellDataType.NUMBER; //cellType為空,則表示該單元格類型為數(shù)字
  formatIndex = -1;
  formatString = null;
  String cellType = attributes.getValue("t"); //單元格類型
  String cellStyleStr = attributes.getValue("s"); //
  String columnData = attributes.getValue("r"); //獲取單元格的位置,如A1,B1
 
  if ("b".equals(cellType)) { //處理布爾值
   nextDataType = CellDataType.BOOL;
  } else if ("e".equals(cellType)) { //處理錯(cuò)誤
   nextDataType = CellDataType.ERROR;
  } else if ("inlineStr".equals(cellType)) {
   nextDataType = CellDataType.INLINESTR;
  } else if ("s".equals(cellType)) { //處理字符串
   nextDataType = CellDataType.SSTINDEX;
  } else if ("str".equals(cellType)) {
   nextDataType = CellDataType.FORMULA;
  }
 
  if (cellStyleStr != null) { //處理日期
   int styleIndex = Integer.parseInt(cellStyleStr);
   XSSFCellStyle style = stylesTable.getStyleAt(styleIndex);
   formatIndex = style.getDataFormat();
   formatString = style.getDataFormatString();
   if (formatString.contains("m/d/yyyy") || formatString.contains("yyyy/mm/dd")|| formatString.contains("yyyy/m/d") ) {
    nextDataType = CellDataType.DATE;
    formatString = "yyyy-MM-dd hh:mm:ss";
   }
 
   if (formatString == null) {
    nextDataType = CellDataType.NULL;
    formatString = BuiltinFormats.getBuiltinFormat(formatIndex);
   }
  }
 }
 
 /**
  * 對(duì)解析出來(lái)的數(shù)據(jù)進(jìn)行類型處理
  * @param value 單元格的值,
  *    value代表解析:BOOL的為0或1, ERROR的為內(nèi)容值,F(xiàn)ORMULA的為內(nèi)容值,INLINESTR的為索引值需轉(zhuǎn)換為內(nèi)容值,
  *    SSTINDEX的為索引值需轉(zhuǎn)換為內(nèi)容值, NUMBER為內(nèi)容值,DATE為內(nèi)容值
  * @param thisStr 一個(gè)空字符串
  * @return
  */
 @SuppressWarnings("deprecation")
 public String getDataValue(String value, String thisStr) {
  switch (nextDataType) {
   // 這幾個(gè)的順序不能隨便交換,交換了很可能會(huì)導(dǎo)致數(shù)據(jù)錯(cuò)誤
   case BOOL: //布爾值
    char first = value.charAt(0);
    thisStr = first == '0' ? "FALSE" : "TRUE";
    break;
   case ERROR: //錯(cuò)誤
    thisStr = "\"ERROR:" + value.toString() + '"';
    break;
   case FORMULA: //公式
    thisStr = '"' + value.toString() + '"';
    break;
   case INLINESTR:
    XSSFRichTextString rtsi = new XSSFRichTextString(value.toString());
    thisStr = rtsi.toString();
    rtsi = null;
    break;
   case SSTINDEX: //字符串
    String sstIndex = value.toString();
    try {
     int idx = Integer.parseInt(sstIndex);
     XSSFRichTextString rtss = new XSSFRichTextString(sst.getEntryAt(idx));//根據(jù)idx索引值獲取內(nèi)容值
     thisStr = rtss.toString();
     //System.out.println(thisStr);
     //有些字符串是文本格式的,但內(nèi)容卻是日期
 
     rtss = null;
    } catch (NumberFormatException ex) {
     thisStr = value.toString();
    }
    break;
   case NUMBER: //數(shù)字
    if (formatString != null) {
     thisStr = formatter.formatRawCellContents(Double.parseDouble(value), formatIndex, formatString).trim();
    } else {
     thisStr = value;
    }
    thisStr = thisStr.replace("_", "").trim();
    break;
   case DATE: //日期
    thisStr = formatter.formatRawCellContents(Double.parseDouble(value), formatIndex, formatString);
    // 對(duì)日期字符串作特殊處理,去掉T
    thisStr = thisStr.replace("T", " ");
    break;
   default:
    thisStr = " ";
    break;
  }
  return thisStr;
 }
 
 public int countNullCell(String ref, String preRef) {
  //excel2007最大行數(shù)是1048576,最大列數(shù)是16384,最后一列列名是XFD
  String xfd = ref.replaceAll("\\d+", "");
  String xfd_1 = preRef.replaceAll("\\d+", "");
 
  xfd = fillChar(xfd, 3, '@', true);
  xfd_1 = fillChar(xfd_1, 3, '@', true);
 
  char[] letter = xfd.toCharArray();
  char[] letter_1 = xfd_1.toCharArray();
  int res = (letter[0] - letter_1[0]) * 26 * 26 + (letter[1] - letter_1[1]) * 26 + (letter[2] - letter_1[2]);
  return res - 1;
 }
 
 public String fillChar(String str, int len, char let, boolean isPre) {
  int len_1 = str.length();
  if (len_1 < len) {
   if (isPre) {
    for (int i = 0; i < (len - len_1); i++) {
     str = let + str;
    }
   } else {
    for (int i = 0; i < (len - len_1); i++) {
     str = str + let;
    }
   }
  }
  return str;
 }
 
 /**
  * @return the exceptionMessage
  */
 public String getExceptionMessage() {
  return exceptionMessage;
 }
}

讀取工具類:

import java.io.InputStream;
import java.util.List;
 
public class ExcelReaderUtil {
 
 //excel2003擴(kuò)展名
 public static final String EXCEL03_EXTENSION = ".xls";
 //excel2007擴(kuò)展名
 public static final String EXCEL07_EXTENSION = ".xlsx";
 
 //讀取xls格式
 public static List<List<String>> readExcelXls(InputStream in) throws Exception {
  ExcelXlsReader excelXls=new ExcelXlsReader();
  List<List<String>> dataList =excelXls.process(in);
  return dataList;
 }
 
 //讀取xlsx格式
 public static List<List<String>> readExcelXlsx(InputStream in) throws Exception {
  ExcelXlsxReader excelXls=new ExcelXlsxReader();
  List<List<String>> dataList =excelXls.process(in);
  return dataList;
 }
 
 public static void readExcel(String fileName) throws Exception {
  int totalRows =0;
  if (fileName.endsWith(EXCEL03_EXTENSION)) { //處理excel2003文件
   ExcelXlsReader excelXls=new ExcelXlsReader();
   totalRows =excelXls.process(fileName);
  } else if (fileName.endsWith(EXCEL07_EXTENSION)) {//處理excel2007文件
   ExcelXlsxReader excelXlsxReader = new ExcelXlsxReader();
   totalRows = excelXlsxReader.process(fileName);
  } else {
   throw new Exception("文件格式錯(cuò)誤,fileName的擴(kuò)展名只能是xls或xlsx。");
  }
  System.out.println("發(fā)送的總行數(shù):" + totalRows);
 }
 
 public static void main(String[] args) throws Exception {
  String path="C:\\test.xlsx";
  ExcelReaderUtil.readExcel(path);
 }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android內(nèi)存泄漏實(shí)戰(zhàn)解析

    Android內(nèi)存泄漏實(shí)戰(zhàn)解析

    Java是垃圾回收語(yǔ)言的一種。這篇文章主要介紹了Android內(nèi)存泄漏 的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • springboot配置文件讀取pom文件信息方式

    springboot配置文件讀取pom文件信息方式

    這篇文章主要介紹了springboot配置文件讀取pom文件信息方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • 基于spring實(shí)現(xiàn)websocket實(shí)時(shí)推送實(shí)例

    基于spring實(shí)現(xiàn)websocket實(shí)時(shí)推送實(shí)例

    這篇文章主要為大家詳細(xì)介紹了基于spring實(shí)現(xiàn)websocket實(shí)時(shí)推送實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • HashMap vs TreeMap vs Hashtable vs LinkedHashMap

    HashMap vs TreeMap vs Hashtable vs LinkedHashMap

    這篇文章主要介紹了HashMap vs TreeMap vs Hashtable vs LinkedHashMap的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • IntelliJ IDEA中如何調(diào)試Java Stream操作

    IntelliJ IDEA中如何調(diào)試Java Stream操作

    這篇文章主要介紹了IntelliJ IDEA中如何優(yōu)雅的調(diào)試Java Stream操作,在強(qiáng)大的IDEA插件支持下,stream的調(diào)試其實(shí)也沒那么難了,下面就來(lái)學(xué)習(xí)一下在IDEA中如何調(diào)試stream操作吧
    2022-05-05
  • 使用Nexus搭建Maven私服的方法步驟

    使用Nexus搭建Maven私服的方法步驟

    這篇文章主要介紹了使用Nexus搭建Maven私服的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • SpringBoot整合RocketMQ實(shí)現(xiàn)消息發(fā)送和接收的詳細(xì)步驟

    SpringBoot整合RocketMQ實(shí)現(xiàn)消息發(fā)送和接收的詳細(xì)步驟

    這篇文章主要介紹了SpringBoot整合RocketMQ實(shí)現(xiàn)消息發(fā)送和接收功能,我們使用主流的SpringBoot框架整合RocketMQ來(lái)講解,使用方便快捷,本文分步驟給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-08-08
  • 5分鐘快速學(xué)會(huì)spring boot整合JdbcTemplate的方法

    5分鐘快速學(xué)會(huì)spring boot整合JdbcTemplate的方法

    這篇文章主要給大家介紹了如何通過(guò)5分鐘快速學(xué)會(huì)spring boot整合JdbcTemplate的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用spring boot整合JdbcTemplate具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 使用Java手搓一個(gè)控制臺(tái)進(jìn)度條打印工具

    使用Java手搓一個(gè)控制臺(tái)進(jìn)度條打印工具

    這篇文章主要為大家詳細(xì)介紹了如何使用Java手搓一個(gè)控制臺(tái)進(jìn)度條打印工具,文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2025-04-04
  • SpringBoot框架集成token實(shí)現(xiàn)登錄校驗(yàn)功能

    SpringBoot框架集成token實(shí)現(xiàn)登錄校驗(yàn)功能

    這篇文章主要為大家詳細(xì)介紹了SpringBoot框架集成token實(shí)現(xiàn)登錄校驗(yàn)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08

最新評(píng)論

AV天堂一区二区免费试看| 日本免费视频午夜福利视频| 亚洲自拍偷拍综合色| 亚洲成人黄色一区二区三区| 97人妻夜夜爽二区欧美极品| 日韩熟女系列一区二区三区| 亚洲护士一区二区三区| 自拍 日韩 欧美激情| 久草免费人妻视频在线| 青青在线视频性感少妇和隔壁黑丝 | 天天干天天操天天扣| 日本熟妇喷水xxx| 久久久久久久久久一区二区三区| 在线新三级黄伊人网| 欧洲亚洲欧美日韩综合| 青青尤物在线观看视频网站| 精品av国产一区二区三区四区| 色av色婷婷人妻久久久精品高清| 香蕉91一区二区三区| 91福利在线视频免费观看| 一区二区三区av高清免费| 欧美日韩不卡一区不区二区| 毛茸茸的大外阴中国视频| 老司机午夜精品视频资源| 久草视频在线一区二区三区资源站| 福利视频一区二区三区筱慧| 午夜极品美女福利视频| 天天躁日日躁狠狠躁躁欧美av| 亚洲精品国品乱码久久久久| 午夜精品在线视频一区| 国产精品入口麻豆啊啊啊 | 欧洲亚洲欧美日韩综合| 韩国AV无码不卡在线播放| 99热99这里精品6国产| 国产91嫩草久久成人在线视频| 成年午夜免费无码区| 日本午夜爽爽爽爽爽视频在线观看| 大香蕉大香蕉大香蕉大香蕉大香蕉| 亚洲欧美清纯唯美另类| 欧美国品一二三产区区别| 最新激情中文字幕视频| 青青青青操在线观看免费| 午夜激情精品福利视频| 精品一区二区亚洲欧美| 国产欧美精品免费观看视频| 97人妻色免费视频| 亚洲精品无码久久久久不卡| weyvv5国产成人精品的视频| 色婷婷久久久久swag精品| 青草亚洲视频在线观看| 日韩欧美国产精品91| 天天日天天操天天摸天天舔| 青青草成人福利电影| 亚洲中文字幕人妻一区| 免费在线播放a级片| 伊人情人综合成人久久网小说 | 国产污污污污网站在线| gav成人免费播放| 国产在线免费观看成人| 啪啪啪操人视频在线播放| 女生自摸在线观看一区二区三区| 欧美性感尤物人妻在线免费看| 最近中文2019年在线看| 欧美在线一二三视频| 精品久久久久久久久久中文蒉| 国产成人精品久久二区91| 青青青视频手机在线观看| 国产91久久精品一区二区字幕| 99热久久这里只有精品| av资源中文字幕在线观看| 插逼视频双插洞国产操逼插洞| 亚洲高清免费在线观看视频| 成年午夜影片国产片| 欧美精品黑人性xxxx| 成人高潮aa毛片免费| 欧美麻豆av在线播放| 91色老99久久九九爱精品| 日韩伦理短片在线观看| 99热久久这里只有精品| 免费观看成年人视频在线观看 | 久久久久久久精品老熟妇| 91精品资源免费观看| 欧美黑人巨大性xxxxx猛交| 久久久制服丝袜中文字幕| 精品一区二区亚洲欧美| 国产性生活中老年人视频网站| 欧美日韩熟女一区二区三区| 2022中文字幕在线| 中文字幕av熟女人妻| 亚洲成人av一区久久| 五月色婷婷综合开心网4438| 国产精品国产三级国产精东| 哥哥姐姐综合激情小说| 中文字幕之无码色多多| 91综合久久亚洲综合| 天天操天天干天天日狠狠插| 亚洲成人三级在线播放 | 国产在线免费观看成人| 一区二区三区麻豆福利视频| 美女被肏内射视频网站| 中文字幕高清在线免费播放| 不卡一不卡二不卡三| 性色av一区二区三区久久久| 姐姐的朋友2在线观看中文字幕| 青青青青青青草国产| 免费国产性生活视频| 把腿张开让我插进去视频| 在线观看免费视频色97| 亚洲高清免费在线观看视频| 国产黄网站在线观看播放| 国产精品三级三级三级| 在线观看视频污一区| 1024久久国产精品| 欧美区一区二区三视频| 少妇一区二区三区久久久| 国产一级麻豆精品免费| 成人久久精品一区二区三区| 97精品视频在线观看| 狠狠操操操操操操操操操| 青青草原色片网站在线观看| 性感美女高潮视频久久久| 欧美伊人久久大香线蕉综合| 欧美香蕉人妻精品一区二区| 亚洲一区二区三区五区| 亚洲综合另类欧美久久| 中国熟女@视频91| 日本一道二三区视频久久| 免费成人va在线观看| 国产精品人妻66p| 国内精品在线播放第一页| 亚洲国产精品免费在线观看| 人妻少妇亚洲一区二区| 中文字幕中文字幕人妻| 人妻少妇一区二区三区蜜桃| av日韩在线观看大全| www天堂在线久久| 天堂av在线最新版在线| 18禁无翼鸟成人在线| 色av色婷婷人妻久久久精品高清| 久久香蕉国产免费天天| 青青青青在线视频免费观看| 91精品高清一区二区三区| 精品黑人巨大在线一区| 国产精品午夜国产小视频| 国产综合视频在线看片| 亚洲超碰97人人做人人爱| 啪啪啪啪啪啪啪免费视频| 国产高清在线观看1区2区| 红桃av成人在线观看| 国产自拍在线观看成人| 十八禁在线观看地址免费| 亚洲在线观看中文字幕av| 另类av十亚洲av| 黄色在线观看免费观看在线| 女蜜桃臀紧身瑜伽裤| 中文字幕亚洲久久久| 香蕉aⅴ一区二区三区| 视频 一区二区在线观看| 亚洲一区二区三区久久午夜| 免费黄页网站4188| 91免费黄片可看视频| 成人蜜桃美臀九一一区二区三区| 久久久久久久久久久免费女人| 成人国产激情自拍三区| 一本久久精品一区二区| 专门看国产熟妇的网站| 青青草亚洲国产精品视频| 熟女在线视频一区二区三区| 国产视频一区在线观看| 欧美80老妇人性视频| 美女被肏内射视频网站| 美女操逼免费短视频下载链接| 少妇一区二区三区久久久| 人人妻人人爽人人澡人人精品| 大屁股肉感人妻中文字幕在线| 一区二区三区视频,福利一区二区| 97超碰国语国产97超碰| 97色视频在线观看| 久久久久久性虐视频| av男人天堂狠狠干| 五十路熟女人妻一区二区9933| 五十路息与子猛烈交尾视频| 成人24小时免费视频| 一区二区三区国产精选在线播放| 中文字幕在线视频一区二区三区 | 中国黄色av一级片| 亚洲午夜电影之麻豆 | 日韩近亲视频在线观看| 亚洲麻豆一区二区三区| 亚洲av日韩高清hd| 亚洲在线免费h观看网站| 天天综合天天综合天天网| 美女日逼视频免费观看| 精品久久婷婷免费视频| 亚洲成人av一区在线| 亚洲2021av天堂| 国产一区二区神马久久| 中文字幕成人日韩欧美| 精品日产卡一卡二卡国色天香| 一级黄色av在线观看| 国产日韩精品免费在线| 神马午夜在线观看视频| 天天干狠狠干天天操| 免费福利av在线一区二区三区| 阿v天堂2014 一区亚洲| 亚洲va欧美va人人爽3p| 99久久久无码国产精品性出奶水 | 啊啊啊想要被插进去视频| 91大神福利视频网| 自拍偷拍一区二区三区图片| 亚洲激情,偷拍视频| 国产夫妻视频在线观看免费 | 99精品免费观看视频| 激情人妻校园春色亚洲欧美| www日韩毛片av| 女人精品内射国产99| 少妇与子乱在线观看| 青青草精品在线视频观看| 青青青青青青草国产| 亚洲福利精品福利精品福利| 国产福利小视频二区| 男人天堂色男人av| 人妻凌辱欧美丰满熟妇| 亚洲激情偷拍一区二区| 国产福利在线视频一区| 亚洲欧美自拍另类图片| 亚洲av自拍天堂网| 精品久久久久久久久久久a√国产| 曰本无码人妻丰满熟妇啪啪| 午夜免费观看精品视频| 国产视频在线视频播放| 韩国男女黄色在线观看| 国产+亚洲+欧美+另类| 人妻久久无码中文成人| 男女之间激情网午夜在线| 欧美日本国产自视大全| 老熟妇xxxhd老熟女| 久久精品亚洲国产av香蕉| 日韩加勒比东京热二区| 激情人妻校园春色亚洲欧美| 亚洲中文字字幕乱码| 夏目彩春在线中文字幕| 亚洲人妻视频在线网| 亚洲天堂有码中文字幕视频| 人妻少妇av在线观看| 国产之丝袜脚在线一区二区三区| 日韩国产乱码中文字幕| 日本又色又爽又黄又粗| 亚洲福利精品视频在线免费观看| 4个黑人操素人视频网站精品91| 一区二区三区日本伦理| 99热久久这里只有精品| caoporm超碰国产| 免费在线观看视频啪啪| 区一区二区三国产中文字幕| 国产在线观看黄色视频| 福利片区一区二体验区| 沙月文乃人妻侵犯中文字幕在线 | 在线免费观看视频一二区| 91精品免费久久久久久| 亚洲午夜电影之麻豆| 最新国产精品网址在线观看| 天天日天天摸天天爱| 天天日天天摸天天爱| 伊人成人综合开心网| 成人在线欧美日韩国产| 99av国产精品欲麻豆| 日韩国产乱码中文字幕| 亚洲久久午夜av一区二区| 偷拍美女一区二区三区| 国产日韩av一区二区在线| 亚洲综合图片20p| 亚洲天堂精品久久久| 人妻丝袜av在线播放网址| 国产视频一区在线观看| 午夜国产免费福利av| 人妻无码中文字幕专区| 超pen在线观看视频公开97| 久久久久久九九99精品| 婷婷久久久综合中文字幕| 青青草人人妻人人妻| 国产性生活中老年人视频网站| 日韩一区二区电国产精品| 涩涩的视频在线观看视频| 一区二区在线视频中文字幕| 可以在线观看的av中文字幕| 人妻少妇性色欲欧美日韩| 天天日天天敢天天干| 青春草视频在线免费播放| 视频二区在线视频观看| 亚洲av男人的天堂你懂的| 在线观看一区二区三级| 2021国产一区二区| 3344免费偷拍视频| 沙月文乃人妻侵犯中文字幕在线| 国产品国产三级国产普通话三级| 国产亚洲天堂天天一区| 福利在线视频网址导航| 久久午夜夜伦痒痒想咳嗽P| 亚洲午夜伦理视频在线 | 欧美精品一二三视频| 国产 在线 免费 精品| 国产女人被做到高潮免费视频| xxx日本hd高清| 日本18禁久久久久久| 欧美女同性恋免费a| 亚洲2021av天堂| 人人妻人人爽人人澡人人精品| 97色视频在线观看| 欧洲亚洲欧美日韩综合| 熟女91pooyn熟女| 另类av十亚洲av| 午夜精品在线视频一区| 欧美日韩情色在线观看| 黑人大几巴狂插日本少妇| 色综合久久五月色婷婷综合 | 国产在线一区二区三区麻酥酥| 国产精品自拍视频大全| 欧美中国日韩久久精品| 亚洲在线观看中文字幕av| 欧美中文字幕一区最新网址| 100%美女蜜桃视频| 晚上一个人看操B片| 欧美精产国品一二三产品价格| 超级碰碰在线视频免费观看| 91快播视频在线观看| 性色蜜臀av一区二区三区| 少妇高潮无套内谢麻豆| 无码国产精品一区二区高潮久久4| 五十路熟女人妻一区二区9933| 嫩草aⅴ一区二区三区| 亚洲人妻视频在线网| 久久久久久性虐视频| 视频啪啪啪免费观看| 老鸭窝日韩精品视频观看| 中文字幕av一区在线观看| 日韩激情文学在线视频| 亚洲卡1卡2卡三卡四老狼| 晚上一个人看操B片| 一色桃子人妻一区二区三区| 激情五月婷婷免费视频| 91老师蜜桃臀大屁股| 1769国产精品视频免费观看| 亚洲女人的天堂av| 天天摸天天日天天操| 国产精品手机在线看片| 91中文字幕免费在线观看| 中国无遮挡白丝袜二区精品| 天堂av狠狠操蜜桃| 99热国产精品666| 精品亚洲在线免费观看| 亚洲av午夜免费观看| 老有所依在线观看完整版| 天天操天天干天天插| 国产性色生活片毛片春晓精品| 亚洲成人av一区在线| 日韩伦理短片在线观看| 青青青国产片免费观看视频| 一区二区三区另类在线| 国产日韩av一区二区在线| 极品性荡少妇一区二区色欲| 色伦色伦777国产精品| 午夜精品一区二区三区福利视频| 女生自摸在线观看一区二区三区| 2o22av在线视频| 视频二区在线视频观看| 一区二区视频在线观看免费观看 | 亚国产成人精品久久久| 激情综合治理六月婷婷| 午夜在线观看岛国av,com| 免费费一级特黄真人片| 亚洲天堂成人在线观看视频网站| 中国产一级黄片免费视频播放| 美女福利写真在线观看视频| 国产女人被做到高潮免费视频| 99精品视频之69精品视频 | 亚洲国产免费av一区二区三区| 青青草原色片网站在线观看| 在线观看亚洲人成免费网址| 亚洲一区二区三区在线高清| 黑人变态深video特大巨大| av天堂加勒比在线| 亚洲丝袜老师诱惑在线观看| 国产三级精品三级在线不卡| 最近的中文字幕在线mv视频| 午夜精品一区二区三区福利视频| 国产精品欧美日韩区二区| 美日韩在线视频免费看| 午夜久久香蕉电影网| 91片黄在线观看喷潮| 激情伦理欧美日韩中文字幕| 国产av一区2区3区| 黄色片黄色片wyaa| 家庭女教师中文字幕在线播放 | 国产一线二线三线的区别在哪 | 久久机热/这里只有| 黄色男人的天堂视频| tube69日本少妇| 日韩欧美在线观看不卡一区二区| 精品视频国产在线观看| 欧美视频不卡一区四区| 丰满少妇翘臀后进式| 天美传媒mv视频在线观看| 亚洲精品高清自拍av| 三上悠亚和黑人665番号| 亚洲免费成人a v| 美女骚逼日出水来了| 精产国品久久一二三产区区别| 精品91高清在线观看| 欧美中文字幕一区最新网址| 中国黄片视频一区91| 最新国产亚洲精品中文在线| 欧美一区二区三区乱码在线播放| 国产中文字幕四区在线观看| 五十路丰满人妻熟妇| 亚洲日本一区二区三区| 狠狠操狠狠操免费视频| 初美沙希中文字幕在线| 日本午夜爽爽爽爽爽视频在线观看| 国产一区二区在线欧美| 青青青激情在线观看视频| 男人的天堂一区二区在线观看| 精品首页在线观看视频| 中文字幕一区二区三区人妻大片| 中国无遮挡白丝袜二区精品| 日韩人妻在线视频免费| 日本精品美女在线观看| 91精品国产综合久久久蜜| 美女骚逼日出水来了| 青青尤物在线观看视频网站| 免费手机黄页网址大全| 亚洲成a人片777777| 区一区二区三国产中文字幕| 99热色原网这里只有精品| 精品一区二区三区午夜| 传媒在线播放国产精品一区| 国产又粗又猛又爽又黄的视频美国| 国产97在线视频观看| 神马午夜在线观看视频| 日韩三级黄色片网站| 麻豆精品成人免费视频| 成人av在线资源网站| 男大肉棒猛烈插女免费视频| 国产高清女主播在线| 亚洲蜜臀av一区二区三区九色| 黑人解禁人妻叶爱071| 亚洲视频乱码在线观看| 国产麻豆乱子伦午夜视频观看| 一区二区三区另类在线 | 亚洲精品福利网站图片| 国产精品精品精品999| 久久精品36亚洲精品束缚| 偷拍美女一区二区三区| 蜜桃专区一区二区在线观看| 天天射夜夜操狠狠干| 护士小嫩嫩又紧又爽20p| 91极品大一女神正在播放| 国产久久久精品毛片| 精品国产成人亚洲午夜| 午夜精品一区二区三区城中村| 亚洲另类图片蜜臀av| 黄页网视频在线免费观看| 亚洲综合另类精品小说| 日韩欧美中文国产在线 | 亚洲 欧美 精品 激情 偷拍| 欧亚乱色一区二区三区| 午夜久久久久久久99| 把腿张开让我插进去视频| 国产大鸡巴大鸡巴操小骚逼小骚逼| 成人H精品动漫在线无码播放| 日本女大学生的黄色小视频| 国产又粗又黄又硬又爽| 狠狠躁夜夜躁人人爽天天天天97| 55夜色66夜色国产精品站| 绝顶痉挛大潮喷高潮无码| 黄色黄色黄片78在线| 亚洲一级美女啪啪啪| 中文字幕无码日韩专区免费| 水蜜桃一区二区三区在线观看视频| 日韩加勒比东京热二区| 孕妇奶水仑乱A级毛片免费看| 亚洲最大黄了色网站| 日辽宁老肥女在线观看视频| 青青热久免费精品视频在线观看| 性欧美激情久久久久久久| 亚洲蜜臀av一区二区三区九色 | 玩弄人妻熟妇性色av少妇| 成年午夜免费无码区| 老司机免费视频网站在线看| 青青青aaaa免费| 欧美中文字幕一区最新网址| 91试看福利一分钟| 国产精品视频一区在线播放| 高清一区二区欧美系列| 熟女在线视频一区二区三区| 91国偷自产一区二区三区精品| 首之国产AV医生和护士小芳| 一色桃子人妻一区二区三区| 精品国产高潮中文字幕| 九色精品视频在线播放| 亚洲av成人免费网站| 精品一区二区亚洲欧美| 天天干天天日天天干天天操| 红杏久久av人妻一区| 久久久久久97三级| 国产亚洲精品欧洲在线观看| 伊人综合免费在线视频| 国产精品精品精品999| 性生活第二下硬不起来| 97精品视频在线观看| 视频啪啪啪免费观看| 国产va在线观看精品| 边摸边做超爽毛片18禁色戒 | 国产黄色片在线收看| 精品一线二线三线日本| 亚洲高清一区二区三区视频在线| 亚洲一区二区三区uij| 亚洲卡1卡2卡三卡四老狼| 欧美中国日韩久久精品| 欧美一级色视频美日韩| 99视频精品全部15| 91在线视频在线精品3| 青青草精品在线视频观看| 99热碰碰热精品a中文| 天天干天天日天天谢综合156| 2022国产综合在线干| 大鸡巴操b视频在线| 大尺度激情四射网站| av视网站在线观看| 春色激情网欧美成人| 日韩写真福利视频在线观看| 夜色撩人久久7777| 国产精品伦理片一区二区| 午夜成午夜成年片在线观看| 中文字幕日韩无敌亚洲精品| 久久久久久99国产精品| 国产精品sm调教视频| 国产精品女邻居小骚货| 女生被男生插的视频网站| 欧美一区二区三区啪啪同性| av老司机精品在线观看| 最近中文字幕国产在线| 欧美特色aaa大片| 天天日天天摸天天爱| 2018在线福利视频| 亚洲欧美另类自拍偷拍色图| 最新的中文字幕 亚洲| 国产九色91在线视频| 绝顶痉挛大潮喷高潮无码| 中文字幕日韩精品日本| 91国内精品自线在拍白富美| 国产97在线视频观看| 91麻豆精品秘密入口在线观看| 操日韩美女视频在线免费看| 国产高清在线观看1区2区| 欧美综合婷婷欧美综合| 亚洲av午夜免费观看| 亚洲一级特黄特黄黄色录像片| 天天操天天操天天碰| 2020久久躁狠狠躁夜夜躁| 欧美成一区二区三区四区| 亚洲欧洲av天堂综合| 国产女人被做到高潮免费视频| 可以免费看的www视频你懂的 | 亚洲午夜福利中文乱码字幕| 免费在线播放a级片| 9色在线视频免费观看| 国产日韩一区二区在线看| 久久机热/这里只有| 黄色成年网站午夜在线观看| 国产片免费观看在线观看| 欧美 亚洲 另类综合| 亚洲精品麻豆免费在线观看 | 日韩欧美中文国产在线| 天天干天天操天天摸天天射| 日韩精品一区二区三区在线播放| tube69日本少妇| 久久久久久久久久久久久97| 日本一区精品视频在线观看| 少妇人妻二三区视频| 黄片三级三级三级在线观看| 亚洲激情唯美亚洲激情图片| 午夜极品美女福利视频| 播放日本一区二区三区电影| 午夜免费观看精品视频| 日本熟妇色熟妇在线观看| 蜜臀av久久久久久久| 国产女孩喷水在线观看| 亚洲av一妻不如妾| av网站色偷偷婷婷网男人的天堂| 一区二区麻豆传媒黄片| 日日操综合成人av| 日本午夜福利免费视频| 亚洲成人线上免费视频观看| av手机在线观播放网站| 超级碰碰在线视频免费观看| jiuse91九色视频| 午夜美女福利小视频| 亚洲成人激情视频免费观看了| 人妻熟女在线一区二区| 欧美美女人体视频一区| 亚洲欧美另类自拍偷拍色图| 少妇人妻真实精品视频| 综合激情网激情五月天| 搞黄色在线免费观看| 国内自拍第一页在线观看| 黄色男人的天堂视频| 青青草人人妻人人妻| 福利在线视频网址导航| 日本午夜爽爽爽爽爽视频在线观看| 欧美亚洲少妇福利视频| 欧美亚洲免费视频观看| 天堂女人av一区二区| 晚上一个人看操B片| 精品久久久久久高潮| eeuss鲁片一区二区三区| 在线不卡日韩视频播放| 黄色三级网站免费下载| 99久久成人日韩欧美精品| 91社福利《在线观看| 天天日天天舔天天射进去| 国产a级毛久久久久精品| 国产精彩对白一区二区三区| 日韩欧美亚洲熟女人妻| 啪啪啪啪啪啪啪啪av| 男大肉棒猛烈插女免费视频 | 91人妻人人做人人爽在线| 中文字幕在线观看国产片| 久久久精品999精品日本| 中国无遮挡白丝袜二区精品| 国产精品黄页网站视频| 国产91精品拍在线观看| 精品黑人一区二区三区久久国产| 18禁污污污app下载| 75国产综合在线视频| av网站色偷偷婷婷网男人的天堂| 国产成人一区二区三区电影网站| 日日日日日日日日夜夜夜夜夜夜| 又大又湿又爽又紧A视频| 亚洲国产欧美一区二区三区…| 精品91自产拍在线观看一区| 女人精品内射国产99| 在线国产精品一区二区三区| 一级黄片大鸡巴插入美女| 国产精品视频欧美一区二区| 亚洲欧美日韩视频免费观看| 亚洲精品乱码久久久久久密桃明| 超碰97人人做人人爱| 成人激情文学网人妻| 国产精品视频一区在线播放| 日本午夜久久女同精女女| 亚洲一区二区久久久人妻| 日韩av有码一区二区三区4| 成人蜜臀午夜久久一区| 黄网十四区丁香社区激情五月天| 亚洲一级av无码一级久久精品| 日本人妻少妇18—xx| 亚洲推理片免费看网站| 天天爽夜夜爽人人爽QC| 女警官打开双腿沦为性奴| 首之国产AV医生和护士小芳| 自拍偷拍日韩欧美亚洲| 日本阿v视频在线免费观看| 日韩美女精品视频在线观看网站| 国产亚洲四十路五十路| 国产成人精品亚洲男人的天堂| 国产麻豆乱子伦午夜视频观看| 在线免费观看黄页视频| 欧美精品 日韩国产| 亚洲高清国产一区二区三区| 99人妻视频免费在线| 99精品视频之69精品视频| 国产日本欧美亚洲精品视| 亚洲av日韩精品久久久| 欧美亚洲自偷自拍 在线| 国产高清精品极品美女| 男人天堂色男人av| 国产又粗又硬又大视频| 大肉大捧一进一出好爽在线视频| 欧美乱妇无乱码一区二区| 唐人色亚洲av嫩草| 亚洲综合一区二区精品久久| 91av中文视频在线| 国产福利小视频二区| 开心 色 六月 婷婷| 91色秘乱一区二区三区| 欧美精品欧美极品欧美视频| 92福利视频午夜1000看| av日韩在线观看大全| 成年美女黄网站18禁久久| 精品一区二区三区三区88| 日本后入视频在线观看| 亚洲国产欧美一区二区丝袜黑人| 天天干天天操天天扣| 久草视频在线一区二区三区资源站| 日本熟女精品一区二区三区| 中字幕人妻熟女人妻a62v网| 中文字幕之无码色多多| 天堂中文字幕翔田av| 色综合久久久久久久久中文| 中文字幕人妻三级在线观看| 亚洲va国产va欧美va在线| avjpm亚洲伊人久久| 国产一级麻豆精品免费| 91精品资源免费观看| 亚洲伊人久久精品影院一美女洗澡| 国产妇女自拍区在线观看 | av在线免费中文字幕| av久久精品北条麻妃av观看| 日韩a级精品一区二区| 亚洲国产欧美一区二区丝袜黑人| 国产亚洲天堂天天一区| 婷婷六月天中文字幕| 玖玖一区二区在线观看| 亚洲自拍偷拍精品网| 98视频精品在线观看| 男人和女人激情视频| www骚国产精品视频| 免费观看丰满少妇做受| 都市家庭人妻激情自拍视频| 欧洲精品第一页欧洲精品亚洲| 久久久91蜜桃精品ad| 性欧美激情久久久久久久| AV天堂一区二区免费试看| 成人精品视频99第一页| ka0ri在线视频| 人人人妻人人澡人人| 欧美一区二区三区久久久aaa| 国产免费av一区二区凹凸四季| 女警官打开双腿沦为性奴| 欧美黄色录像免费看的| 888欧美视频在线| 亚洲自拍偷拍综合色| 亚洲一区二区三区偷拍女厕91| 欧美3p在线观看一区二区三区| 91色秘乱一区二区三区| 狍和女人的王色毛片| 亚洲va国产va欧美精品88| 熟女少妇激情五十路| 中文字幕av第1页中文字幕| 欧美日本aⅴ免费视频| 国产麻豆国语对白露脸剧情| 天天干天天爱天天色| 欧美亚洲偷拍自拍色图| 欧美精产国品一二三区| 久久热这里这里只有精品| 青娱乐最新视频在线| 天天日天天敢天天干| 色综合久久五月色婷婷综合| 国内资源最丰富的网站| 欧美3p在线观看一区二区三区| 久久精品36亚洲精品束缚| 亚洲av日韩精品久久久久久hd| 国产精品一二三不卡带免费视频| 日韩av熟妇在线观看| 亚洲av日韩av网站| 国产真实乱子伦a视频| 又粗又长 明星操逼小视频| 青青草在观免费国产精品| 午夜国产福利在线观看| 伊人精品福利综合导航| 干逼又爽又黄又免费的视频| 天天色天天舔天天射天天爽| 二区中出在线观看老师 | 好男人视频在线免费观看网站| 啊用力插好舒服视频| 国际av大片在线免费观看| 中文字幕乱码av资源| 天堂女人av一区二区| 亚洲一区二区三区精品视频在线| 97青青青手机在线视频| 在线观看操大逼视频| 欧美黑人性猛交xxxxⅹooo| 18禁网站一区二区三区四区| 岛国av高清在线成人在线| 91老熟女连续高潮对白| 中文字幕在线观看极品视频| 鸡巴操逼一级黄色气| 少妇系列一区二区三区视频| 100%美女蜜桃视频| 午夜影院在线观看视频羞羞羞| 最新的中文字幕 亚洲| 亚洲综合乱码一区二区| 亚洲图片偷拍自拍区| 综合色区亚洲熟妇shxstz| 大香蕉玖玖一区2区| 亚洲精品av在线观看| 麻豆精品成人免费视频| 色吉吉影音天天干天天操| 夜夜骑夜夜操夜夜奸| 最新国产精品网址在线观看| 亚洲欧美日韩视频免费观看| 熟女妇女老妇一二三区| 夏目彩春在线中文字幕| 久久精品视频一区二区三区四区 | 亚洲国产精品久久久久久6| 日本性感美女三级视频| 欧美视频综合第一页| yellow在线播放av啊啊啊| 久久免看30视频口爆视频| 中文字幕国产专区欧美激情| 亚洲激情偷拍一区二区| 青青青青爽手机在线| 久久永久免费精品人妻专区| 涩爱综合久久五月蜜臀| 精品视频中文字幕在线播放| 国产密臀av一区二区三| 国产精品视频欧美一区二区| 欧美 亚洲 另类综合| 一级A一级a爰片免费免会员| 大鸡巴操娇小玲珑的女孩逼| 婷婷五月亚洲综合在线| 男人的天堂在线黄色| 色综合久久无码中文字幕波多| 天天做天天干天天操天天射| 国产精品福利小视频a| 中文字幕在线观看极品视频| 免费在线看的黄网站| 亚洲欧美人精品高清| 天天日天天鲁天天操| 男生舔女生逼逼视频| 99热久久极品热亚洲| 日韩少妇人妻精品无码专区| 特级无码毛片免费视频播放| 国产成人午夜精品福利| 同居了嫂子在线播高清中文| 免费国产性生活视频| 亚洲av一妻不如妾| 午夜激情久久不卡一区二区| 大鸡吧插逼逼视频免费看| 精品国产乱码一区二区三区乱| 青青在线视频性感少妇和隔壁黑丝| av天堂资源最新版在线看| 国产janese在线播放| 国产 在线 免费 精品| 国产视频一区二区午夜| 亚洲美女高潮喷浆视频| 亚洲精品久久综合久| 亚洲成人精品女人久久久| 最新欧美一二三视频 | 75国产综合在线视频| 国产精品视频资源在线播放 | 51国产成人精品视频| 在线国产中文字幕视频| 亚洲精品乱码久久久本| 免费岛国喷水视频在线观看| 91老熟女连续高潮对白| 色伦色伦777国产精品| 97精品人妻一区二区三区精品| 91免费放福利在线观看| 少妇人妻久久久久视频黄片| 成人高清在线观看视频| 国产a级毛久久久久精品| 一区二区三区综合视频| 天天摸天天亲天天舔天天操天天爽| 99av国产精品欲麻豆| 在线可以看的视频你懂的| 日韩三级黄色片网站| 久久这里只有精彩视频免费| 青青青国产片免费观看视频| 色综合久久五月色婷婷综合| 黄色av网站免费在线| 亚洲图片偷拍自拍区| 成人资源在线观看免费官网| 午夜精品福利一区二区三区p| 亚洲av成人网在线观看| 国产精品视频一区在线播放| 一二三区在线观看视频| 国产精品国色综合久久| 色综合久久久久久久久中文| 99精品视频在线观看免费播放| 久草视频福利在线首页| 国产欧美日韩第三页| 在线国产中文字幕视频| 特级欧美插插插插插bbbbb| 人妻丰满熟妇综合网| 水蜜桃一区二区三区在线观看视频 | 1000部国产精品成人观看视频| 宅男噜噜噜666免费观看| 欧美视频中文一区二区三区| 亚国产成人精品久久久| 亚洲精品国产久久久久久| 天天干天天爱天天色| 少妇人妻真实精品视频| 亚洲精品ww久久久久久| 亚洲成高清a人片在线观看| 国产亚洲成人免费在线观看| 99久久超碰人妻国产| 亚洲激情唯美亚洲激情图片| 欧美中文字幕一区最新网址| 色秀欧美视频第一页| 久久精品美女免费视频| 天天插天天狠天天操| 老鸭窝日韩精品视频观看| 粉嫩av蜜乳av蜜臀| 成人高清在线观看视频| 538精品在线观看视频| av成人在线观看一区| 只有精品亚洲视频在线观看| 亚洲欧美人精品高清| 大骚逼91抽插出水视频| 中文字幕一区二 区二三区四区 | 日本高清在线不卡一区二区| 欧美区一区二区三视频| 狠狠嗨日韩综合久久| 亚国产成人精品久久久| 直接能看的国产av| 日韩精品中文字幕在线| 一区二区三区激情在线| 国产精品久久久久久久久福交| 精品一区二区亚洲欧美| 又黄又刺激的午夜小视频| 黄色中文字幕在线播放| 亚洲国产香蕉视频在线播放| 福利视频网久久91| 亚洲一区久久免费视频| 国产极品精品免费视频| 欧美视频中文一区二区三区| 2019av在线视频| 人妻另类专区欧美制服| 日本高清成人一区二区三区| 深田咏美亚洲一区二区| 自拍偷拍一区二区三区图片| 欧美综合婷婷欧美综合| 麻豆性色视频在线观看| 日本免费视频午夜福利视频| 99久久成人日韩欧美精品| 成人综合亚洲欧美一区| 青娱乐在线免费视频盛宴| av亚洲中文天堂字幕网| 欧美3p在线观看一区二区三区| 极品性荡少妇一区二区色欲| 日本中文字幕一二区视频| 中国熟女@视频91| 日噜噜噜夜夜噜噜噜天天噜噜噜| 男人天堂av天天操| 婷婷综合亚洲爱久久| 亚洲一区二区人妻av| 偷拍美女一区二区三区| 日韩精品啪啪视频一道免费| 国产免费av一区二区凹凸四季| 午夜美女少妇福利视频| 青青草人人妻人人妻| 婷婷六月天中文字幕| 18禁无翼鸟成人在线| av老司机精品在线观看| 国产高潮无码喷水AV片在线观看| 粉嫩av蜜乳av蜜臀| gogo国模私拍视频| 亚洲综合一区成人在线| 男人天堂av天天操| 美日韩在线视频免费看| 欧美精产国品一二三区| 欧美黑人巨大性xxxxx猛交| 最新日韩av传媒在线| 亚洲欧美精品综合图片小说| 欧美日韩高清午夜蜜桃大香蕉| 55夜色66夜色国产精品站| 少妇系列一区二区三区视频| 熟女国产一区亚洲中文字幕| 黄页网视频在线免费观看| 五月激情婷婷久久综合网| 性生活第二下硬不起来| 激情伦理欧美日韩中文字幕| 欧美国品一二三产区区别| av资源中文字幕在线观看| 熟女妇女老妇一二三区| 亚洲综合另类精品小说| 青娱乐在线免费视频盛宴| av天堂加勒比在线| 最新中文字幕免费视频| 亚洲精品午夜久久久久| 欧美成人精品欧美一级黄色| 亚洲高清视频在线不卡| 97瑟瑟超碰在线香蕉| 日本av在线一区二区三区| 九色视频在线观看免费| 爱爱免费在线观看视频| 六月婷婷激情一区二区三区| 精品区一区二区三区四区人妻| 久久久噜噜噜久久熟女av| 一区二区三区日韩久久| 日韩人妻丝袜中文字幕| aⅴ五十路av熟女中出| 美女骚逼日出水来了| 91精品免费久久久久久| 色秀欧美视频第一页| AV无码一区二区三区不卡| 97年大学生大白天操逼| 日韩人妻丝袜中文字幕| 欧美男同性恋69视频| 最新的中文字幕 亚洲| 91免费观看在线网站| 久久久久久久久久久免费女人| 天天干夜夜操啊啊啊| 韩国亚洲欧美超一级在线播放视频| 日韩精品中文字幕播放| 欧美激情电影免费在线| 国产伊人免费在线播放| 免费av岛国天堂网站| 一色桃子久久精品亚洲| 在线免费观看日本片| 在线新三级黄伊人网| 亚洲免费在线视频网站| 免费观看污视频网站| 免费高清自慰一区二区三区网站| 人妻熟女中文字幕aⅴ在线| 日本特级片中文字幕| 日韩美女福利视频网| AV天堂一区二区免费试看| 日本性感美女三级视频| 日本少妇人妻xxxxx18| 激情啪啪啪啪一区二区三区| 大胸性感美女羞爽操逼毛片| 国产日韩精品免费在线| 亚洲av日韩av网站| 精品少妇一二三视频在线| 青青青aaaa免费| 91啪国自产中文字幕在线| 中文字幕av男人天堂| 国产av福利网址大全| aⅴ精产国品一二三产品| 99的爱精品免费视频| 成人免费毛片aaaa| 亚洲高清视频在线不卡| 天天干狠狠干天天操| 国产成人自拍视频在线免费观看| 制服丝袜在线人妻中文字幕| 亚洲一区二区激情在线| 视频一区二区三区高清在线| 色婷婷久久久久swag精品| 青草亚洲视频在线观看| 久久热久久视频在线观看| 91 亚洲视频在线观看| 香蕉aⅴ一区二区三区| www日韩毛片av| 黑人借宿ntr人妻的沦陷2| 色哟哟在线网站入口| 久久久精品精品视频视频| 中文字幕国产专区欧美激情| 欧美日韩v中文在线| 青青青青草手机在线视频免费看| 中字幕人妻熟女人妻a62v网| 人人妻人人爱人人草| 欧美成人一二三在线网| 亚洲福利天堂久久久久久 | 中文字幕在线第一页成人| 91国偷自产一区二区三区精品| 精品日产卡一卡二卡国色天香| 一区二区三区美女毛片| 超碰公开大香蕉97| 中文字幕在线欧美精品| 91av中文视频在线| 午夜激情高清在线观看| 亚洲欧美在线视频第一页| 精品国产午夜视频一区二区| 日韩精品啪啪视频一道免费| 国产精品人妻一区二区三区网站| 亚洲变态另类色图天堂网| 黑人借宿ntr人妻的沦陷2| 天天日天天日天天射天天干| 可以在线观看的av中文字幕| 日韩精品中文字幕在线| 91色网站免费在线观看| 婷婷六月天中文字幕| 天天操天天操天天碰| 日本又色又爽又黄又粗| 91色网站免费在线观看| 五十路熟女人妻一区二| 国产成人精品久久二区91| 久久精品亚洲国产av香蕉| 久久人人做人人妻人人玩精品vr| 亚洲欧美综合另类13p| www天堂在线久久| 国产综合视频在线看片| 老司机免费视频网站在线看| 日韩欧美一级精品在线观看| 天天日天天做天天日天天做| 中文字幕视频一区二区在线观看| 黄色男人的天堂视频| 中文人妻AV久久人妻水| 国产剧情演绎系列丝袜高跟| 宅男噜噜噜666免费观看| 亚洲国产欧美一区二区三区…| 日本少妇精品免费视频| 亚洲欧美精品综合图片小说| 最新国产亚洲精品中文在线| 全国亚洲男人的天堂| 美洲精品一二三产区区别| 久久久久久久久久性潮| 狠狠嗨日韩综合久久| 天天躁日日躁狠狠躁躁欧美av| 91亚洲手机在线视频播放| 偷拍3456eee| 亚洲欧美清纯唯美另类| 91九色国产porny蝌蚪| 三级黄色亚洲成人av| 日本福利午夜电影在线观看| 欧美精品中文字幕久久二区| 五十路丰满人妻熟妇| 黄色成年网站午夜在线观看 | 免费黄页网站4188| 亚洲成人三级在线播放| 亚洲av色香蕉一区二区三区| 日本午夜福利免费视频| 久久久久久99国产精品| 亚洲最大黄了色网站| 91高清成人在线视频| 国产黄色高清资源在线免费观看| 欧美日韩高清午夜蜜桃大香蕉| 中国产一级黄片免费视频播放| 岛国一区二区三区视频在线| 全国亚洲男人的天堂| 中文字幕最新久久久| 日本xx片在线观看| 中文字幕日韩精品日本| 九色porny九色9l自拍视频| 十八禁在线观看地址免费| 国产黄网站在线观看播放| 老熟妇凹凸淫老妇女av在线观看| 国产高清精品一区二区三区| 一二三中文乱码亚洲乱码one| 中文字幕高清资源站| 巨乳人妻日下部加奈被邻居中出 | 深夜男人福利在线观看| 欧洲亚洲欧美日韩综合| 欧美特级特黄a大片免费| 国产又粗又黄又硬又爽| 亚洲卡1卡2卡三卡四老狼| 在线国产精品一区二区三区| 欧美一级视频一区二区| 日本丰满熟妇BBXBBXHD| 毛茸茸的大外阴中国视频| 久碰精品少妇中文字幕av| 青青青青青青草国产| 国产精品视频男人的天堂| 久久精品在线观看一区二区| 成人av电影免费版| 欧美一级色视频美日韩| 久久农村老妇乱69系列| 大陆胖女人与丈夫操b国语高清| caoporn蜜桃视频| 青青在线视频性感少妇和隔壁黑丝| 91色秘乱一区二区三区| 日韩欧美国产一区不卡| 女生被男生插的视频网站| 亚洲国产在线精品国偷产拍 | 欧美精品国产综合久久| www日韩a级s片av| 国产精品久久久久久久久福交| 欧美精品久久久久久影院| 午夜的视频在线观看| 国产女孩喷水在线观看| 91超碰青青中文字幕| 人妻少妇性色欲欧美日韩| 国产a级毛久久久久精品| 欧美精品激情在线最新观看视频| 欧美一区二区三区久久久aaa| 国内资源最丰富的网站| 精品美女在线观看视频在线观看| 黑人借宿ntr人妻的沦陷2| 三级黄色亚洲成人av| 性感美女福利视频网站| 亚洲欧美自拍另类图片| 91亚洲国产成人精品性色| 大胆亚洲av日韩av| 伊人成人在线综合网| 天天综合天天综合天天网| 日本成人一区二区不卡免费在线| 成人24小时免费视频| 男人天堂色男人av| 亚洲中文精品字幕在线观看| 精品一区二区三区欧美| 四虎永久在线精品免费区二区| 强行扒开双腿猛烈进入免费版| 玖玖一区二区在线观看| 日本免费一级黄色录像| 一区二区久久成人网| 啊慢点鸡巴太大了啊舒服视频| 涩涩的视频在线观看视频| 亚洲粉嫩av一区二区三区| 97超碰免费在线视频| 狠狠操操操操操操操操操| 天堂av在线播放免费| 久久免费看少妇高潮完整版| 天天射夜夜操狠狠干| 国产欧美日韩在线观看不卡| 人人妻人人人操人人人爽| 中文字幕一区二区三区人妻大片| 日韩欧美亚洲熟女人妻| 免费观看丰满少妇做受| 91老熟女连续高潮对白| 国产老熟女伦老熟妇ⅹ| 午夜激情精品福利视频| 国产精品黄页网站视频| 888欧美视频在线| 亚洲成人三级在线播放 | 在线免费91激情四射| 77久久久久国产精产品| 边摸边做超爽毛片18禁色戒| 男人靠女人的逼视频| 777奇米久久精品一区| 亚洲综合图片20p| 99热碰碰热精品a中文| wwwxxx一级黄色片| 男人操女人的逼免费视频| 伊人成人综合开心网| 一区二区在线观看少妇| 日本少妇高清视频xxxxx| 超黄超污网站在线观看| 亚洲高清自偷揄拍自拍| 亚洲中文字幕校园春色 | 在线观看亚洲人成免费网址| 天天摸天天日天天操| 在线不卡成人黄色精品| 国产福利在线视频一区| 91麻豆精品传媒国产黄色片| 精品国产在线手机在线| 2018最新中文字幕在线观看| nagger可以指黑人吗| 在线观看一区二区三级| 淫秽激情视频免费观看| 中文字幕 码 在线视频| 国产伊人免费在线播放| 成熟丰满熟妇高潮xx×xx| 中文字幕在线视频一区二区三区| 天天干天天操天天扣| 97资源人妻免费在线视频| 白嫩白嫩美女极品国产在线观看| 日噜噜噜夜夜噜噜噜天天噜噜噜| 精品一区二区亚洲欧美| 欧美另类z0z变态| 日韩av免费观看一区| 久久久噜噜噜久久熟女av| 2022天天干天天操| 午夜成午夜成年片在线观看| 欧美成一区二区三区四区| 国产精品成久久久久三级蜜臀av| 欧美成一区二区三区四区| 农村胖女人操逼视频| 丝袜肉丝一区二区三区四区在线| 免费在线黄色观看网站| 日韩av熟妇在线观看| 久久热久久视频在线观看| 激情啪啪啪啪一区二区三区| 黄色在线观看免费观看在线| 亚洲国产欧美一区二区三区久久| 99精品免费观看视频| 天堂女人av一区二区| 综合精品久久久久97| 97超碰人人搞人人| 黑人巨大的吊bdsm| 欧美熟妇一区二区三区仙踪林| 又黄又刺激的午夜小视频| 啪啪啪操人视频在线播放| 久久久精品欧洲亚洲av| 欧美老鸡巴日小嫩逼| 亚洲国产中文字幕啊啊啊不行了| 天天日天天天天天天天天天天 | 99精品视频在线观看婷婷| 最新国产精品网址在线观看| 亚洲 色图 偷拍 欧美| 一区二区视频在线观看视频在线| 国产黑丝高跟鞋视频在线播放| 青青草在观免费国产精品| 天天干天天日天天干天天操| 日韩欧美国产一区ab| 91传媒一区二区三区| 国产视频网站一区二区三区| 国产精品久久久久网| 成人激情文学网人妻| 国产1区,2区,3区| 91在线视频在线精品3| 天天干天天操天天摸天天射| 日本在线一区二区不卡视频| 日韩视频一区二区免费观看| 国产精品入口麻豆啊啊啊| 亚洲第一伊人天堂网| 女同性ⅹxx女同h偷拍| 日韩成人综艺在线播放| 精品亚洲在线免费观看| 国产麻豆剧果冻传媒app| 69精品视频一区二区在线观看| 鸡巴操逼一级黄色气| 亚洲精品无码色午夜福利理论片| 欧美xxx成人在线| 亚洲成人激情视频免费观看了 | 午夜免费体验区在线观看| 天天日天天舔天天射进去| 一区二区视频视频视频| 日本一二三区不卡无| 99精品免费久久久久久久久a| 大胸性感美女羞爽操逼毛片| 亚洲乱码中文字幕在线| 人人妻人人澡欧美91精品| 97精品视频在线观看| 国内精品在线播放第一页| 日本一区精品视频在线观看| 国产精品人妻一区二区三区网站| 亚洲精品乱码久久久本| 欧美女同性恋免费a| 97精品视频在线观看| 婷婷六月天中文字幕| 不卡一区一区三区在线| 日本人妻精品久久久久久| 阿v天堂2014 一区亚洲| 欧美视频一区免费在线| 鸡巴操逼一级黄色气| 91精品免费久久久久久| 蜜桃精品久久久一区二区| 国产chinesehd精品麻豆| 欧美男同性恋69视频| 日韩一个色综合导航| 欧美中文字幕一区最新网址| 午夜精品九一唐人麻豆嫩草成人| 午夜激情精品福利视频| 国产视频网站国产视频| 日本熟妇一区二区x x| 初美沙希中文字幕在线| 啪啪啪18禁一区二区三区| 亚洲另类在线免费观看| 农村胖女人操逼视频| 国产午夜亚洲精品不卡在线观看| 中文字幕1卡1区2区3区| 欧美成人精品在线观看| 国产成人自拍视频在线免费观看| 国产午夜无码福利在线看| 人人妻人人澡人人爽人人dvl| 黄色无码鸡吧操逼视频| 青青青aaaa免费| 精品国产在线手机在线| 日韩美女搞黄视频免费| 欧美特级特黄a大片免费| 国产91久久精品一区二区字幕| 日本熟女50视频免费| 日韩欧美国产精品91| 国产精品久久久久久久久福交 | 亚洲欧洲一区二区在线观看| 天天草天天色天天干| 老鸭窝日韩精品视频观看| 亚洲人妻av毛片在线| 免费在线观看视频啪啪| 视频一区 视频二区 视频| 午夜免费观看精品视频| av中文字幕国产在线观看| 久久丁香花五月天色婷婷| 少妇人妻久久久久视频黄片| 亚洲一区二区激情在线| 免费观看丰满少妇做受| 欧美一级色视频美日韩| 专门看国产熟妇的网站| 视频啪啪啪免费观看| 做爰视频毛片下载蜜桃视频1| 黄工厂精品视频在线观看| 中国熟女一区二区性xx| 鸡巴操逼一级黄色气| 国产视频一区二区午夜| 色综合久久五月色婷婷综合| 黄色片黄色片wyaa| 农村胖女人操逼视频| 久久精品亚洲国产av香蕉| 天天想要天天操天天干| 免费在线看的黄网站| 阴茎插到阴道里面的视频| 中文字幕高清免费在线人妻 | 男女之间激情网午夜在线| 18禁无翼鸟成人在线| 亚洲2021av天堂| 亚洲欧美福利在线观看| 欧美乱妇无乱码一区二区| 国产精品人久久久久久| 亚洲成人熟妇一区二区三区| 精品黑人一区二区三区久久国产| 天天干天天操天天插天天日| 国内自拍第一页在线观看| 亚洲av日韩av第一区二区三区| 日比视频老公慢点好舒服啊| 福利午夜视频在线观看| 青青青青草手机在线视频免费看| 亚洲无线观看国产高清在线| 5528327男人天堂| 我想看操逼黄色大片| 天天操天天爽天天干| 国产乱弄免费视频观看| av天堂中文免费在线| 在线观看亚洲人成免费网址| 狠狠操操操操操操操操操| 啊啊好大好爽啊啊操我啊啊视频 | 欧洲精品第一页欧洲精品亚洲| 欧美亚洲牲夜夜综合久久| 五十路熟女av天堂| 班长撕开乳罩揉我胸好爽| 亚洲少妇人妻无码精品| 91久久精品色伊人6882| 日本一二三区不卡无| 端庄人妻堕落挣扎沉沦| 888欧美视频在线| 亚洲少妇高潮免费观看| 日本性感美女三级视频| 青草青永久在线视频18| 新婚人妻聚会被中出| 色呦呦视频在线观看视频| 日韩一个色综合导航| 青青草在观免费国产精品| 成熟熟女国产精品一区| 这里有精品成人国产99| 亚洲av无硬久久精品蜜桃| 亚洲1卡2卡三卡4卡在线观看| 国产精品久久久久久久女人18| 40道精品招牌菜特色| 自拍偷拍亚洲另类色图| 国产极品精品免费视频 | av手机免费在线观看高潮| 高潮视频在线快速观看国家快速| 久碰精品少妇中文字幕av | 中文字幕av第1页中文字幕| 亚洲欧美一区二区三区爱爱动图 | 老司机在线精品福利视频| 91快播视频在线观看| 亚洲一级av大片免费观看| 成人动漫大肉棒插进去视频| 男人天堂最新地址av| 国产精品人妻熟女毛片av久| 91超碰青青中文字幕| 亚洲第一伊人天堂网| 伊人情人综合成人久久网小说| 女同性ⅹxx女同hd| 老司机福利精品免费视频一区二区 | 日本性感美女写真视频| 熟女人妻三十路四十路人妻斩| 伊人精品福利综合导航| 91九色porny国产蝌蚪视频| 精品少妇一二三视频在线| 91p0rny九色露脸熟女| 国产熟妇人妻ⅹxxxx麻豆| 天堂av在线官网中文| 这里只有精品双飞在线播放| 亚洲免费在线视频网站| 日本xx片在线观看| 国产黄色大片在线免费播放| 国产精品一区二区三区蜜臀av| 欧美色婷婷综合在线| 51国产偷自视频在线播放| 日韩中文字幕精品淫| 久久久久久99国产精品| 免费在线看的黄网站| 在线观看亚洲人成免费网址| 中国视频一区二区三区| 在线国产中文字幕视频| 91精品激情五月婷婷在线| 亚洲欧美激情国产综合久久久| 亚洲国产精品美女在线观看 | 欧美激情电影免费在线| 真实国产乱子伦一区二区| 日本性感美女写真视频| 亚洲免费视频欧洲免费视频| 国产视频一区在线观看| 国产成人一区二区三区电影网站| 日本阿v视频在线免费观看| 色花堂在线av中文字幕九九| 天天日天天干天天搡| 亚洲中文字幕国产日韩| 中出中文字幕在线观看| 97超碰国语国产97超碰| 99精品一区二区三区的区| 国产不卡av在线免费| 少妇人妻真实精品视频| 精品久久婷婷免费视频| 亚洲精品麻豆免费在线观看| 扒开腿挺进肉嫩小18禁视频| 大学生A级毛片免费视频| 日本免费一级黄色录像| 日本啪啪啪啪啪啪啪| 日韩美女综合中文字幕pp| 亚洲一区二区久久久人妻| 97小视频人妻一区二区| 中文字幕无码日韩专区免费| 精品久久婷婷免费视频| 不卡一区一区三区在线| 中文字幕免费在线免费| 天天日天天干天天干天天日| 亚洲欧美自拍另类图片| 丁香花免费在线观看中文字幕| 91免费黄片可看视频| 亚洲综合另类欧美久久| 桃色视频在线观看一区二区| 亚洲熟妇x久久av久久| 国产成人精品av网站| 亚洲国产欧美国产综合在线| 亚洲精品一线二线在线观看 | 国产清纯美女al在线| 国产视频网站一区二区三区 | 久久久久久99国产精品| 日日夜夜精品一二三| 欧美一级色视频美日韩| 日辽宁老肥女在线观看视频| 欧美亚洲偷拍自拍色图| 天天想要天天操天天干| 国产片免费观看在线观看| 在线免费91激情四射 | 欧美日韩一区二区电影在线观看| av大全在线播放免费| 在线观看成人国产电影| 在线免费观看视频一二区| 国产又粗又硬又猛的毛片视频| av中文字幕国产在线观看| av日韩在线观看大全| 日本熟妇色熟妇在线观看| 狠狠躁狠狠爱网站视频| 亚洲中文字幕乱码区| 在线观看视频 你懂的| v888av在线观看视频| 亚洲国产成人在线一区| 亚洲福利精品视频在线免费观看| 亚洲高清国产自产av| 一区二区三区综合视频| 风流唐伯虎电视剧在线观看| 都市激情校园春色狠狠| 亚洲午夜电影之麻豆| 麻豆精品成人免费视频| 人人妻人人澡人人爽人人dvl| 中文字幕高清免费在线人妻| 2019av在线视频| 97少妇精品在线观看| 19一区二区三区在线播放| 久久久久久cao我的性感人妻| 色哟哟在线网站入口| 黑人进入丰满少妇视频| 亚洲国产免费av一区二区三区| 亚洲精品 日韩电影| 1区2区3区不卡视频| 在线新三级黄伊人网| 亚洲综合色在线免费观看| 久久久久久久99精品| 中文字幕日韩人妻在线三区| 国产内射中出在线观看| 视频一区 视频二区 视频| 亚洲欧美综合另类13p| av破解版在线观看| 中文字幕在线乱码一区二区 | 男人在床上插女人视频| 色在线观看视频免费的| 人妻熟女中文字幕aⅴ在线| 扒开腿挺进肉嫩小18禁视频| 97超碰人人搞人人| 美洲精品一二三产区区别| 国产美女一区在线观看| 日韩欧美在线观看不卡一区二区| 伊人综合aⅴ在线网| 日韩亚洲高清在线观看| 大陆胖女人与丈夫操b国语高清 | 亚洲少妇人妻无码精品| 男生用鸡操女生视频动漫 | 日韩熟女av天堂系列| 欧美日韩一区二区电影在线观看| 亚洲欧美成人综合视频| 97人妻人人澡爽人人精品| 成人免费公开视频无毒| 亚洲天堂精品福利成人av| 东游记中文字幕版哪里可以看到| 一个色综合男人天堂| 92福利视频午夜1000看| 精品亚洲国产中文自在线| 中文字幕在线乱码一区二区| 亚洲高清国产一区二区三区| 午夜极品美女福利视频| 亚洲欧美国产综合777| av在线资源中文字幕| 国产福利小视频二区| 在线视频自拍第三页| 国产精品成久久久久三级蜜臀av| av在线免费资源站| 一级A一级a爰片免费免会员 | 国产日韩欧美美利坚蜜臀懂色| 100%美女蜜桃视频| 婷婷色国产黑丝少妇勾搭AV| 丝袜美腿欧美另类 中文字幕| 桃色视频在线观看一区二区| 中文字幕乱码人妻电影| 国产黑丝高跟鞋视频在线播放| 大香蕉伊人中文字幕| 不卡一区一区三区在线| 精品久久久久久久久久中文蒉| 国产熟妇乱妇熟色T区| 人妻丝袜榨强中文字幕| 婷婷综合蜜桃av在线| 天天干夜夜操啊啊啊| 国产精品久久久久网| 精品人妻伦一二三区久| 一区二区在线观看少妇| 亚洲免费成人a v| 99精品免费久久久久久久久a| 人妻av无码专区久久绿巨人 | 黄色在线观看免费观看在线| av老司机精品在线观看| 极品粉嫩小泬白浆20p主播| 日韩一区二区三区三州| 中文字幕日韩人妻在线三区| 5528327男人天堂| 国产三级片久久久久久久| 久久久极品久久蜜桃| 人妻在线精品录音叫床| 99久久99一区二区三区| 成人色综合中文字幕| 日韩激情文学在线视频| 开心 色 六月 婷婷| 亚洲成a人片777777| 天天干天天操天天爽天天摸| 涩涩的视频在线观看视频| avjpm亚洲伊人久久| 最新中文字幕免费视频| 亚洲精品中文字幕下载| 日本韩国免费福利精品| 加勒比视频在线免费观看| 最新的中文字幕 亚洲| 天堂v男人视频在线观看| 欧美亚洲偷拍自拍色图| 视频一区 视频二区 视频| 久久久久久国产精品| 亚洲精品无码久久久久不卡| 欧美xxx成人在线| 91人妻精品久久久久久久网站| 动漫美女的小穴视频| 中国把吊插入阴蒂的视频| 日本高清在线不卡一区二区| 欧美精产国品一二三区| 插逼视频双插洞国产操逼插洞| 人人妻人人澡人人爽人人dvl| 在线免费观看亚洲精品电影| 亚洲的电影一区二区三区 | 亚洲一区二区三区久久午夜| 日本一区二区三区免费小视频| 天天爽夜夜爽人人爽QC| 日韩精品中文字幕福利| 天天通天天透天天插| 99国内小视频在现欢看| 91在线视频在线精品3| 91大屁股国产一区二区| 国产丰满熟女成人视频| 日本中文字幕一二区视频| 老司机欧美视频在线看| 中英文字幕av一区| 91亚洲国产成人精品性色| 日本最新一二三区不卡在线| 自拍偷拍一区二区三区图片| 大陆精品一区二区三区久久| 欧亚日韩一区二区三区观看视频 | 一区二区视频在线观看视频在线| 国产一级麻豆精品免费| 一级a看免费观看网站| 在线 中文字幕 一区| 亚洲av午夜免费观看| 成人av免费不卡在线观看| 亚洲欧美激情国产综合久久久| 日韩写真福利视频在线观看| 中文字幕+中文字幕| 香蕉av影视在线观看| 欧美偷拍亚洲一区二区| 亚洲欧洲av天堂综合| 一区二区三区四区中文| 含骚鸡巴玩逼逼视频| av在线免费中文字幕| 欧美女同性恋免费a| 一区二区视频在线观看免费观看| 欧美另类z0z变态| 免费在线观看视频啪啪| 阿v天堂2014 一区亚洲| aaa久久久久久久久| av天堂中文免费在线| 在线观看视频 你懂的| 天堂资源网av中文字幕| 不卡一区一区三区在线| 国产普通话插插视频| 欧美一区二区三区啪啪同性| 激情五月婷婷综合色啪| 美洲精品一二三产区区别| 日韩av有码一区二区三区4| 久久久超爽一二三av| 天天摸天天干天天操科普| 国产精品自拍在线视频| 热思思国产99re| 午夜影院在线观看视频羞羞羞| 午夜在线一区二区免费| 久久久久久9999久久久久| 免费无毒热热热热热热久| 九色porny九色9l自拍视频| 国产在线一区二区三区麻酥酥| 日韩加勒比东京热二区| 午夜婷婷在线观看视频| 国产精品久久久久网| 亚洲精品国产在线电影| 亚洲免费在线视频网站| 2018在线福利视频| 在线不卡成人黄色精品| yellow在线播放av啊啊啊 | 亚洲成人av一区在线| 久草视频在线一区二区三区资源站| 在线 中文字幕 一区| 欧美韩国日本国产亚洲| av久久精品北条麻妃av观看| 肏插流水妹子在线乐播下载| 天天干狠狠干天天操| 999久久久久999| 1区2区3区4区视频在线观看| 天堂av在线播放免费| 欧美亚洲中文字幕一区二区三区| 超pen在线观看视频公开97| 69精品视频一区二区在线观看| 天天射,天天操,天天说| 精品老妇女久久9g国产| 欧美一区二区中文字幕电影| 日本女人一级免费片| 欧美日本在线视频一区| 国产亚洲视频在线观看| 青青草原网站在线观看| 在线免费91激情四射| 精品人妻伦一二三区久 | 亚洲最大免费在线观看| 亚洲午夜在线视频福利| 1000部国产精品成人观看视频| 国产超码片内射在线| 亚洲午夜在线视频福利| 中文字幕在线乱码一区二区| 91香蕉成人app下载| 宅男噜噜噜666免费观看| avjpm亚洲伊人久久| 国产精品精品精品999| av亚洲中文天堂字幕网| 亚洲高清视频在线不卡| 日本xx片在线观看| 欧美精品资源在线观看| 一区二区三区四区五区性感视频| 成年人该看的视频黄免费| 久久久久只精品国产三级| 青青草成人福利电影| 人妻丝袜诱惑我操她视频| 亚洲av无乱一区二区三区性色| 插小穴高清无码中文字幕| 国产精品人久久久久久| 蜜桃色婷婷久久久福利在线| 女警官打开双腿沦为性奴| 亚洲av可乐操首页| 香蕉片在线观看av| 久草视频 久草视频2| 夏目彩春在线中文字幕| 亚洲天堂成人在线观看视频网站| 高清成人av一区三区| 一级A一级a爰片免费免会员| 老熟妇凹凸淫老妇女av在线观看| 亚洲国产精品中文字幕网站| 大白屁股精品视频国产| 这里有精品成人国产99| 在线免费观看黄页视频| 中文字幕亚洲中文字幕| 亚洲麻豆一区二区三区| 五十路熟女人妻一区二| 一区二区三区欧美日韩高清播放| 国产精品探花熟女在线观看| 天天射夜夜操狠狠干| av手机在线免费观看日韩av| 国产乱弄免费视频观看| 国产精品黄大片在线播放| 又大又湿又爽又紧A视频| 91精品国产麻豆国产| 国产成人精品亚洲男人的天堂| 91免费福利网91麻豆国产精品| 久精品人妻一区二区三区 | 欧美地区一二三专区| 视频一区 二区 三区 综合| 天天操天天操天天碰| 插小穴高清无码中文字幕| 99热色原网这里只有精品| 激情五月婷婷综合色啪| 在线观看一区二区三级| 黑人大几巴狂插日本少妇| 97成人免费在线观看网站| 99热碰碰热精品a中文| 成年人午夜黄片视频资源| 久久免看30视频口爆视频| 午夜精彩视频免费一区| 激情人妻校园春色亚洲欧美| 亚洲成高清a人片在线观看| 欧美激情电影免费在线| 亚洲综合另类精品小说| 精品一区二区亚洲欧美| 精品成人啪啪18免费蜜臀| 国产无遮挡裸体免费直播视频| 色av色婷婷人妻久久久精品高清| 日韩欧美亚洲熟女人妻| 91人妻精品一区二区在线看| 免费看国产又粗又猛又爽又黄视频 | 人妻素人精油按摩中出| 97人人模人人爽人人喊| 97色视频在线观看| 亚洲av自拍天堂网| 在线观看一区二区三级| 操的小逼流水的文章| 老熟妇凹凸淫老妇女av在线观看| 精品乱子伦一区二区三区免费播 | 欧美一区二区三区四区性视频| 国产在线自在拍91国语自产精品 | 男人的网址你懂的亚洲欧洲av| 在线国产精品一区二区三区| 9色精品视频在线观看| 欧美亚洲国产成人免费在线| 全国亚洲男人的天堂| 偷青青国产精品青青在线观看 | 第一福利视频在线观看| avjpm亚洲伊人久久| 国产日韩一区二区在线看 | 亚洲国产精品中文字幕网站| 老熟妇xxxhd老熟女| 98视频精品在线观看| 亚洲欧美一区二区三区爱爱动图| 国产又粗又猛又爽又黄的视频美国| 99精品国自产在线人| 年轻的人妻被夫上司侵犯| 91免费福利网91麻豆国产精品| 社区自拍揄拍尻屁你懂的 | 国产成人自拍视频播放| 宅男噜噜噜666国产| 在线观看操大逼视频| 人妻av无码专区久久绿巨人| 老司机午夜精品视频资源| 日本阿v视频在线免费观看| 丰满少妇翘臀后进式| 欧美性感尤物人妻在线免费看| 亚洲精品在线资源站| 天天日天天鲁天天操| 操日韩美女视频在线免费看| 免费一级特黄特色大片在线观看 | 成年午夜影片国产片| 肏插流水妹子在线乐播下载| 成年人黄视频在线观看| 国产中文精品在线观看| 国产精品探花熟女在线观看| 亚洲欧美成人综合在线观看| 天天综合天天综合天天网| 超碰中文字幕免费观看| 国产实拍勾搭女技师av在线| 一区二区三区日韩久久| 在线免费观看黄页视频| 福利视频一区二区三区筱慧| 久久这里只有精彩视频免费| 农村胖女人操逼视频| 日本欧美视频在线观看三区| 国产亚洲欧美另类在线观看| 亚洲熟妇无码一区二区三区| 国产精品一区二区久久久av| av手机在线免费观看日韩av| 欧美综合婷婷欧美综合| 国产之丝袜脚在线一区二区三区| 人人妻人人爽人人添夜| 亚洲人人妻一区二区三区| 99精品视频在线观看婷婷| 无忧传媒在线观看视频| 国产精品人妻66p| jiuse91九色视频| 绝顶痉挛大潮喷高潮无码| 国产精品熟女久久久久浪潮| 亚洲另类综合一区小说| 91久久人澡人人添人人爽乱| 日韩av免费观看一区| 3D动漫精品啪啪一区二区下载| 亚洲午夜电影在线观看| 亚洲一区二区三区在线高清 | 亚洲一区二区三区av网站| 欧美亚洲自偷自拍 在线| 最近中文2019年在线看| 在线 中文字幕 一区| 免费啪啪啪在线观看视频| 偷拍3456eee| 久久麻豆亚洲精品av| 午夜免费体验区在线观看| 免费在线观看视频啪啪 | 欧美成人精品欧美一级黄色| 天天色天天舔天天射天天爽| 亚洲欧洲av天堂综合| mm131美女午夜爽爽爽| 97色视频在线观看| 成人综合亚洲欧美一区| 免费高清自慰一区二区三区网站| 中字幕人妻熟女人妻a62v网| 2022精品久久久久久中文字幕| 这里有精品成人国产99| 唐人色亚洲av嫩草| 亚洲va国产va欧美精品88| 欧美日韩一级黄片免费观看| 在线视频自拍第三页| 亚洲精品亚洲人成在线导航| 91亚洲精品干熟女蜜桃频道 | 欧美偷拍亚洲一区二区| 偷拍自拍亚洲视频在线观看| 黄色黄色黄片78在线| 老鸭窝在线观看一区| 中字幕人妻熟女人妻a62v网| 91免费放福利在线观看| 亚洲av琪琪男人的天堂| 美女视频福利免费看| 熟女91pooyn熟女| 1769国产精品视频免费观看| 后入美女人妻高清在线| 99一区二区在线观看| 亚洲国产在线精品国偷产拍| 91在线免费观看成人| 亚洲一区久久免费视频| 亚洲中文字幕人妻一区| 国产一区二区火爆视频| 亚国产成人精品久久久| sejizz在线视频| 国产亚洲四十路五十路| 九色porny九色9l自拍视频| 男大肉棒猛烈插女免费视频| 国产91精品拍在线观看| 天天日天天爽天天干| 大香蕉福利在线观看| 日韩欧美制服诱惑一区在线| 欧美黄片精彩在线免费观看| 一个色综合男人天堂| 人妻久久久精品69系列| 91国产在线免费播放| 可以免费看的www视频你懂的| 丰满少妇翘臀后进式| 精品91高清在线观看| 精品一区二区三区三区88| 久久午夜夜伦痒痒想咳嗽P| 日本特级片中文字幕| 人人在线视频一区二区| 少妇人妻100系列| 国产精品一区二区三区蜜臀av| 亚洲日本一区二区久久久精品| 国产精品中文av在线播放| 中国老熟女偷拍第一页| 美女被肏内射视频网站| 毛片一级完整版免费| 成人亚洲国产综合精品| 精品一区二区亚洲欧美| 老司机你懂得福利视频| 中文人妻AV久久人妻水| 亚洲av日韩av第一区二区三区| 亚洲欧美日韩视频免费观看| 少妇人妻久久久久视频黄片| 成人在线欧美日韩国产| 综合精品久久久久97| 久久丁香婷婷六月天| 精彩视频99免费在线| 北条麻妃高跟丝袜啪啪| chinese国产盗摄一区二区| 国产a级毛久久久久精品| 99人妻视频免费在线| 在线观看亚洲人成免费网址| 亚洲成人av一区久久| 久久午夜夜伦痒痒想咳嗽P| 亚欧在线视频你懂的| 性欧美激情久久久久久久| 午夜免费体验区在线观看| 熟女少妇激情五十路| 精内国产乱码久久久久久| 欧美精产国品一二三产品区别大吗| 国产普通话插插视频| 美女福利视频导航网站| 欧美va不卡视频在线观看| 不卡精品视频在线观看| 天天插天天狠天天操| 国产在线观看黄色视频| 91免费黄片可看视频| 晚上一个人看操B片| 中文字幕,亚洲人妻| 人妻少妇亚洲精品中文字幕| 视频久久久久久久人妻| 天天干夜夜操天天舔| 午夜精彩视频免费一区| 国产chinesehd精品麻豆| 欧美专区第八页一区在线播放| 日韩少妇人妻精品无码专区| 天天色天天操天天透| 偷偷玩弄新婚人妻h视频| 亚洲中文字幕人妻一区| 欧洲日韩亚洲一区二区三区| 中文字幕日本人妻中出| 骚货自慰被发现爆操| 日韩熟女av天堂系列| 国产成人精品亚洲男人的天堂| 天堂资源网av中文字幕| 一级黄色片夫妻性生活| 成年女人免费播放视频| 美洲精品一二三产区区别| 国产成人一区二区三区电影网站| 午夜精品福利一区二区三区p| 亚洲国产欧美国产综合在线| 一区二区三区美女毛片| 动漫美女的小穴视频| 午夜激情高清在线观看| 天天干天天爱天天色| 欧洲精品第一页欧洲精品亚洲 | 男生用鸡操女生视频动漫| 国产亚州色婷婷久久99精品| 丝袜长腿第一页在线| 国产精品久久久久久久久福交 | 天天操天天干天天插| 最新日韩av传媒在线| 国产av一区2区3区| 老熟妇xxxhd老熟女| 亚洲图片偷拍自拍区| 在线观看成人国产电影| 人妻凌辱欧美丰满熟妇| 亚洲欧美一区二区三区爱爱动图| 亚洲国产精品中文字幕网站| 日辽宁老肥女在线观看视频| 91久久人澡人人添人人爽乱| 天天日天天操天天摸天天舔| 亚洲中文精品字幕在线观看| 又黄又刺激的午夜小视频| v888av在线观看视频| 日韩视频一区二区免费观看| 欧美亚洲免费视频观看| 麻豆精品成人免费视频| 任我爽精品视频在线播放| 欧美色婷婷综合在线| 国产无遮挡裸体免费直播视频| 日本熟女50视频免费| 1024久久国产精品| heyzo蜜桃熟女人妻| 久久久久久97三级| 在线观看免费视频色97| 精品黑人巨大在线一区| 一区二区三区精品日本| 亚洲va国产va欧美va在线| 人妻少妇亚洲一区二区| 天天色天天爱天天爽| 粉嫩av蜜乳av蜜臀| 亚洲精品成人网久久久久久小说| 国产精品久久久久久美女校花| 激情小视频国产在线| 日本三极片视频网站观看| 护士特殊服务久久久久久久| 亚洲午夜精品小视频| 家庭女教师中文字幕在线播放| 精品美女在线观看视频在线观看| 久久精品在线观看一区二区| 人妻久久无码中文成人| 最新欧美一二三视频| 天天躁夜夜躁日日躁a麻豆| 中文字幕 码 在线视频| 中文字幕欧美日韩射射一| 一本一本久久a久久精品综合不卡| 丰满熟女午夜福利视频| huangse网站在线观看| 中文 成人 在线 视频| 黑人乱偷人妻中文字幕| 中文字幕人妻三级在线观看| 国产a级毛久久久久精品| 开心 色 六月 婷婷| 天天干天天插天天谢| 91‖亚洲‖国产熟女| 精品美女福利在线观看| 国产成人精品午夜福利训2021| 综合激情网激情五月五月婷婷| 自拍偷拍亚洲欧美在线视频| 欧美综合婷婷欧美综合| 99精品久久久久久久91蜜桃| 美女福利视频导航网站| 亚洲伊人久久精品影院一美女洗澡 | 日韩欧美高清免费在线| 极品粉嫩小泬白浆20p主播| 欧美成人精品欧美一级黄色| 一二三区在线观看视频| 午夜场射精嗯嗯啊啊视频| 1000部国产精品成人观看视频 | 中文字幕第三十八页久久| 久草视频首页在线观看| 黑人变态深video特大巨大| 美洲精品一二三产区区别| 二区中出在线观看老师| 男女之间激情网午夜在线| 久久久91蜜桃精品ad| 国产三级片久久久久久久| 蜜桃精品久久久一区二区| 不戴胸罩引我诱的隔壁的人妻| 精品国产在线手机在线| 免费看高清av的网站| 国产+亚洲+欧美+另类| 久碰精品少妇中文字幕av | 热99re69精品8在线播放| 91色网站免费在线观看| 亚洲一区二区人妻av| 大香蕉大香蕉在线有码 av| 99久久超碰人妻国产| 国产精品一区二区av国| 女同久久精品秋霞网| 五十路熟女人妻一区二| 精品久久久久久久久久中文蒉| 天天日天天干天天要| 青青青青青青青在线播放视频| 久久午夜夜伦痒痒想咳嗽P| 2019av在线视频| 亚洲熟女综合色一区二区三区四区| 黑人巨大的吊bdsm| 精品91高清在线观看| 黄色无码鸡吧操逼视频| 午夜美女少妇福利视频| 欧美特色aaa大片| 黄色在线观看免费观看在线| 欧美专区第八页一区在线播放| 久久热这里这里只有精品| 亚洲激情,偷拍视频| 国产女孩喷水在线观看| 美洲精品一二三产区区别| 中文人妻AV久久人妻水| 一区二区视频视频视频| 黄色中文字幕在线播放| 国产av一区2区3区| 亚洲精品午夜久久久久| 国产精品久久久久久久久福交| 天天色天天操天天舔| av网站色偷偷婷婷网男人的天堂| 欧美精品一二三视频| avjpm亚洲伊人久久| 国产九色91在线视频| 亚洲av极品精品在线观看| av亚洲中文天堂字幕网| 超级福利视频在线观看| 瑟瑟视频在线观看免费视频| 日本美女性生活一级片| 98视频精品在线观看| 香蕉aⅴ一区二区三区| 91快播视频在线观看| 93视频一区二区三区| 888欧美视频在线| 98视频精品在线观看| 夜色福利视频在线观看| 青青青青青操视频在线观看| 宅男噜噜噜666免费观看| 国产在线自在拍91国语自产精品| 97欧洲一区二区精品免费| 天天日天天干天天插舔舔| av在线观看网址av| 亚洲一区二区三区精品乱码| 一区二区三区麻豆福利视频| 激情色图一区二区三区| 99的爱精品免费视频| 精品亚洲中文字幕av| 男人靠女人的逼视频| 99re久久这里都是精品视频| 日韩午夜福利精品试看| av老司机精品在线观看| 午夜在线观看岛国av,com| 午夜在线观看岛国av,com| 18禁网站一区二区三区四区 | 美女日逼视频免费观看| 婷婷综合亚洲爱久久| 91免费福利网91麻豆国产精品| 欧美黑人巨大性xxxxx猛交| 在线观看的a站 最新| 午夜精品在线视频一区| 婷婷色国产黑丝少妇勾搭AV| 天天干天天操天天玩天天射| 蜜臀成人av在线播放| 亚洲国产在人线放午夜| 9国产精品久久久久老师| 亚洲欧美另类自拍偷拍色图| 丰满的继坶3中文在线观看| 欧美一级片免费在线成人观看 | 人妻素人精油按摩中出| 欧美精产国品一二三区| 大香蕉玖玖一区2区| 欧美日韩精品永久免费网址| 不卡一区一区三区在线| 国产卡一卡二卡三乱码手机| 中文字幕免费福利视频6| 久久农村老妇乱69系列| 久久精品视频一区二区三区四区 | 日韩精品中文字幕福利| 老熟妇xxxhd老熟女| 91快播视频在线观看| 免费在线播放a级片| 91桃色成人网络在线观看| 日视频免费在线观看| 亚洲av日韩高清hd| 超碰97人人澡人人| 国产九色91在线视频| 欧美亚洲免费视频观看| 91色秘乱一区二区三区| 一级A一级a爰片免费免会员| 中文字幕熟女人妻久久久| 日韩欧美国产一区ab| 最新的中文字幕 亚洲| 亚洲一级av大片免费观看| 亚洲欧美精品综合图片小说| 一区二区三区精品日本| 欧美精产国品一二三区| 人妻爱爱 中文字幕| 欧美精品欧美极品欧美视频| 水蜜桃国产一区二区三区| 夜夜操,天天操,狠狠操| 青青热久免费精品视频在线观看| 在线免费91激情四射| caoporn蜜桃视频| 岛国免费大片在线观看| 欧美日韩人妻久久精品高清国产| 亚洲码av无色中文| 99人妻视频免费在线| 亚洲的电影一区二区三区| 国产chinesehd精品麻豆| 亚洲欧美在线视频第一页| 中文字幕欧美日韩射射一| 成人在线欧美日韩国产| 亚洲免费福利一区二区三区| 曰本无码人妻丰满熟妇啪啪| 精品视频国产在线观看| 国产极品美女久久久久久| 天天操夜夜骑日日摸| 亚洲高清一区二区三区视频在线 | 成年午夜影片国产片| 亚洲粉嫩av一区二区三区| 中文字幕一区二区三区蜜月| 亚洲欧美另类自拍偷拍色图| 91在线免费观看成人| 在线观看的a站 最新| 午夜在线精品偷拍一区二| 日韩欧美一级aa大片| 丝袜长腿第一页在线| 亚洲国产精品美女在线观看| 韩国AV无码不卡在线播放| 亚洲国产美女一区二区三区软件| 成人精品视频99第一页| 亚洲熟女女同志女同| 日本女大学生的黄色小视频| 99久久久无码国产精品性出奶水| 久久精品亚洲成在人线a| 天天干天天日天天干天天操| 亚洲中文字字幕乱码| 97青青青手机在线视频| 中文字幕高清免费在线人妻| 青娱乐最新视频在线| 国产成人自拍视频播放| 国产精品久久久久久久久福交| 91九色国产熟女一区二区| 日韩美av高清在线| 国产日韩精品免费在线| 欧美黄色录像免费看的| 福利片区一区二体验区| 天堂va蜜桃一区入口| 青青草原色片网站在线观看| 少妇与子乱在线观看| 免费黄页网站4188| 久久农村老妇乱69系列| 操的小逼流水的文章| 天天射夜夜操综合网| 美女大bxxxx内射| 国产精品一区二区三区蜜臀av| 日本xx片在线观看| 狠狠嗨日韩综合久久| 换爱交换乱高清大片| 色综合天天综合网国产成人 | 国产老熟女伦老熟妇ⅹ| 欧美色呦呦最新网址| 婷婷色国产黑丝少妇勾搭AV| 欧美日韩一级黄片免费观看| 一区二区三区日本伦理| 国产欧美精品一区二区高清| 人妻丝袜诱惑我操她视频| 不卡精品视频在线观看| 黑人乱偷人妻中文字幕| 91亚洲国产成人精品性色| 婷婷久久一区二区字幕网址你懂得| 国产亚洲成人免费在线观看| 午夜激情精品福利视频| 欧美交性又色又爽又黄麻豆| 都市激情校园春色狠狠| 久草视频中文字幕在线观看| 超碰在线观看免费在线观看| 91精品国产黑色丝袜| 免费看国产av网站| 亚洲色偷偷综合亚洲AV伊人| 93精品视频在线观看| 国产在线91观看免费观看| 成年人该看的视频黄免费| 午夜在线观看岛国av,com| 成人av亚洲一区二区| 免费大片在线观看视频网站| 中文字幕—97超碰网| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 无套猛戳丰满少妇人妻| 亚洲av色图18p| 午夜精品一区二区三区福利视频| 99热久久这里只有精品| 亚洲1卡2卡三卡4卡在线观看 | 午夜成午夜成年片在线观看| 91天堂天天日天天操| 91人妻人人做人人爽在线| 国产综合高清在线观看| 国产中文字幕四区在线观看| 超pen在线观看视频公开97| 在线免费观看视频一二区| 日本免费午夜视频网站| 中文字幕亚洲中文字幕| 免费观看理论片完整版| 日韩av熟妇在线观看| av视屏免费在线播放| 国产中文字幕四区在线观看| 日韩不卡中文在线视频网站| 欧美日韩一级黄片免费观看| 日韩欧美国产一区ab| 人妻另类专区欧美制服| 日韩视频一区二区免费观看| 一区二区三区av高清免费| 国产女人被做到高潮免费视频 | 亚洲第一伊人天堂网| 成人30分钟免费视频| 亚洲区美熟妇久久久久| 在线观看成人国产电影| 欧美另类重口味极品在线观看| 久久久久久性虐视频| 日视频免费在线观看| 动色av一区二区三区| 狠狠躁夜夜躁人人爽天天天天97| 伊人综合免费在线视频| 免费在线观看视频啪啪| av高潮迭起在线观看| 日韩人妻xxxxx| 2021久久免费视频| 日韩三级电影华丽的外出| 99久久成人日韩欧美精品| 国产污污污污网站在线 | 亚洲国产在人线放午夜| 亚洲熟女久久久36d| 亚洲精品ww久久久久久| 欧美日韩一级黄片免费观看| 国产精选一区在线播放| 欧美一区二区三区激情啪啪啪 | 婷婷六月天中文字幕| 91老师蜜桃臀大屁股| 92福利视频午夜1000看| 日韩人妻丝袜中文字幕| 天天操天天弄天天射| 中文字幕网站你懂的| 国产熟妇乱妇熟色T区| 337p日本大胆欧美人| 国产精品一区二区久久久av| avjpm亚洲伊人久久| 91精品国产综合久久久蜜| 98视频精品在线观看| 天天射夜夜操狠狠干| 韩国亚洲欧美超一级在线播放视频| 国产一区二区视频观看| 80电影天堂网官网| 国产清纯美女al在线| 五月精品丁香久久久久福利社| 五十路在线观看完整版| 色狠狠av线不卡香蕉一区二区| 无码精品一区二区三区人| 蜜桃专区一区二区在线观看| 欧美成人小视频在线免费看| 黄色大片免费观看网站| 国产精品黄片免费在线观看| 老鸭窝在线观看一区| 亚洲欧美激情中文字幕| 班长撕开乳罩揉我胸好爽| 这里只有精品双飞在线播放| 91天堂精品一区二区| 午夜精品一区二区三区4| 91中文字幕最新合集| 日本中文字幕一二区视频| 激情伦理欧美日韩中文字幕| 黄色视频在线观看高清无码| 1区2区3区4区视频在线观看| 偷拍自拍国产在线视频| 亚洲午夜电影之麻豆| 91人妻精品一区二区在线看 | 中文字母永久播放1区2区3区| 青青草视频手机免费在线观看| 91 亚洲视频在线观看| 人人妻人人爽人人添夜| 日本最新一二三区不卡在线| 最后99天全集在线观看| 成年午夜影片国产片| 国产性色生活片毛片春晓精品| 激情小视频国产在线| 一二三区在线观看视频| 五色婷婷综合狠狠爱| 久久久久久9999久久久久| 57pao国产一区二区| 国产在线观看黄色视频| 黄色成年网站午夜在线观看| 孕妇奶水仑乱A级毛片免费看| 999九九久久久精品| 亚洲黄色av网站免费播放| 国产福利小视频二区| 成人激情文学网人妻| 一区二区麻豆传媒黄片| 亚洲自拍偷拍精品网| 国产精品一区二区久久久av| 亚洲偷自拍高清视频| 91国偷自产一区二区三区精品| 97a片免费在线观看| 中文字幕 码 在线视频| 五十路在线观看完整版| 亚洲av色图18p| 国产三级影院在线观看| 精品久久久久久高潮| 精品国产成人亚洲午夜| 肏插流水妹子在线乐播下载| 11久久久久久久久久久| 天美传媒mv视频在线观看| 91‖亚洲‖国产熟女| 日本少妇的秘密免费视频| 日韩欧美一级精品在线观看| 国产欧美精品免费观看视频| 国产精品久久久久久久女人18| 极品性荡少妇一区二区色欲| 欧美精品欧美极品欧美视频| 国产janese在线播放| 日本成人不卡一区二区| av乱码一区二区三区| 亚洲成人国产av在线| 中文字幕人妻一区二区视频| 青娱乐在线免费视频盛宴| 毛片av在线免费看| 男人的天堂在线黄色| 亚洲中文精品人人免费| yy96视频在线观看| 成人sm视频在线观看| 亚洲日本一区二区三区| 亚洲人妻国产精品综合| 91极品大一女神正在播放| 中文字幕亚洲久久久| 97精品成人一区二区三区| 国产黄色高清资源在线免费观看|