日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

apache poi_将HTML转换为Apache POI的RichTextString

發布時間:2023/12/3 HTML 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 apache poi_将HTML转换为Apache POI的RichTextString 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

apache poi

1.概述

在本教程中,我們將構建一個將HTML作為輸入的應用程序,并使用提供HTML的RichText表示形式創建Microsoft Excel工作簿。 為了生成Microsoft Excel工作簿,我們將使用Apache POI 。 為了分析HTML,我們將使用Jericho。

Github上提供了本教程的完整源代碼。

2.什么是耶利哥?

Jericho是一個Java庫 ,它允許對HTML文檔的各個部分(包括服務器端標簽)進行分析和操作,同時逐字再現任何無法識別或無效HTML。 它還提供了高級HTML表單操作功能。 它是一個開放源代碼庫,使用以下許可證發行: Eclipse公共許可證(EPL) , GNU通用公共許可證(LGPL)和Apache許可證 。

我發現Jericho非常易于使用,可以實現將HTML轉換為RichText的目標。

3. pom.xml

這是我們正在構建的應用程序所需的依賴項。 請注意,對于此應用程序,我們必須使用Java 9 。 這是因為我們使用的java.util.regex appendReplacement方法自Java 9起才可用。

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.5.9.RELEASE</version><relativePath /> <!-- lookup parent from repository --> </parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><java.version>9</java.version> </properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-batch</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 --><dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId><version>3.7</version></dependency><dependency><groupId>org.springframework.batch</groupId><artifactId>spring-batch-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.15</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.15</version></dependency><!-- https://mvnrepository.com/artifact/net.htmlparser.jericho/jericho-html --><dependency><groupId>net.htmlparser.jericho</groupId><artifactId>jericho-html</artifactId><version>3.4</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><optional>true</optional></dependency><!-- legacy html allow --><dependency><groupId>net.sourceforge.nekohtml</groupId><artifactId>nekohtml</artifactId></dependency> </dependencies>

4.網頁– Thymeleaf

我們使用Thymeleaf來創建一個基本頁面,該頁面具有帶有文本區域的表單。 Github上提供 Thymeleaf頁面的源代碼。 如果愿意,可以使用RichText編輯器替換此textarea,例如CKEditor。 我們只需要注意使用適當的setData方法使AJAX的數據正確即可。 在Spring Boot中,以前有一個關于CKeditor的教程,標題為CKEditor,名為AJAX 。

5.控制器

在我們的控制器中,我們將自動裝配JobLauncher和一個Spring Batch作業,我們將創建一個名為GenerateExcel的作業 。 通過自動裝配這兩個類,當POST請求發送到“ / export”時,我們可以按需運行Spring Batch Job GenerateExcel 。

要注意的另一件事是,為了確保Spring Batch作業將運行一次以上,我們在此代碼中包含唯一參數: addLong(“ uniqueness”,System.nanoTime())。toJobParameters() 。 如果我們不包括唯一參數,則可能會發生錯誤,因為只能創建和執行唯一的JobInstances,否則Spring Batch無法區分第一個JobInstance和第二個JobInstance 。

