精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Java高級(jí)特性-注解:注解實(shí)現(xiàn)Excel導(dǎo)出功能

開(kāi)發(fā) 后端
注解是 Java 的一個(gè)高級(jí)特性,Spring 更是以注解為基礎(chǔ),發(fā)展出一套“注解驅(qū)動(dòng)編程”。

[[355260]]

 注解是 Java 的一個(gè)高級(jí)特性,Spring 更是以注解為基礎(chǔ),發(fā)展出一套“注解驅(qū)動(dòng)編程”。

這聽(tīng)起來(lái)高大上,但畢竟是框架的事,我們也能用好注解嗎?

的確,我們很少有機(jī)會(huì)自己寫注解,導(dǎo)致我們搞不清楚注解是怎么回事,更別提用好注解了。

既然這樣,我們就從具體的工作出發(fā),開(kāi)發(fā)一個(gè) Excel 導(dǎo)出功能。我相信,你在搞懂這個(gè)例子后,就能明白注解是怎么個(gè)用法。

Excel 導(dǎo)出-需求拆解

在后臺(tái)管理系統(tǒng)中,常常需要把數(shù)據(jù)導(dǎo)出 Excel 表。

比如,在雙十一過(guò)后,銷售部要把商品訂單錄入到 Excel 表,財(cái)務(wù)部要把支付訂單錄入到 Excel 表,然后各部門匯總分析,最后找個(gè)時(shí)間討論怎么改善公司的服務(wù)。

你想呀,雙十一的訂單成千上萬(wàn),靠人工錄入,少說(shuō)也要花三四天,而且還特別容易出錯(cuò)。所以,你必須開(kāi)發(fā) Excel 導(dǎo)出功能。

那么,具體怎么做呢?

上次我們提到,注解想發(fā)揮作用,有三個(gè)要素:定義、使用、讀取。這次,我們就利用注解的三個(gè)特性,來(lái)實(shí)現(xiàn) Excel 導(dǎo)出功能,設(shè)計(jì)過(guò)程是這樣的。

第一步,我們要?jiǎng)?chuàng)建不同的 Excel 模型。雙十一過(guò)后,銷售部要訂單數(shù)據(jù),財(cái)務(wù)部要支付數(shù)據(jù),兩個(gè)部門要的 Excel 表肯定也不一樣,這就得幫每個(gè)部門創(chuàng)建不同的 Excel 模型,他們拿到想要的數(shù)據(jù)。

第二步,我們要根據(jù) Excel 模型,來(lái)導(dǎo)出 Excel 表。

看到這,你應(yīng)該明白 Excel 導(dǎo)出的設(shè)計(jì)過(guò)程了。接下來(lái),我們就來(lái)一步步實(shí)現(xiàn)這個(gè)功能。

創(chuàng)建 Excel 模型

創(chuàng)建 Excel 模型,涉及到注解三要素中的定義、使用。

首先,定義 Excel 注解,我們直接看關(guān)鍵代碼。 

  1. @Target({ElementType.FIELD})  
  2. @Retention(RetentionPolicy.RUNTIME)  
  3. public @interface ExcelField {  
  4.     /**  
  5.      * 導(dǎo)出字段標(biāo)題  
  6.      */  
  7.     String title();     
  8.     /**  
  9.      * 導(dǎo)出字段排序(升序)  
  10.      */  
  11.     int sort() default 0;     
  12.     /**  
  13.      * 對(duì)齊方式(0:自動(dòng);1:靠左;2:居中;3:靠右)  
  14.      */  
  15.     int align() default 0;     

這里用到了兩個(gè)元注解@Retention和@Target。@Target代表這個(gè)注解只能放在成員變量上;@Retention代表這個(gè)注解要加載到 JVM 內(nèi)存,我們可以用反射來(lái)讀取注解。

此外,注解還有 3 個(gè)成員變量,分別對(duì)應(yīng):Excel 的字段標(biāo)題、字段排序、對(duì)齊方式,方便大家微調(diào)表格。到了這,定義 Excel 注解就完成了。

接下來(lái),使用注解,我們還是直接看代碼。 

  1. public class OrderModel {  
  2.     @ExcelField(title = "訂單號(hào)"align = 2sort = 20 
  3.     private String orderNo;  
  4.     @ExcelField(title = "金額"align = 2sort = 20
  5.     private String amount;   
  6.      // 創(chuàng)建時(shí)間  
  7.     private Date createTime;    
  8.      // 省略 getter/setter 方法  

訂單模型有 3 個(gè)字段:訂單號(hào)、金額、創(chuàng)建時(shí)間,但這里注解只加到訂單號(hào)、金額上,表示這兩個(gè)字段會(huì)導(dǎo)出 Excel 表,而創(chuàng)建時(shí)間會(huì)忽略,你可以看看這副圖片。

至此,我們完成了定義注解、使用注解,得到了一個(gè) Excel 模型。但要想實(shí)現(xiàn)導(dǎo)出功能,還必須根據(jù)這個(gè)模型,生成出 Excel 表。

讀取 Excel 模型

讀取 Excel 模型,涉及到注解三要素中的讀取。 我們需要讀取注解,生成 Excel 表,這主要分成 3 個(gè)步驟:初始化 Excel 表對(duì)象—>寫入數(shù)據(jù)到 Excel 表對(duì)象—>輸出文件。

第一步,初始化 Excel 表對(duì)象。在這一步中,我們要根據(jù) Excel 模型,生成一個(gè) Excel 表對(duì)象,要?jiǎng)?chuàng)建這幾個(gè)東西:標(biāo)題、表頭、樣式等等。我們來(lái)看代碼。 

  1. public class ExcelExporter {  
  2.     // ...省略無(wú)數(shù)代碼  
  3.     /***************************** 初始化 Excel 表對(duì)象 ****************************/  
  4.     /**  
  5.      * 構(gòu)造函數(shù)  
  6.      * @param title 表格標(biāo)題,傳“空值”,表示無(wú)標(biāo)題  
  7.      * @param cls   excel模型對(duì)象  
  8.      */  
  9.     public ExcelExporter(String title, Class<?> cls) {  
  10.         // 獲取注解list  
  11.         Field[] fs = cls.getDeclaredFields();  
  12.         for (Field f : fs) {  
  13.             ExcelField ef = f.getAnnotation(ExcelField.class); 
  14.             if (ef != null) {  
  15.                 annotationList.add(new Object[]{ef, f});  
  16.             }  
  17.         }  
  18.         annotationList.sort(comparing(o -> ((ExcelField) o[0]).sort()));  
  19.         // 通過(guò)注解獲取表頭  
  20.         List<String> headerList = new ArrayList<>();  
  21.         for (Object[] os : annotationList) {  
  22.             String t = ((ExcelField) os[0]).title();  
  23.             headerList.add(t);  
  24.         }  
  25.         // 初始化excel表:創(chuàng)建excel表、添加表標(biāo)題、創(chuàng)建表頭等等  
  26.         initialize(title, headerList);  
  27.     }  

在初始化的時(shí)候,我們先從 Excel 模型對(duì)象中讀取注解,獲得一個(gè)注解列表;然后,再?gòu)淖⒔饬斜碇校x取 title-字段標(biāo)題;最后,再初始化 Excel 表對(duì)象,包括:創(chuàng)建 Excel 表對(duì)象、添加表標(biāo)題、創(chuàng)建表頭、添加樣式。

第二步,寫入數(shù)據(jù)到 Excel 表對(duì)象。在這一步中,我們要把 Java 的列表數(shù)據(jù)寫到 Excel 表對(duì)象里,讓這些數(shù)據(jù)能變成 Excel 表的一行行信息。還是來(lái)看代碼。 

  1. public class ExcelExporter {  
  2.     /***************************** 初始化 Excel 表對(duì)象 ****************************/  
  3.     // ...省略無(wú)數(shù)代碼  
  4.     /***************************** 寫入數(shù)據(jù)到 Excel 表對(duì)象 ****************************/  
  5.     /**  
  6.      * 寫入數(shù)據(jù)  
  7.      * @return list 數(shù)據(jù)列表  
  8.      */  
  9.     public <E> ExcelExporter setDataList(List<E> list) {  
  10.         for (E dataObj : list) {  
  11.             // 添加行  
  12.             Row row = this.addRow();  
  13.             // 獲取數(shù)據(jù),并寫入單元格  
  14.             int cellNo = 0 
  15.             for (Object[] os : annotationList) {  
  16.                 // 獲取成員變量的值  
  17.                 Object value = null 
  18.                 try {  
  19.                     value = Reflections.invokeGetter(dataObj, ((Field) os[1]).getName());  
  20.                 } catch (Exception ex) {  
  21.                     log.info(ex.toString());  
  22.                     value = "" 
  23.                 }  
  24.                 if (value == null) {  
  25.                     value = "" 
  26.                 }  
  27.                 // 寫入單元格  
  28.                 ExcelField ef = (ExcelField) os[0];  
  29.                 this.addCell(row, cellNo++, value, ef.align());  
  30.             }  
  31.         }  
  32.         return this;  
  33.     }  

我們先傳入一個(gè)數(shù)據(jù)列表 dataList,然后用循環(huán)來(lái)遍歷 dataList,在這個(gè)循環(huán)中,我們不斷把數(shù)據(jù)寫進(jìn) Excel 表對(duì)象里,具體操作是:創(chuàng)建了一個(gè)空白行,利用注解獲取成員變量里的值,最后寫進(jìn) Excel 表的單元格里。

第三步,輸出文件。在這一步中,就是 Excel 表對(duì)象變成一個(gè)文件,來(lái)看下最后的代碼吧。 

  1. public class ExcelExporter {  
  2.     /***************************** 初始化 Excel 表對(duì)象 ****************************/  
  3.     // ...省略無(wú)數(shù)代碼  
  4.     /***************************** 寫入數(shù)據(jù)到 Excel 表對(duì)象 ****************************/  
  5.     // ...省略無(wú)數(shù)代碼  
  6.     /***************************** 輸出相關(guān) ****************************/  
  7.     /**  
  8.      * 輸出到文件  
  9.      * @param fileName 輸出文件名,加上絕對(duì)路徑  
  10.      */  
  11.     public ExcelExporter writeFile(String fileName) throws IOException {  
  12.         FileOutputStream os = new FileOutputStream(fileName);  
  13.         this.write(os);  
  14.         return this;  
  15.     }  

輸出文件就沒(méi)什么好說(shuō)的了,就是指定文件名,然后把文件輸出到指定的地方。

到了這,讀取 Excel 模型就完成了。

當(dāng)然,讀取 Excel 模型涉及到注解的讀取,這是最難理解的地方,因?yàn)樽x取注解要用到 Java 另一個(gè)高級(jí)特性—反射。而且,注解一般是用來(lái)簡(jiǎn)化業(yè)務(wù),如果你對(duì)業(yè)務(wù)沒(méi)有深刻的了解,是很難用好的。

限于篇幅,我只講了最核心的代碼,項(xiàng)目的完整代碼放在文末的鏈接上,大家可以好好看看。

寫在最后

注解想發(fā)揮作用,有三個(gè)要素:定義、使用、讀取。這篇文章利用了注解的三要素,實(shí)現(xiàn)了 Excel 導(dǎo)出功能。

這分成兩步。第一步,創(chuàng)建 Excel 模型,這涉及到注解三要素中的定義、使用;第二步,讀取 Excel 模型,這涉及到注解三要素中的讀取。

總之,注解一般用來(lái)簡(jiǎn)化業(yè)務(wù),你要想用好注解,不但得熟練掌握 Java 的高級(jí)用法,還得對(duì)業(yè)務(wù)有深刻的理解。 

 

責(zé)任編輯:龐桂玉 來(lái)源: segmentfault
相關(guān)推薦

2021-12-30 12:30:01

Java注解編譯器

2023-08-26 11:36:31

Java框架Spring

2023-02-03 08:21:30

excelMySQL

2020-09-22 09:41:09

前端

2014-04-15 15:45:22

Java8Java8教程

2023-02-25 10:04:21

JavaExcel導(dǎo)出功能

2023-03-30 16:16:00

Java自定義注解開(kāi)發(fā)

2014-04-15 09:53:54

Java8類型注解

2024-04-28 08:20:52

Controller接口URL

2019-12-24 10:19:44

泛型反射注解

2024-09-02 07:54:36

2012-02-09 10:42:24

Java

2021-03-01 07:55:41

Java annotation注解

2023-02-07 09:17:19

Java注解原理

2023-11-16 12:35:00

Java程序

2021-03-26 09:37:12

Java開(kāi)發(fā)代碼

2023-05-08 08:11:49

@Component使用場(chǎng)景時(shí)序圖

2025-05-19 01:00:00

2014-12-24 10:24:55

Java

2011-07-19 09:38:41

一維數(shù)組Junit靜態(tài)成員
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

成人午夜在线影视| 国产精品久久久久久69| 伊人精品一区| 欧美日韩精品免费| 国产a级黄色大片| 欧美一区二区黄片| 秋霞国产午夜精品免费视频| 久久精品国产亚洲精品2020| 香蕉在线观看视频| 粉嫩一区二区三区| 亚洲精品欧美专区| 日韩精彩视频| 草草视频在线播放| 爽爽淫人综合网网站| 久久成人18免费网站| 国产老熟女伦老熟妇露脸| 亚洲精品555| 午夜久久久影院| 一区二区不卡视频| 视频二区在线| 国产精品18久久久久久久网站| 欧美一区二区三区免费视| 国产成人在线网址| 免费短视频成人日韩| 91精品国产综合久久福利| 黄色片一级视频| 欧美日韩经典丝袜| 国产精品五月天| 精品久久蜜桃| 亚洲第一天堂影院| 久久99久久久欧美国产| 欧美一级高清免费| 久久久久久久久久久网| 日韩av片子| 亚洲欧美三级伦理| 性欧美18—19sex性高清| 色综合久久久| 一本高清dvd不卡在线观看| 91亚洲精品国产| 精品欧美色视频网站在线观看| 国产亚洲一区二区三区四区| 国产日韩精品推荐| 亚洲av综合色区无码一二三区| 美女国产一区二区三区| 国产精品xxx视频| 日日噜噜噜噜人人爽亚洲精品| 国内久久精品| 欧美精品性视频| 男人av资源站| 91精品一区国产高清在线gif| 在线观看久久久久久| 国产免费看av| 性欧美lx╳lx╳| 日韩精品在线视频| 少妇精品一区二区三区| 欧美黄色网视频| 亚洲国产一区二区三区在线观看| 亚洲成人福利视频| 亚洲天堂中文字幕在线观看| 日韩女优电影在线观看| 国产人妖在线观看| 日本免费一区二区视频| 日韩午夜在线影院| 国产精品嫩草69影院| 欧美一级片网址| 欧美一级高清片| 粗大的内捧猛烈进出视频| 精品一区二区三区免费看| 3d成人动漫网站| 女人扒开双腿让男人捅| 91国内精品| 亚洲国产精品福利| 女尊高h男高潮呻吟| 国产91精品对白在线播放| 国产性猛交xxxx免费看久久| 国产一区二区三区视频播放| 欧美不卡在线| 97人人做人人爱| 日本中文字幕在线| 日本视频在线一区| 91在线色戒在线| 蜜桃91麻豆精品一二三区| 91影院在线免费观看| 日本视频一区二区在线观看| 欧美18一19xxx性| 曰韩精品一区二区| 免费无码国产v片在线观看| 在线日本欧美| 欧美一级专区免费大片| 噜噜噜在线视频| 欧美肥老太太性生活| 欧美久久精品午夜青青大伊人| 久久精品国产亚洲av无码娇色| 销魂美女一区二区三区视频在线| 国产精品激情自拍| 亚洲精品中文字幕成人片| 国产午夜亚洲精品不卡| 亚洲激情免费视频| 婷婷六月国产精品久久不卡| 日韩一区二区三区视频| 香蕉网在线播放| 91高清一区| 日本一本a高清免费不卡| 国产精品伦一区二区三区| av中文字幕在线不卡| 亚洲一区二区精品在线| av资源在线| 538prom精品视频线放| 精品人妻一区二区三区视频| 亚洲无中文字幕| 奇米成人av国产一区二区三区| 国产偷拍一区二区| 国产日韩成人精品| 日本熟妇人妻xxxx| 亚洲天堂网站| 亚洲偷熟乱区亚洲香蕉av| 久久久久无码国产精品不卡| 免费在线一区观看| 久久精品国产99精品国产亚洲性色| 91社区在线| 色婷婷av一区二区三区软件| 香蕉久久久久久av成人| 天堂网在线观看国产精品| 日本道色综合久久影院| 污视频在线免费| 亚洲影院理伦片| 尤物网站在线看| 日韩免费看片| 国产精国产精品| 欧美色图另类| 亚洲成va人在线观看| 国产男女无遮挡猛进猛出| 日韩www.| 国产精品男女猛烈高潮激情| 日本中文字幕一区二区有码在线| 亚洲国产精品人人做人人爽| 天堂va欧美va亚洲va老司机| 色97色成人| 国产欧美精品久久久| 国产免费a∨片在线观看不卡| 岛国av一区二区| www.美色吧.com| 狠狠88综合久久久久综合网| 114国产精品久久免费观看| 黄色动漫在线观看| 欧美人牲a欧美精品| 亚洲色图日韩精品| 免费精品视频在线| 亚洲精品一区二| 久久婷婷五月综合色丁香| 在线看日韩av| 一本大道伊人av久久综合| 欧美激情在线看| 欧美成人三级在线播放| 91麻豆国产自产在线观看亚洲| 国产精品免费久久久久影院| a天堂在线资源| 欧美日韩一区久久| 日本爱爱小视频| 国产尤物一区二区| 国产一级做a爰片久久毛片男| 1204国产成人精品视频| 久久男人资源视频| 五月婷婷丁香六月| 欧美午夜宅男影院在线观看| av黄色免费网站| 奇米一区二区三区| youjizz.com亚洲| 亚洲免费一区三区| 韩国三级电影久久久久久| 亚洲av成人精品日韩在线播放| 欧美日韩国产一区二区三区| 级毛片内射视频| 久久成人免费日本黄色| 女女同性女同一区二区三区按摩| 免费一区二区三区在线视频| 性色av一区二区三区| 精品无人乱码| 欧美久久久影院| 亚洲国产综合久久| 国产日产欧美精品一区二区三区| 国内外成人免费在线视频| 欧美日韩视频| 欧美亚洲另类在线一区二区三区| 成人免费一区| 欧美国产日本在线| 可以免费看污视频的网站在线| 欧美性色aⅴ视频一区日韩精品| 成人免费毛片xxx| 成人黄色a**站在线观看| 日韩精品一区二区三区色欲av| 久久国产电影| 国产视频在线观看一区| 2019年精品视频自拍| 欧美丰满少妇xxxxx| 巨骚激情综合| 欧美一区二区三区视频在线观看| 五月天婷婷综合网| 国产精品高清亚洲| 国产视频久久久久久| 精品一区二区国语对白| 日本欧美黄色片| 亚洲精品va| 日本精品一区二区三区高清 久久 日本精品一区二区三区不卡无字幕 | 成人综合婷婷国产精品久久 | www.久久草| 日韩欧美看国产| 欧美激情18p| 在线播放日本| 亚洲老头同性xxxxx| 国产高清在线免费| 91久久线看在观草草青青| 久久精品www人人爽人人| 国产日韩欧美精品电影三级在线| 69xxx免费视频| 国精品**一区二区三区在线蜜桃| 欧美牲交a欧美牲交aⅴ免费下载| 影视亚洲一区二区三区| 神马一区二区影院| 亚洲福利网站| 国产精品久久7| 成人av在线播放| 国产精品久久久久高潮| 男女羞羞在线观看| 欧美激情精品久久久久久蜜臀| 888av在线| 国产午夜精品视频| 黄色电影免费在线看| 亚洲国产高潮在线观看| 精品人妻午夜一区二区三区四区| 欧美日韩中文字幕一区| 国产视频1区2区| 富二代精品短视频| 日韩黄色精品视频| 亚洲一区二区三区中文字幕| 最新一区二区三区| 亚洲欧美另类小说视频| 制服丨自拍丨欧美丨动漫丨| 亚洲国产成人一区二区三区| 91久久免费视频| 久久日韩精品一区二区五区| 亚洲国产果冻传媒av在线观看| 豆国产96在线|亚洲| 老女人性生活视频| 国产成人自拍网| 一区二区在线免费观看视频| 国产一区二区三区四区在线观看| 国产农村妇女精品久久| 国内精品不卡在线| 1314成人网| 国产91丝袜在线观看| 精品久久久久久无码人妻| 成人手机电影网| 久久性爱视频网站| 91丝袜高跟美女视频| 亚洲av片不卡无码久久| 久久网站热最新地址| 国产在线综合视频| 国产精品热久久久久夜色精品三区 | 日韩一区二区三区电影在线观看 | 精品免费视频一区二区| 国精品人妻无码一区二区三区喝尿 | 国产污视频网站| 精品久久久久久亚洲精品| 久久久久99精品成人片我成大片| 欧美视频在线观看免费| 久久久精品视频网站 | 性色av蜜臀av| 精品国内二区三区| 色视频在线看| 中日韩午夜理伦电影免费 | 国产精品不卡一区二区三区| 情侣偷拍对白清晰饥渴难耐| 亚洲女女做受ⅹxx高潮| 久久午夜无码鲁丝片| 五月天久久比比资源色| 成人黄色激情视频| 欧美高清视频在线高清观看mv色露露十八 | 亚洲视频免费| 欧美性久久久久| 老司机精品视频在线| xxxx视频在线观看| 久久久久久电影| 黄色a级片在线观看| 午夜久久久影院| 一区二区三区播放| 日韩hd视频在线观看| 男人的天堂在线视频免费观看| 蜜臀久久99精品久久久久久宅男 | 在线一区二区观看| 99精品在线视频观看| 日韩成人在线网站| 久久精品视频观看| 欧美一级淫片丝袜脚交| 欧美日韩午夜电影网| 日韩电影免费观看高清完整| 欧美精品aa| 色戒在线免费观看| 91免费观看国产| 久久久久久久久毛片| 色诱亚洲精品久久久久久| 国产成人精品一区二三区四区五区| 亚洲精品日韩欧美| 丝袜在线观看| 国产精品永久免费在线| 色婷婷av一区二区三区丝袜美腿| 亚洲第一页在线视频| 午夜宅男久久久| 91精品人妻一区二区三区蜜桃2| 欧美韩国日本综合| 91九色丨porny丨肉丝| 欧美一区二区三区免费在线看 | 国产精品香蕉| 中文字幕色一区二区| 天堂蜜桃91精品| 无码任你躁久久久久久老妇| 亚洲视频中文字幕| 这里只有精品国产| 亚洲免费电影一区| 国产盗摄一区二区| 亚洲影视中文字幕| 久久蜜桃av| 免费看a级黄色片| 91麻豆123| 国产小视频在线免费观看| 日韩视频123| 理论片午午伦夜理片在线播放| 国产999精品| 亚洲精品国产动漫| 国内性生活视频| av在线播放不卡| 国产网友自拍视频| 日韩欧美亚洲一区二区| 久久bbxx| 亚洲影院污污.| 久久久国产精品| 欧美成人手机在线视频| 国产精品久久久久婷婷| 91精东传媒理伦片在线观看| 国产性猛交xxxx免费看久久| 第四色男人最爱上成人网| 欧美一级爽aaaaa大片| 玖玖玖国产精品| 一级片手机在线观看| 欧美性生交xxxxxdddd| 欧美性孕妇孕交| 国产suv精品一区二区| 视频一区欧美| 国产又大又黄又粗又爽| 中文字幕+乱码+中文字幕一区| 国产真人无遮挡作爱免费视频| 亚洲欧美日韩第一区| 国产成人免费9x9x人网站视频 | 亚洲最大激情中文字幕| 亚洲精品va| www.四虎精品| 精品动漫一区二区| 国产色在线 com| 国产精品揄拍500视频| 久久精品亚洲人成影院 | 黄色动漫在线免费看| 久久久五月婷婷| 日本欧美www| 久久精品国产综合| 99香蕉久久| 免费欧美一级视频| 日本一区二区三区四区在线视频 | 成人黄色免费短视频| 亚洲精品视频一区二区三区| 国产在线不卡视频| 日本免费观看视| 在线播放日韩欧美| 国产一区二区三区| 69sex久久精品国产麻豆| 91免费视频观看| 97成人免费视频| 久久久久久久久网站| 国产乱码精品一区二区三区四区| 黄色小视频免费网站| 亚洲第一福利一区| h视频网站在线观看| 91九色在线观看| 99精品免费视频| 懂色av粉嫩av蜜臀av一区二区三区| 欧美一级专区免费大片| 新版的欧美在线视频| 正在播放一区二区三区| 暴力调教一区二区三区| 成人免费一区二区三区| 久久久久久久一| 日韩免费特黄一二三区| 午夜男人的天堂| 欧美顶级少妇做爰| 国模套图日韩精品一区二区| 中文字幕日韩一区二区三区| 99久久er热在这里只有精品66| 一区二区三区在线免费观看视频| 欧美黑人性视频| 欧美激情另类| 成人国产精品久久久网站|