@Controller public class WebController {private String currentContent;@AutowiredJobLauncher jobLauncher;@AutowiredGenerateExcel exceljob; @GetMapping("/")public ModelAndView getHome() {ModelAndView modelAndView = new ModelAndView("index");return modelAndView;}@PostMapping("/export")public String postTheFile(@RequestBody String body, RedirectAttributes redirectAttributes, Model model)throws IOException, JobExecutionAlreadyRunningException, JobRestartException, JobInstanceAlreadyCompleteException, JobParametersInvalidException {setCurrentContent(body);Job job = exceljob.ExcelGenerator();jobLauncher.run(job, new JobParametersBuilder().addLong("uniqueness", System.nanoTime()).toJobParameters());return "redirect:/";}//standard getters and setters}

6.批處理作業

在批處理作業的步驟1中,我們調用getCurrentContent()方法來獲取傳遞到Thymeleaf表單中的內容,創建一個新的XSSFWorkbook,指定一個任意的Microsoft Excel Sheet選項卡名稱,然后將所有三個變量都傳遞到createWorksheet方法中我們將在本教程的下一步中進行以下操作:

@Configuration @EnableBatchProcessing @Lazy public class GenerateExcel {List<String> docIds = new ArrayList<String>();@Autowiredprivate JobBuilderFactory jobBuilderFactory;@Autowiredprivate StepBuilderFactory stepBuilderFactory;@AutowiredWebController webcontroller;@AutowiredCreateWorksheet createexcel;@Beanpublic Step step1() {return stepBuilderFactory.get("step1").tasklet(new Tasklet() {@Overridepublic RepeatStatus execute(StepContribution stepContribution, ChunkContext chunkContext) throws Exception, JSONException {String content = webcontroller.getCurrentContent();System.out.println("content is ::" + content);Workbook wb = new XSSFWorkbook();String tabName = "some";createexcel.createWorkSheet(wb, content, tabName);return RepeatStatus.FINISHED;}}).build();}@Beanpublic Job ExcelGenerator() {return jobBuilderFactory.get("ExcelGenerator").start(step1()).build();}}

我們還在其他教程中介紹了Spring Batch,例如將XML轉換為JSON + Spring Batch和Spring Batch CSV Processing 。

7. Excel創建服務

我們使用各種類來創建我們的Microsoft Excel文件。 在將HTML轉換為RichText時,順序很重要,因此這將是重點。

7.1 RichTextDetails

一個帶有兩個參數的類:一個字符串,其內容將成為RichText,一個字體映射。

public class RichTextDetails {private String richText;private Map<Integer, Font> fontMap;//standard getters and setters@Overridepublic int hashCode() {// The goal is to have a more efficient hashcode than standard one.return richText.hashCode();}

7.2 RichTextInfo

一個POJO,它將跟蹤RichText的位置以及其他內容:

public class RichTextInfo {private int startIndex;private int endIndex;private STYLES fontStyle;private String fontValue;// standard getters and setters, and the like

7.3樣式

一個包含要處理HTML標記的枚舉。 我們可以根據需要添加以下內容:

public enum STYLES {BOLD("b"), EM("em"), STRONG("strong"), COLOR("color"), UNDERLINE("u"), SPAN("span"), ITALLICS("i"), UNKNOWN("unknown"),PRE("pre");// standard getters and setters

7.4 TagInfo

POJO跟蹤標簽信息:

public class TagInfo {private String tagName;private String style;private int tagType;// standard getters and setters

7.5 HTML為RichText

這不是一個小類,所以讓我們按方法將其分解。

本質上,我們用div標簽將任意HTML包圍起來,因此我們知道我們在尋找什么。 然后,我們在div標簽中查找所有元素,將每個元素添加到RichTextDetails的ArrayList中,然后將整個ArrayList傳遞給mergeTextDetails方法。 mergeTextDetails返回RichtextString,這是我們需要設置單元格值的內容:

public RichTextString fromHtmlToCellValue(String html, Workbook workBook){Config.IsHTMLEmptyElementTagRecognised = true;Matcher m = HEAVY_REGEX.matcher(html);String replacedhtml = m.replaceAll("");StringBuilder sb = new StringBuilder();sb.insert(0, "<div>");sb.append(replacedhtml);sb.append("</div>");String newhtml = sb.toString();Source source = new Source(newhtml);List<RichTextDetails> cellValues = new ArrayList<RichTextDetails>();for(Element el : source.getAllElements("div")){cellValues.add(createCellValue(el.toString(), workBook));}RichTextString cellValue = mergeTextDetails(cellValues);return cellValue;}

如上所述,我們在此方法中傳遞了RichTextDetails的ArrayList。 Jericho的設置采用布爾值來識別空標簽元素,例如
:已識別Config.IsHTMLEmptyElementTag。 在與在線富文本編輯器打交道時,這可能很重要,因此我們將其設置為true。 因為我們需要跟蹤元素的順序,所以我們使用LinkedHashMap而不是HashMap。

private static RichTextString mergeTextDetails(List<RichTextDetails> cellValues) {Config.IsHTMLEmptyElementTagRecognised = true;StringBuilder textBuffer = new StringBuilder();Map<Integer, Font> mergedMap = new LinkedHashMap<Integer, Font>(550, .95f);int currentIndex = 0;for (RichTextDetails richTextDetail : cellValues) {//textBuffer.append(BULLET_CHARACTER + " ");currentIndex = textBuffer.length();for (Entry<Integer, Font> entry : richTextDetail.getFontMap().entrySet()) {mergedMap.put(entry.getKey() + currentIndex, entry.getValue());}textBuffer.append(richTextDetail.getRichText()).append(NEW_LINE);}RichTextString richText = new XSSFRichTextString(textBuffer.toString());for (int i = 0; i < textBuffer.length(); i++) {Font currentFont = mergedMap.get(i);if (currentFont != null) {richText.applyFont(i, i + 1, currentFont);}}return richText;}

如上所述,我們使用Java 9來將StringBuilder與java.util.regex.Matcher.appendReplacement結合使用 。 為什么? 那是因為StringBuffer的運行速度比StringBuilder慢。 StringBuffer函數被同步以確保線程安全,因此速度較慢。

我們使用Deque而不是Stack,因為Deque接口提供了更完整和一致的LIFO堆棧操作集:

static RichTextDetails createCellValue(String html, Workbook workBook) {Config.IsHTMLEmptyElementTagRecognised = true;Source source = new Source(html);Map<String, TagInfo> tagMap = new LinkedHashMap<String, TagInfo>(550, .95f);for (Element e : source.getChildElements()) {getInfo(e, tagMap);}StringBuilder sbPatt = new StringBuilder();sbPatt.append("(").append(StringUtils.join(tagMap.keySet(), "|")).append(")");String patternString = sbPatt.toString();Pattern pattern = Pattern.compile(patternString);Matcher matcher = pattern.matcher(html);StringBuilder textBuffer = new StringBuilder();List<RichTextInfo> textInfos = new ArrayList<RichTextInfo>();ArrayDeque<RichTextInfo> richTextBuffer = new ArrayDeque<RichTextInfo>();while (matcher.find()) {matcher.appendReplacement(textBuffer, "");TagInfo currentTag = tagMap.get(matcher.group(1));if (START_TAG == currentTag.getTagType()) {richTextBuffer.push(getRichTextInfo(currentTag, textBuffer.length(), workBook));} else {if (!richTextBuffer.isEmpty()) {RichTextInfo info = richTextBuffer.pop();if (info != null) {info.setEndIndex(textBuffer.length());textInfos.add(info);}}}}matcher.appendTail(textBuffer);Map<Integer, Font> fontMap = buildFontMap(textInfos, workBook);return new RichTextDetails(textBuffer.toString(), fontMap);}

我們可以在這里看到RichTextInfo的使用位置:

private static Map<Integer, Font> buildFontMap(List<RichTextInfo> textInfos, Workbook workBook) {Map<Integer, Font> fontMap = new LinkedHashMap<Integer, Font>(550, .95f);for (RichTextInfo richTextInfo : textInfos) {if (richTextInfo.isValid()) {for (int i = richTextInfo.getStartIndex(); i < richTextInfo.getEndIndex(); i++) {fontMap.put(i, mergeFont(fontMap.get(i), richTextInfo.getFontStyle(), richTextInfo.getFontValue(), workBook));}}}return fontMap;}

我們在哪里使用STYLES枚舉:

private static Font mergeFont(Font font, STYLES fontStyle, String fontValue, Workbook workBook) {if (font == null) {font = workBook.createFont();}switch (fontStyle) {case BOLD:case EM:case STRONG:font.setBoldweight(Font.BOLDWEIGHT_BOLD);break;case UNDERLINE:font.setUnderline(Font.U_SINGLE);break;case ITALLICS:font.setItalic(true);break;case PRE:font.setFontName("Courier New");case COLOR:if (!isEmpty(fontValue)) {font.setColor(IndexedColors.BLACK.getIndex());}break;default:break;}return font;}

我們正在使用TagInfo類來跟蹤當前標簽:

private static RichTextInfo getRichTextInfo(TagInfo currentTag, int startIndex, Workbook workBook) {RichTextInfo info = null;switch (STYLES.fromValue(currentTag.getTagName())) {case SPAN:if (!isEmpty(currentTag.getStyle())) {for (String style : currentTag.getStyle().split(";")) {String[] styleDetails = style.split(":");if (styleDetails != null && styleDetails.length > 1) {if ("COLOR".equalsIgnoreCase(styleDetails[0].trim())) {info = new RichTextInfo(startIndex, -1, STYLES.COLOR, styleDetails[1]);}}}}break;default:info = new RichTextInfo(startIndex, -1, STYLES.fromValue(currentTag.getTagName()));break;}return info;}

我們處理HTML標簽:

private static void getInfo(Element e, Map<String, TagInfo> tagMap) {tagMap.put(e.getStartTag().toString(),new TagInfo(e.getStartTag().getName(), e.getAttributeValue("style"), START_TAG));if (e.getChildElements().size() > 0) {List<Element> children = e.getChildElements();for (Element child : children) {getInfo(child, tagMap);}}if (e.getEndTag() != null) {tagMap.put(e.getEndTag().toString(),new TagInfo(e.getEndTag().getName(), END_TAG));} else {// Handling self closing tagstagMap.put(e.getStartTag().toString(),new TagInfo(e.getStartTag().getName(), END_TAG));}}

7.6創建工作表

使用StringBuilder,我創建了一個要寫入FileOutPutStream的字符串。 在實際應用中,應由用戶定義。 我在兩個不同的行上附加了文件夾路徑和文件名。 請將文件路徑更改為您自己的文件路徑。

sheet.createRow(0)在第一行創建一行,而dataRow.createCell(0)在該行的列A中創建一個單元格。

public void createWorkSheet(Workbook wb, String content, String tabName) {StringBuilder sbFileName = new StringBuilder();sbFileName.append("/Users/mike/javaSTS/michaelcgood-apache-poi-richtext/");sbFileName.append("myfile.xlsx");String fileMacTest = sbFileName.toString();try {this.fileOut = new FileOutputStream(fileMacTest);} catch (FileNotFoundException ex) {Logger.getLogger(CreateWorksheet.class.getName()).log(Level.SEVERE, null, ex);}Sheet sheet = wb.createSheet(tabName); // Create new sheet w/ Tab namesheet.setZoom(85); // Set sheet zoom: 85%// content rich textRichTextString contentRich = null;if (content != null) {contentRich = htmlToExcel.fromHtmlToCellValue(content, wb);}// begin insertion of values into cellsRow dataRow = sheet.createRow(0);Cell A = dataRow.createCell(0); // Row NumberA.setCellValue(contentRich);sheet.autoSizeColumn(0);try {/// Write the output to a filewb.write(fileOut);fileOut.close();} catch (IOException ex) {Logger.getLogger(CreateWorksheet.class.getName()).log(Level.SEVERE, null, ex);}}

8.演示

我們訪問localhost:8080 。

我們用一些HTML輸入一些文本:

我們打開excel文件,然后看到我們創建的RichText:

9.結論

我們可以看到將HTML轉換為Apache POI的RichTextString類并不是一件容易的事。 但是,對于商業應用程序而言,將HTML轉換為RichTextString至關重要,因為在Microsoft Excel文件中,可讀性很重要。 我們構建的應用程序的性能可能還有改進的余地,但我們涵蓋了構建此類應用程序的基礎。

完整的源代碼可在Github上找到。

翻譯自: https://www.javacodegeeks.com/2018/01/converting-html-richtextstring-apache-poi.html

apache poi

總結

以上是生活随笔為你收集整理的apache poi_将HTML转换为Apache POI的RichTextString的全部內容,希望文章能夠幫你解決所遇到的問題。

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

丁香九月激情综合 | 96精品高清视频在线观看软件特色 | av一级片在线观看 | 九九热在线视频免费观看 | 亚洲激情在线播放 | 美女免费视频一区二区 | 国产偷v国产偷∨精品视频 在线草 | 欧美成人中文字幕 | 中文欧美字幕免费 | 亚洲欧美国产视频 | 久久亚洲婷婷 | 午夜视频一区二区 | 在线高清av| 日韩久久电影 | 91欧美日韩国产 | 狠狠色丁香婷婷综合基地 | av女优中文字幕在线观看 | 久久久久久久久久久久国产精品 | 九九久久国产 | 人人爱在线视频 | 日韩免费av网址 | 91伊人| 天堂av免费看 | 久草在线国产 | 成年人黄色免费看 | 亚洲精品在线视频网站 | 欧美日韩在线观看一区 | 精品av在线播放 | 日韩精品视频网站 | 高清免费av在线 | 国产高清视频免费在线观看 | 国产一卡久久电影永久 | 欧美人交a欧美精品 | 色网站在线 | 亚洲,国产成人av | 久久a热6 | 久久综合爱| 亚洲天天看 | 久久久久国产精品免费免费搜索 | 午夜骚影 | 毛片网在线观看 | 久艹视频在线观看 | 99免费观看视频 | 中文字幕在线视频免费播放 | 亚洲国产视频网站 | 天天弄天天操 | 一级电影免费在线观看 | 国产精品美女久久久久久网站 | 国产.精品.日韩.另类.中文.在线.播放 | 激情欧美一区二区免费视频 | 国产精品永久久久久久久www | 中文字幕在线免费看 | 成人免费视频免费观看 | 久久久这里有精品 | 在线观看亚洲精品视频 | 波多野结衣综合网 | 亚洲 综合 国产 精品 | 亚洲动漫在线观看 | 精品国内自产拍在线观看视频 | www.黄色小说.com | 国产黄色片免费在线观看 | 久草久视频 | 日韩在线无| 天天天天天天操 | 伊人伊成久久人综合网站 | 成人免费观看大片 | 欧美午夜性 | 婷婷 中文字幕 | 日韩精品免费一区二区在线观看 | 国产精品一区二区三区免费视频 | 国产剧情在线一区 | 久爱精品在线 | 国产精品成人一区二区三区 | 91热视频在线观看 | 国产精品少妇 | 日韩中文字幕在线不卡 | 国产又粗又硬又爽视频 | 六月丁香婷婷在线 | 国产精品第一页在线 | av先锋中文字幕 | 中国一级特黄毛片大片久久 | 久久综合在线 | 成人免费视频网 | 久久激五月天综合精品 | 国内偷拍精品视频 | 天堂在线一区二区三区 | 亚洲精品国产精品国自产 | 久久九九网站 | 五月激情婷婷丁香 | 久久综合福利 | 福利一区二区在线 | 久久久久免费网站 | 国产精品久久久久久模特 | 狠狠狠狠狠狠狠狠干 | 美女黄久久 | 亚洲精品自在在线观看 | 欧美极度另类性三渗透 | 特级西西444www高清大视频 | 国产在线观看国语版免费 | 视频二区在线 | 爱色婷婷| 一级国产视频 | 日韩乱码中文字幕 | 亚洲国产日韩av | 国产精品久久久久婷婷 | 日本一区二区三区免费观看 | 亚洲视频 中文字幕 | 色综合天天色综合 | 国产精品扒开做爽爽的视频 | 在线亚洲免费视频 | 973理论片235影院9 | aaaaaa毛片| 在线蜜桃视频 | 日韩视频一区二区在线观看 | 高清有码中文字幕 | 激情视频亚洲 | 免费看污黄网站 | 亚洲成人精品久久 | 天天操天| 狂野欧美激情性xxxx欧美 | 欧美一级看片 | 人人玩人人爽 | 国产日韩欧美在线播放 | 九九视频在线播放 | 在线小视频 | 五月婷久久 | 久久精品综合 | 插久久 | 99久久国产免费,99久久国产免费大片 | а中文在线天堂 | 精品国产精品一区二区夜夜嗨 | 最新av在线免费观看 | 在线视频精品播放 | 国产麻豆精品一区二区 | 日韩av视屏 | 五月婷婷一区二区三区 | 18女毛片| 日韩三级中文字幕 | 九色视频网址 | 93久久精品日日躁夜夜躁欧美 | 91av在线播放视频 | av在线电影免费观看 | 国产中文字幕网 | a视频在线| 久久天天躁狠狠躁夜夜不卡公司 | 精品国自产在线观看 | 国产一二三区av | 国产免费视频一区二区裸体 | 日日操日日操 | 亚洲欧美日韩在线一区二区 | 亚洲少妇久久 | 黄色在线看网站 | 久久综合9988久久爱 | 夜色资源站国产www在线视频 | 欧美成年黄网站色视频 | av在线影视 | 精品视频999 | 日韩免费三区 | 99久久精品国产毛片 | 91亚洲精品久久久中文字幕 | 久二影院| 国产精品大全 | 久久在线视频精品 | 99精品视频一区二区 | 在线国产精品一区 | 日日夜色 | 欧美a级在线免费观看 | 黄色在线观看网站 | 日韩a级黄色片 | 婷婷丁香色综合狠狠色 | 亚洲涩综合 | 成人夜晚看av | 在线视频一二三 | 91久久久久久久一区二区 | 日韩视频免费观看高清 | 91久久精品一区二区二区 | 欧美精品乱码久久久久 | 免费h视频| 天天做天天射 | 日本久久久久久科技有限公司 | 国产在线黄 | 日韩精品中文字幕有码 | 国产一区二区三区高清播放 | 91色九色 | 97av超碰 | 欧美精品在线观看一区 | 精品一区二区在线播放 | 国产精品久久99综合免费观看尤物 | 久久中文字幕视频 | 亚洲精品99久久久久久 | av一级二级 | 天堂av官网 | 日韩精品免费专区 | 一级电影免费在线观看 | 在线观看国产成人av片 | 精品国产99国产精品 | 亚洲国产精品va在线看黑人动漫 | 国产真实精品久久二三区 | 午夜精品成人一区二区三区 | 97视频在线免费观看 | 日韩黄色免费电影 | 日韩欧美一区二区三区黑寡妇 | 亚洲热视频 | av在线观| 色视频在线观看免费 | 日韩免费观看高清 | 国产美女精彩久久 | 激情小说网站亚洲综合网 | 亚洲精品午夜国产va久久成人 | av中文字幕第一页 | 色资源网免费观看视频 | 成人黄视频 | 中文字幕 第二区 | 在线观看日韩精品 | 天天干天天干天天操 | 色综合天天 | 日韩成年视频 | 国产精品成人品 | 日韩欧美在线观看一区 | 91九色丨porny丨丰满6 | 亚洲乱码久久 | 中文在线a天堂 | 精品国产一区二区三区在线观看 | 日韩va在线观看 | 欧美最猛性xxxxx(亚洲精品) | 免费av小说 | 亚洲精品一区二区三区高潮 | 九九综合九九 | 国产精品理论视频 | 操操操干干干 | 久久久久久毛片精品免费不卡 | 国产午夜激情视频 | 91精品国产综合久久福利 | 中文亚洲欧美日韩 | 久久九九九九 | 午夜 在线| 国产精品毛片网 | 人人干人人干人人干 | 国产日韩欧美在线看 | 丁香激情五月 | 国产一级视频在线免费观看 | 丝袜精品视频 | 中文字幕第 | 久久无码精品一区二区三区 | 99一级片 | 亚洲成a人片77777kkkk1在线观看 | 99久久久国产精品免费99 | 激情开心色 | 久久撸在线视频 | 国产精品成人一区二区三区吃奶 | 日韩精品一区二区三区丰满 | 在线精品在线 | 国产精品麻豆视频 | 婷婷色 亚洲 | 久久天天躁夜夜躁狠狠躁2022 | 久久资源总站 | 婷香五月 | 少妇性xxx | 亚州欧美视频 | 日韩超碰 | 日韩在线资源 | 午夜精品一区二区三区在线 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 玖玖爱国产在线 | 在线观看国产www | 麻豆va一区二区三区久久浪 | 久一网站| 午夜电影中文字幕 | 亚洲精品短视频 | 成人a在线 | 在线观看精品一区 | 五月开心激情 | 在线观看中文字幕 | 999电影免费在线观看 | 三级av免费观看 | 国产丝袜美腿在线 | 久热这里有精品 | 91传媒视频在线观看 | 日韩久久精品 | av夜夜操 | 日韩久久午夜一级啪啪 | 精品亚洲一区二区三区 | 中文字幕免费在线 | www免费在线观看 | 国产精品成人久久 | 国产精品午夜av | 精品国产欧美一区二区三区不卡 | 超碰99在线| 欧美男女爱爱视频 | 久久久久国产一区二区三区四区 | 午夜免费福利视频 | 欧美一区二区三区在线 | .国产精品成人自产拍在线观看6 | 久久久久久电影 | 99久久婷婷国产综合精品 | 午夜视频在线观看欧美 | 国产一二三在线视频 | 狠狠色丁香婷婷综合基地 | 免费情缘| 人人射人人插 | 久久久久久国产精品亚洲78 | 国产成人福利片 | 天天射天天干天天爽 | 欧美激情精品 | 久久久久久综合网天天 | 国产手机精品视频 | 亚洲成人av电影在线 | 国产 一区二区三区 在线 | 国产精品毛片久久久久久久久久99999999 | 91成熟丰满女人少妇 | 狠狠色综合网站久久久久久久 | 亚洲精品中文字幕视频 | 伊人影院99 | 国产免费又爽又刺激在线观看 | 亚洲国产精品一区二区久久,亚洲午夜 | 亚洲国产最新 | 国产麻豆精品久久 | 国产污视频在线观看 | 网站免费黄 | 992tv在线观看 | 国产中文字幕av | 天天玩天天干天天操 | www.香蕉| 超碰久热| 国产精品久久久亚洲 | 亚洲五月综合 | 成人av av在线 | av高清不卡 | 亚洲尺码电影av久久 | 黄色小网站在线观看 | 国产一区在线精品 | 亚洲日本va在线观看 | 一区二区三区www | 亚洲成年人免费网站 | 久久久久国产精品一区 | 成人全视频免费观看在线看 | 成人h动漫在线看 | 黄色片视频在线观看 | 日韩在线播放av | 婷婷电影在线观看 | 中文字幕中文字幕中文字幕 | 欧美 日韩 视频 | 色婷婷久久久 | 日日爱999 | 欧美性免费 | 手机av在线网站 | 中文在线免费看视频 | 成片免费观看视频999 | 91av在线视频免费观看 | www178ccom视频在线| 欧美日韩在线电影 | 亚洲电影影音先锋 | 五月婷在线播放 | 天天天干天天天操 | 欧美极品少妇xxxx | 91视频亚洲 | 精品自拍sae8—视频 | 男女拍拍免费视频 | 亚洲精品videossex少妇 | 成人午夜av电影 | 亚洲综合色网站 | 成人免费在线观看电影 | 人人爱爱人人 | 亚洲精品影视在线观看 | 色99网| 国产69精品久久久久久 | www黄在线| 天天操人| 精品久久久久久久久久久久久久久久久久 | 亚洲欧美视频在线播放 | 国产精品999久久久 久产久精国产品 | 久久在线电影 | 亚洲精品一区二区三区高潮 | 黄色大片视频网站 | 人人插人人艹 | 国产又粗又猛又黄又爽视频 | 成人免费观看视频网站 | 91久草视频| 亚洲精品日韩一区二区电影 | 一级淫片在线观看 | 97在线免费视频观看 | 五月婷婷开心中文字幕 | 天天艹天天 | av九九九| av片子在线观看 | 国产精品av一区二区 | 国产成人一区二区三区影院在线 | 色婷婷狠狠操 | 午夜av在线播放 | 精品视频成人 | 人人艹人人 | 成人a大片 | 热精品 | 婷婷综合 | 91在线播放视频 | 久久黄色a级片 | 色婷婷激情电影 | 99高清视频有精品视频 | 国产精品久久久久国产精品日日 | 国产高清中文字幕 | 黄污网| 欧美男男激情videos | 操久 | 中文字幕高清在线播放 | 欧美精品乱码久久久久久 | 99精品一区二区三区 | 在线中文字幕观看 | 国产伦精品一区二区三区四区视频 | 久免费视频 | 九九视频免费 | 日韩激情片在线观看 | 亚洲成人资源 | 久久深爱网 | 国产一区二区三精品久久久无广告 | 人人添人人澡人人澡人人人爽 | 久草视频免费观 | 中文字幕av播放 | 色婷婷综合激情 | 狠狠的操狠狠的干 | 国产精品久久久久久久久毛片 | 国产一区二区精 | 99色人| 久久综合中文字幕 | 嫩草伊人久久精品少妇av | 亚洲电影图片小说 | 久久99热这里只有精品 | av在线网站观看 | 一级做a视频 | 成年人免费在线观看网站 | 99视频在线免费看 | 国产小视频在线观看免费 | 国产69精品久久久久久久久久 | 国产视频二区三区 | 麻花豆传媒一二三产区 | 精品国产一区二区三区男人吃奶 | 亚洲黄色小说网址 | 中文字幕在线视频一区 | 99热这里只有精品在线观看 | 久草网免费 | 日精品在线观看 | 天堂在线一区二区三区 | 波多野结衣电影一区 | 色成人亚洲网 | 天天干.com| 精品亚洲va在线va天堂资源站 | 国产精品一区二区久久 | 成人免费观看视频网站 | a黄色片在线观看 | 精品亚洲视频在线观看 | 99久久er热在这里只有精品66 | 日本aa在线| 蜜臀av麻豆 | 亚洲欧美国内爽妇网 | 中文字幕av在线电影 | 91九色综合| 91av九色| 国产视频一区二区在线播放 | 日韩精品一区二区三区免费视频观看 | 免费看的黄色小视频 | 日韩欧美在线综合网 | 国产美女精品视频免费观看 | 黄色a级片在线观看 | 91色国产在线 | 在线免费观看视频你懂的 | 开心激情网五月天 | 丁香六月色 | 在线视频精品 | 午夜 久久 tv | 91麻豆精品国产91久久久无需广告 | 精品日本视频 | 日韩网站在线看片你懂的 | 久久精品亚洲一区二区三区观看模式 | 亚洲精品视频网站在线观看 | 狠狠色狠狠色综合日日小说 | 黄色精品久久久 | 免费在线国产精品 | 亚洲永久精品在线 | 国产婷婷vvvv激情久 | 最新久久免费视频 | 亚洲精品一区二区18漫画 | 国内精品久久久 | 欧美日韩高清一区二区 国产亚洲免费看 | 成年人免费看 | 在线观看视频精品 | 手机在线欧美 | 草久在线播放 | 色综合天天色 | 午夜国产一区二区 | 日韩免费成人av | 国产99久久99热这里精品5 | 国产又粗又猛又爽又黄的视频先 | 500部大龄熟乱视频 欧美日本三级 | 97超碰人人干 | 国产精品久久99精品毛片三a | 国产不卡免费 | 国产一级一片免费播放放 | 久久天天操 | 国产精品久久久久久久久毛片 | 99久久这里有精品 | 天天草夜夜 | 午夜精品久久久久久久久久 | 黄色免费观看 | 亚洲天堂网在线观看视频 | 久操视频在线免费看 | 中文字幕亚洲欧美日韩2019 | 免费观看黄色12片一级视频 | 国产69久久精品成人看 | 久久久黄视频 | 久草在线手机观看 | 天天天干天天射天天天操 | 欧美日韩在线免费观看 | 久久久精品福利视频 | 麻豆国产精品永久免费视频 | 日韩网站视频 | 亚洲国产午夜视频 | 国产精品一区二区白浆 | 亚洲精品玖玖玖av在线看 | 97视频在线观看播放 | 男女视频国产 | 欧美日韩二区在线 | 国产精品一区二区免费视频 | 激情欧美丁香 | 亚洲综合在线播放 | 天天干,天天草 | 91完整版在线观看 | 在线黄色国产 | 日韩一三区 | 超碰com | 国产日韩在线一区 | 97在线精品 | 人人插人人舔 | 精品免费国产一区二区三区四区 | 黄色午夜网站 | 亚洲国产视频直播 | 久久99日韩 | 成人亚洲综合 | 精品国产中文字幕 | 色噜噜在线观看 | 91亚·色 | 中文有码在线 | 99在线观看视频网站 | 欧美国产日韩一区二区三区 | 欧美国产精品一区二区 | 97超碰免费在线观看 | 国产偷国产偷亚洲清高 | 久久久久一区二区三区四区 | 国产成人免费在线 | 亚洲精品视频在线免费播放 | 久久久久久久久久久久99 | 国产成人一区二区三区电影 | 色婷婷激情综合 | 九九亚洲精品 | www.看片网站 | 久久精品中文字幕一区二区三区 | 就操操久久 | 91av综合| 亚洲精品资源在线观看 | 狠狠色狠狠色综合日日92 | 二区精品视频 | 香蕉视频网址 | 日韩在线资源 | 久久综合桃花 | 五月婷婷影院 | 国产精品99久久久久久武松影视 | av日韩中文| 亚洲精品久久久蜜桃直播 | 亚洲成人软件 | 少妇bbw搡bbbb搡bbb | 中文日韩在线 | 久久亚洲专区 | 欧美日韩高清不卡 | 国产精品99久久久久久有的能看 | 日日夜夜精品免费观看 | 国产精品区二区三区日本 | 久久成人免费电影 | 久久久91精品国产一区二区精品 | 国产一区二区三区高清播放 | 亚洲精品免费在线播放 | 在线观看中文字幕一区二区 | 精品国产美女 | 日韩一级黄色片 | 日韩精品中文字幕有码 | 美国av片在线观看 | 久久午夜精品影院一区 | 久久精品99国产国产 | 国产九九精品视频 | 久久人人爽人人人人片 | 亚洲资源片| 午夜丁香网 | 久久久91精品国产一区二区精品 | 午夜99 | 亚洲第一中文网 | 国产精品久久久久永久免费 | 激情欧美一区二区三区免费看 | 欧美性做爰猛烈叫床潮 | 久久99网站 | 亚洲欧美视频一区二区三区 | 色资源中文字幕 | 久久精品99国产精品亚洲最刺激 | 91香蕉视频| 97视频免费在线观看 | 天天射日| 久草线 | 色91在线视频 | 丁香婷婷色月天 | 日韩高清在线一区二区三区 | 亚洲视频一区二区三区在线观看 | 免费观看丰满少妇做爰 | 99欧美视频 | 国精产品999国精产品视频 | 日韩欧美一区二区三区黑寡妇 | 亚洲国产人午在线一二区 | 亚洲一区二区高潮无套美女 | 蜜桃麻豆www久久囤产精品 | 97成人免费| 伊人久在线 | www免费看| 成人黄色免费观看 | 91麻豆产精品久久久久久 | 狠狠色丁香婷婷综合久小说久 | 色欧美88888久久久久久影院 | 黄色国产大片 | 国产精品嫩草影院99网站 | 最近中文字幕免费视频 | 欧美日韩另类在线 | 国产一级淫片免费看 | 人人看97| 99在线视频观看 | 国产精品久久久久影院 | 欧美天堂视频在线 | 久久久免费高清视频 | 久久国产精品一区二区三区四区 | 在线看一区 | 九九九九九九精品任你躁 | 国产成视频在线观看 | 中文一区在线 | 午夜精品福利在线 | 欧美激情操 | 日韩a免费 | 久久日本视频 | 欧美精品久久久久a | 91网站在线视频 | 国内成人精品2018免费看 | 欧美a视频 | 成人午夜电影在线播放 | 人人草人人草 | 成人在线播放视频 | 久色伊人 | 右手影院亚洲欧美 | 91一区啪爱嗯打偷拍欧美 | 99久久久久免费精品国产 | 久久久久久毛片精品免费不卡 | 亚洲性少妇性猛交wwww乱大交 | 精品久久久久久久久亚洲 | 99视频精品免费视频 | 久久精品看片 | 九九精品久久久 | av解说在线 | 精品一区二区久久久久久久网站 | 中文字幕亚洲高清 | 在线免费观看羞羞视频 | 日韩二区在线观看 | 亚洲精品久久久蜜桃直播 | h视频日本 | 国产成人福利在线 | av电影在线观看 | 欧美色黄 | 超碰97中文 | 久久99国产精品免费网站 | 国产精彩视频一区 | 九九欧美视频 | 亚洲黄在线观看 | 天天操夜夜操国产精品 | 91免费网站在线观看 | 成人高清av在线 | 91在线精品视频 | 国产精品女人网站 | 亚洲综合丁香 | 亚洲精品合集 | 手机看片国产日韩 | 精品久久久久久久久久久久 | 成人a在线观看 | 91九色在线观看视频 | 一区二区三区在线观看中文字幕 | av女优中文字幕在线观看 | 五月婷婷久久丁香 | 人人超在线公开视频 | 婷婷色中文网 | 国产免费区 | 亚洲专区在线播放 | 免费亚洲黄色 | 中文字幕国产 | 亚洲第一区精品 | 成年人免费看的视频 | 日韩亚洲国产中文字幕 | 欧美精品天堂 | 粉嫩av一区二区三区四区五区 | 91av免费看| av亚洲产国偷v产偷v自拍小说 | 日韩成人av在线 | 免费日韩 | 婷婷六月天丁香 | 欧美韩国在线 | 精品在线免费视频 | 久久精品激情 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 狠狠色丁香婷婷综合最新地址 | 成人性生交大片免费观看网站 | 麻豆视频在线播放 | 日韩久久午夜一级啪啪 | ww亚洲ww亚在线观看 | 日韩在线观看视频在线 | 四虎精品成人免费网站 | 黄污网站在线 | 色婷婷综合久色 | 99精品一区| 国产精品免费在线播放 | 美女视频网站久久 | 欧美激情xxxx性bbbb | 国产精品久久久久久久7电影 | 99免费观看视频 | 久久影视中文字幕 | 99一区二区三区 | www.久久com | 蜜臀av性久久久久蜜臀av | 日本精品视频在线观看 | av理论电影| 国产亚洲日本 | 成人在线播放免费观看 | 亚洲精品乱码久久久久久蜜桃不爽 | aaa黄色毛片 | 国产高清av免费在线观看 | 国产午夜精品在线 | 91成年人视频 | 日本中文一区二区 | 午夜色婷婷 | 人人爱人人添 | 草久久久久 | 免费看成人 | 国产精品区免费视频 | 日日干天夜夜 | 成人av片免费看 | 国产999在线观看 | 在线天堂中文在线资源网 | 日韩深夜在线观看 | 久久99热久久99精品 | 国产在线视频资源 | av在线免费网站 | 中文字幕观看视频 | 日韩女同一区二区三区在线观看 | 免费人成在线观看网站 | 久久久电影 | 中文字幕成人一区 | 欧美日韩高清不卡 | 九九免费在线观看 | www.五月天色| 色片网站在线观看 | 韩国视频一区二区三区 | 99精品福利视频 | 久久久免费精品视频 | 久久国色夜色精品国产 | 另类老妇性bbwbbw高清 | 久久免费的精品国产v∧ | 西西大胆免费视频 | 精品女同一区二区三区在线观看 | 免费av福利| 日韩电影一区二区在线观看 | 免费在线观看视频一区 | 91视频在线免费看 | 天天激情综合 | 久久黄色a级片 | 色在线免费观看 | 黄色在线看网站 | 午夜色大片在线观看 | 2019中文字幕网站 | 亚洲视频分类 | 久久国产精品99久久久久久丝袜 | 亚洲狠狠操| 在线观看色网站 | 国产成人99av超碰超爽 | 亚洲砖区区免费 | 亚洲狠狠干 | 99精品视频网 | 狠狠狠色丁香婷婷综合久久五月 | 久久96 | 国产精品成人一区二区 | 黄色特级片 | 97超级碰 | 久久精品国产精品 | 亚洲精品视频www | 亚洲国产精品成人av | 香蕉视频网站在线观看 | 伊人成人激情 | 奇米影视8888在线观看大全免费 | 在线免费高清视频 | 午夜少妇av| 成人午夜电影在线 | 久久精品中文字幕免费mv | 在线观看免费视频你懂的 | 亚洲精品国产成人 | 久久免费黄色网址 | 国产欧美综合视频 | 精品播放 | www.99久久.com| 香蕉视频网址 | 久久国产精品一国产精品 | 久草视频在线免费看 | 久久经典国产视频 | 天天摸日日摸人人看 | 午夜精品久久久久久久爽 | 99久久99久久综合 | 美女在线观看av | 奇米四色影狠狠爱7777 | 91探花在线视频 | 青青河边草观看完整版高清 | 十八岁以下禁止观看的1000个网站 | 欧美日韩国产精品爽爽 | 日p视频在线观看 | 91精品国产综合久久婷婷香蕉 | 国产精品第2页 | 最近日本字幕mv免费观看在线 | 91精品在线免费观看视频 | 色综合久久五月 | 久久免费观看视频 | av在线一二三区 | 欧美日韩免费视频 | 国产精品18久久久久白浆 | 在线免费观看羞羞视频 | 日本黄色免费在线 | 国产爽妇网 | 亚洲狠狠操 | 91在线视频免费播放 | 久久成电影| 久久综合桃花 | 日韩专区在线播放 | 国产又粗又猛又色 | 伊人在线视频 | 精品国精品自拍自在线 | 国产精品theporn| 中文字幕色播 | 久99热| 久久99国产综合精品免费 | 国产精品久久久久久久毛片 | 久久99精品国产麻豆宅宅 | 91精品国产91久久久久福利 | 午夜国产一区二区三区四区 | 91在线视频网址 | 毛片黄色一级 | 欧美大片第1页 | 国色天香永久免费 | 成年人毛片在线观看 | 亚洲精品国产精品乱码在线观看 | 成人福利av| 麻豆影视网 | 日韩精品视频在线观看网址 | 久久夜夜爽| 青草视频在线播放 | 日日干天天射 | 在线看国产一区 | 成人在线免费观看视视频 | 97在线观看免费高清完整版在线观看 | 久久婷婷久久 | 成年人免费av | av在线在线| 日韩精品黄| 日韩精品视 | 欧美成人播放 | 四虎影视精品 | 99久久久久| 91精品国产99久久久久 | www.夜夜草 | 在线观看网站你懂的 | av日韩在线网站 | 中文字幕乱码亚洲精品一区 | 国产三级香港三韩国三级 | 黄色小说免费在线观看 | 97操碰 | 在线看片一区 | 91人人澡人人爽 | 日韩午夜在线观看 | 99久久婷婷国产 | 日日干av| 日韩在线视频一区二区三区 | 探花视频在线观看 | 日本夜夜草视频网站 | 国产精品麻豆99久久久久久 | 国产一区二区在线免费 | 午夜精品久久久久久久99 | 久久婷婷精品视频 | 一区二区精品视频 | 91麻豆精品91久久久久同性 | 日韩欧美一区二区在线 | 天天色成人 | 99久久精品免费 | 久久国内精品 | 97电影手机版 | 99热这里只有精品在线观看 | 探花在线观看 | 久久精品99国产精品 | 国产99久久久国产精品免费看 | 欧美日韩三区二区 | 黄色电影网站在线观看 | 97理论电影| 超碰人人草 | 97av精品 | 美女中文字幕 | 亚洲精品在线资源 | 亚洲九九| 日韩精品中文字幕在线 | 少妇自拍av| 色综合久久久久综合体桃花网 | 色就是色综合 | 精品国产诱惑 | 国产青春久久久国产毛片 | 日韩精品三区四区 | 日韩欧美极品 | 激情婷婷色 | 黄色亚洲免费 | 国内久久久久 | 91精品免费视频 | 精品一区精品二区 | 免费观看丰满少妇做爰 | 五月婷婷丁香网 | 国产成人一二片 | 国内精品在线一区 | 91丨九色丨丝袜 | 久久这里只有精品首页 | 欧美日高清视频 | 亚洲精品国产精品乱码不99热 | 久久视频国产 | 干亚洲少妇 | 天天干夜夜 | 久久久一本精品99久久精品 | 久久久久亚洲国产精品 | 欧美精品一区二区性色 | 成年人黄色大片在线 | 亚洲欧美国内爽妇网 | 一区二区伦理电影 | 中文字幕韩在线第一页 | 亚洲最大成人免费网站 | 波多野结衣日韩 | 国产精品美女网站 | 精品一区二区三区在线播放 | 制服丝袜一区二区 | 久久三级视频 | 91在线视频播放 | 不卡的av电影 | 免费网站在线观看成人 | 丰满少妇在线 | 国产v欧美| 91x色| 日韩二区三区在线 | japanesefreesex中国少妇 | 91人人爽久久涩噜噜噜 | 综合网天天 | 一区二区三区四区影院 | 日韩中文字 | 国产精品免费观看视频 | 欧美黑人巨大xxxxx | 在线日韩中文 | 午夜精品久久久久久久久久久久久久 | 免费网站在线观看成人 | 99视频国产在线 | 亚洲最新在线视频 | 人人讲下载 | 久久亚洲欧美日韩精品专区 | 久久成人国产 | 一区二区三区电影在线播 | 亚洲免费av网站 | 国产黄在线看 | 日日夜夜操av | 很黄很污的视频网站 | 日韩免费看 | 久久久香蕉视频 | 人人干网站 | 久久免费视频在线观看30 | 日韩av中文在线观看 | 国产99久久九九精品 | 精品在线你懂的 | 亚洲激情小视频 | 日韩精品综合在线 | 日韩精品专区在线影院重磅 | 成年人黄色免费视频 | 成人久久久精品国产乱码一区二区 | 免费网站在线观看成人 | 国产成人精品一区二三区 | 色综合天天色综合 | 日韩午夜电影 | 国产精品久久久久久一区二区 | 蜜臀av夜夜澡人人爽人人 | 在线有码中文 | 国产欧美最新羞羞视频在线观看 | 91在线日韩 | 国产一区高清在线 | 亚洲国产高清在线观看视频 | 精品国产资源 | 日韩在线国产 | 99久久国产免费免费 |