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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java 填充模板

發布時間:2024/3/12 java 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java 填充模板 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近接了個任務,需要對模板進行填充,使用word模板進行填充,嘗試后,使用.docx的文檔。
以下是dome:

/*** 模板附件上傳*/@Override@Transactional(rollbackFor = Exception.class)public void legalConUploadTemplate(ConBase conBase) {/***1.先根據模板參數去法務獲取副本的流,獲取到后進行填充,然后保存到本地,然后再從本地獲取這附件,上傳到法務*/String legalId = baseSysVarClient.getValueByCode("conTemplateLegalId");//判斷是否已生成模板附件List<ConLegalFile> conLegalFileList = conLegalFileService.selectByConBaseIdAndName(conBase.getConBaseId(), "conBase");for (ConLegalFile file : conLegalFileList){this.deletelegalFile(file, conBase.getUpdateUserCode());}//獲取模板信息ConTemplateAttach attach = conTemplateAttachService.selectByLegalId(legalId);JSONObject js = new JSONObject();js.put("attachmentId",attach.getAttachmentId());js.put("mipAccount",conBase.getCreateUserCode());js.put("fileId",attach.getLegalId());byte[] legalDownLoad = this.legalDownLoad(js);List<ConItemCenter> info = conItemCenterService.getInfo(conBase.getConBaseId());InputStream inputStream = ConTemplateCtr.getInstance().print(new ByteArrayInputStream(legalDownLoad), conBase, info);//轉換成MultipartFileMultipartFile multipartFile = null;String name = conBase.getConName() + ".docx";try {multipartFile = new MockMultipartFile(name, name,ContentType.APPLICATION_OCTET_STREAM.toString(), inputStream);} catch (IOException e) {e.printStackTrace();}this.legalConUpload(multipartFile,"ContractNeedStamp","conBase",conBase.getConBaseId().toString(), conBase.getCreateUserCode());}

方法入口
InputStream inputStream = ConTemplateCtr.getInstance().print(new ByteArrayInputStream(legalDownLoad), conBase, info);
注意這行代碼,在這里面進行填充

import com.midea.dmr.common.utils.DateUtils; import com.midea.dmr.cont.domain.bean.ConBase; import com.midea.dmr.cont.domain.bean.ConItemCenter;import java.io.InputStream; import java.util.*;public class ConTemplateCtr {private ConTemplateCtr() {}private static class ConTemplateCtrInstance {private static final ConTemplateCtr INSTANCE = new ConTemplateCtr();}public static ConTemplateCtr getInstance() {return ConTemplateCtrInstance.INSTANCE;}/*** 模板替換*/public InputStream print(InputStream in, ConBase conBase, List<ConItemCenter> info) {// 模板全的路徑//String templatePaht = "D:\\物料制作年度框架協議.docx";// 輸出位置String outPath = "D:\\物料制作年度框架協議3.docx";Map<String, Object> paramMap = new HashMap(16);// 普通的占位符示例 參數數據結構 {str,str}paramMap.put("vendorName", conBase.getVendorName());Date effectiveTime = conBase.getEffectiveTime();paramMap.put("effectiveYear", DateUtils.getYear(effectiveTime));paramMap.put("effectiveMonth", DateUtils.getMonth(effectiveTime));paramMap.put("effectiveDay", DateUtils.getDay(effectiveTime));Date expirationTime = conBase.getExpirationTime();paramMap.put("expirationYear", DateUtils.getYear(expirationTime));paramMap.put("expirationMonth", DateUtils.getMonth(expirationTime));paramMap.put("expirationDay", DateUtils.getDay(expirationTime));paramMap.put("detailedAddress1", conBase.getDetailedAddress1());paramMap.put("vendorUserName", conBase.getVendorUserName());paramMap.put("vendorMobile", conBase.getVendorMobile());paramMap.put("vendorMail", conBase.getVendorMail());paramMap.put("operationCenterName", conBase.getOperationCenterName());List<List<String>> tbRow = new ArrayList();for (int i = 0; i < info.size(); i++) {List<String> tbRow1 = new ArrayList();ConItemCenter conItemCenter = info.get(i);tbRow1.add(conItemCenter.getCostemCode());tbRow1.add(conItemCenter.getProductName());tbRow1.add(conItemCenter.getMaterialProcessDesc());tbRow1.add(conItemCenter.getMaterialSpec());tbRow1.add(conItemCenter.getMaterialBulkSize());tbRow1.add(conItemCenter.getUomName());if (null != conItemCenter.getRealPrice()) {tbRow1.add(String.valueOf(conItemCenter.getRealPrice().setScale(2)));}tbRow.add(tbRow1);}//獲取參數paramMap.put(PoiWordUtils.addRowText + "tb1", tbRow);//模板渲染return DynWordUtils.process(paramMap, in, outPath);}}

這里主要是參數配置
//模板渲染
return DynWordUtils.process(paramMap, in, outPath);
后面的就是方式類
ConTemplateCtr類

package com.midea.dmr.cont.ctr;import com.midea.dmr.common.utils.DateUtils; import com.midea.dmr.cont.domain.bean.ConBase; import com.midea.dmr.cont.domain.bean.ConItemCenter;import java.io.InputStream; import java.util.*;public class ConTemplateCtr {private ConTemplateCtr() {}private static class ConTemplateCtrInstance {private static final ConTemplateCtr INSTANCE = new ConTemplateCtr();}public static ConTemplateCtr getInstance() {return ConTemplateCtrInstance.INSTANCE;}/*** 模板替換*/public InputStream print(InputStream in, ConBase conBase, List<ConItemCenter> info) {// 模板全的路徑//String templatePaht = "D:\\物料制作年度框架協議.docx";// 輸出位置String outPath = "D:\\物料制作年度框架協議3.docx";Map<String, Object> paramMap = new HashMap(16);// 普通的占位符示例 參數數據結構 {str,str}paramMap.put("vendorName", conBase.getVendorName());Date effectiveTime = conBase.getEffectiveTime();paramMap.put("effectiveYear", DateUtils.getYear(effectiveTime));paramMap.put("effectiveMonth", DateUtils.getMonth(effectiveTime));paramMap.put("effectiveDay", DateUtils.getDay(effectiveTime));Date expirationTime = conBase.getExpirationTime();paramMap.put("expirationYear", DateUtils.getYear(expirationTime));paramMap.put("expirationMonth", DateUtils.getMonth(expirationTime));paramMap.put("expirationDay", DateUtils.getDay(expirationTime));paramMap.put("detailedAddress1", conBase.getDetailedAddress1());paramMap.put("vendorUserName", conBase.getVendorUserName());paramMap.put("vendorMobile", conBase.getVendorMobile());paramMap.put("vendorMail", conBase.getVendorMail());paramMap.put("operationCenterName", conBase.getOperationCenterName());List<List<String>> tbRow = new ArrayList();for (int i = 0; i < info.size(); i++) {List<String> tbRow1 = new ArrayList();ConItemCenter conItemCenter = info.get(i);tbRow1.add(conItemCenter.getCostemCode());tbRow1.add(conItemCenter.getProductName());tbRow1.add(conItemCenter.getMaterialProcessDesc());tbRow1.add(conItemCenter.getMaterialSpec());tbRow1.add(conItemCenter.getMaterialBulkSize());tbRow1.add(conItemCenter.getUomName());if (null != conItemCenter.getRealPrice()) {tbRow1.add(String.valueOf(conItemCenter.getRealPrice().setScale(2)));}tbRow.add(tbRow1);}//獲取參數paramMap.put(PoiWordUtils.addRowText + "tb1", tbRow);//模板渲染return DynWordUtils.process(paramMap, in, outPath);}}

DynWordUtils類

package com.midea.dmr.cont.ctr;import org.apache.poi.openxml4j.opc.OPCPackage; import org.apache.poi.xwpf.usermodel.*; import org.apache.xmlbeans.XmlCursor; import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.io.*; import java.util.*;/*** Create by IntelliJ Idea 2018.2** @author: qyp* Date: 2019-10-25 14:48*/ public class DynWordUtils {private static final Logger logger = LoggerFactory.getLogger(DynWordUtils.class);/*** 被list替換的段落 被替換的都是oldParagraph*/private XWPFParagraph oldParagraph;/*** 參數*/private Map<String, Object> paramMap;/*** 當前元素的位置*/int n = 0;/*** 判斷當前是否是遍歷的表格*/boolean isTable = false;/*** 模板對象*/XWPFDocument templateDoc;/*** 默認字體的大小*/public static final int DEFAULT_FONT_SIZE = 10;/*** 重復模式的占位符所在的行索引*/private int currentRowIndex;/*** 入口** @param paramMap 模板中使用的參數* @param templatePaht 模板全路徑* @param outPath 生成的文件存放的本地全路徑*/public static void process(Map<String, Object> paramMap, String templatePaht, String outPath) {DynWordUtils dynWordUtils = new DynWordUtils();dynWordUtils.setParamMap(paramMap);dynWordUtils.createWord(templatePaht, outPath);}/*** 入口** @param paramMap 模板中使用的參數* @param outPath 生成的文件存放的本地全路徑*/public static InputStream process(Map<String, Object> paramMap, InputStream in, String outPath) {DynWordUtils dynWordUtils = new DynWordUtils();dynWordUtils.setParamMap(paramMap);return dynWordUtils.createWord(in, outPath);}/*** 生成動態的word** @param outPath*/public InputStream createWord(InputStream in, String outPath) {ByteArrayOutputStream outStream = null;InputStream inputStream = null;try {Date date = new Date();logger.info("生成動態的createWord_outPath:" + outPath);outStream = new ByteArrayOutputStream();templateDoc = new XWPFDocument(in);parseTemplateWord();logger.info("生成動態的createWord成功。" + date.getTime());templateDoc.write(outStream);inputStream = new ByteArrayInputStream(outStream.toByteArray());} catch (Exception e) {StackTraceElement[] stackTrace = e.getStackTrace();String className = stackTrace[0].getClassName();String methodName = stackTrace[0].getMethodName();int lineNumber = stackTrace[0].getLineNumber();logger.info("錯誤:第:" + lineNumber + "行, 類名:" + className + ", 方法名:" + methodName);logger.info("生成動態的word失敗_" + e.getMessage());} finally {if (outStream != null) {try {outStream.close();} catch (IOException e) {logger.info("關閉流失敗:" + e.getMessage());}}}return inputStream;}/*** 生成動態的word** @param templatePath* @param outPath*/public void createWord(String templatePath, String outPath) {FileOutputStream outStream = null;try {logger.info("生成動態的createWord_templatePath:" + templatePath + "_outPath:" + outPath);outStream = new FileOutputStream(outPath);templateDoc = new XWPFDocument(OPCPackage.open(templatePath));parseTemplateWord();templateDoc.write(outStream);} catch (Exception e) {StackTraceElement[] stackTrace = e.getStackTrace();String className = stackTrace[0].getClassName();String methodName = stackTrace[0].getMethodName();int lineNumber = stackTrace[0].getLineNumber();logger.info("錯誤:第:" + lineNumber + "行, 類名:" + className + ", 方法名:" + methodName);logger.info("createWord_生成動態的word失敗:{}", e.getMessage());} finally {if (outStream != null) {try {outStream.close();} catch (IOException e) {logger.info("createWord_關閉流失敗:" + e.getMessage());}}}}/*** 解析word模板*/public void parseTemplateWord() throws Exception {List<IBodyElement> elements = templateDoc.getBodyElements();for (; n < elements.size(); n++) {IBodyElement element = elements.get(n);// 普通段落if (element instanceof XWPFParagraph) {XWPFParagraph paragraph = (XWPFParagraph) element;oldParagraph = paragraph;if (paragraph.getParagraphText().isEmpty()) {continue;}delParagraph(paragraph);} else if (element instanceof XWPFTable) {// 表格isTable = true;XWPFTable table = (XWPFTable) element;delTable(table, paramMap);isTable = false;}}}/*** 處理段落*/private void delParagraph(XWPFParagraph paragraph) throws Exception {List<XWPFRun> runs = oldParagraph.getRuns();StringBuilder sb = new StringBuilder();for (XWPFRun run : runs) {String text = run.getText(0);if (text == null) {continue;}sb.append(text);run.setText("", 0);}placeholder(paragraph, runs, sb);}/*** 匹配傳入信息集合與模板** @param placeholder 模板需要替換的區域()* @param paramMap 傳入信息集合* @return 模板需要替換區域信息集合對應值*/public void changeValue(XWPFRun currRun, String placeholder, Map<String, Object> paramMap) throws Exception {String placeholderValue = placeholder;if (paramMap == null || paramMap.isEmpty()) {return;}Set<Map.Entry<String, Object>> textSets = paramMap.entrySet();for (Map.Entry<String, Object> textSet : textSets) {//匹配模板與替換值 格式${key}String mapKey = textSet.getKey();String docKey = PoiWordUtils.getDocKey(mapKey);if (placeholderValue.indexOf(docKey) != -1) {Object obj = textSet.getValue();// 需要添加一個listif (obj instanceof List) {placeholderValue = delDynList(placeholder, (List) obj);} else {placeholderValue = placeholderValue.replaceAll(PoiWordUtils.getPlaceholderReg(mapKey), String.valueOf(obj));}}}currRun.setText(placeholderValue, 0);}/*** 處理的動態的段落(參數為list)** @param placeholder 段落占位符* @param obj* @return*/private String delDynList(String placeholder, List obj) {String placeholderValue = placeholder;List dataList = obj;Collections.reverse(dataList);for (int i = 0, size = dataList.size(); i < size; i++) {Object text = dataList.get(i);// 占位符的那行, 不用重新創建新的行if (i == 0) {placeholderValue = String.valueOf(text);} else {XWPFParagraph paragraph = createParagraph(String.valueOf(text));if (paragraph != null) {oldParagraph = paragraph;}// 增加段落后doc文檔的element的size會隨著增加(在當前行的上面添加// 這里減操作是回退并解析新增的行(因為可能新增的帶有占位符,這里為了支持圖片和表格)if (!isTable) {n--;}}}return placeholderValue;}/*** 創建段落 <p></p>** @param texts*/public XWPFParagraph createParagraph(String... texts) {// 使用游標創建一個新行XmlCursor cursor = oldParagraph.getCTP().newCursor();XWPFParagraph newPar = templateDoc.insertNewParagraph(cursor);// 設置段落樣式newPar.getCTP().setPPr(oldParagraph.getCTP().getPPr());copyParagraph(oldParagraph, newPar, texts);return newPar;}/*** 處理表格(遍歷)** @param table 表格* @param paramMap 需要替換的信息集合*/public void delTable(XWPFTable table, Map<String, Object> paramMap) throws Exception {List<XWPFTableRow> rows = table.getRows();for (int i = 0, size = rows.size(); i < size; i++) {XWPFTableRow row = rows.get(i);currentRowIndex = i;// 如果是動態添加行 直接處理后返回if (delAndJudgeRow(table, paramMap, row)) {return;}}}/*** 判斷并且是否是動態行,并且處理表格占位符** @param table 表格對象* @param paramMap 參數map* @param row 當前行* @return* @throws Exception*/private boolean delAndJudgeRow(XWPFTable table, Map<String, Object> paramMap, XWPFTableRow row) throws Exception {// 當前行是動態行標志if (PoiWordUtils.isAddRow(row)) {List<XWPFTableRow> xwpfTableRows = addAndGetRows(table, row, paramMap);// 回溯添加的行,這里是試圖處理動態添加的圖片for (XWPFTableRow tbRow : xwpfTableRows) {delAndJudgeRow(table, paramMap, tbRow);}return true;}// 如果是重復添加的行if (PoiWordUtils.isAddRowRepeat(row)) {List<XWPFTableRow> xwpfTableRows = addAndGetRepeatRows(table, row, paramMap);// 回溯添加的行,這里是試圖處理動態添加的圖片for (XWPFTableRow tbRow : xwpfTableRows) {delAndJudgeRow(table, paramMap, tbRow);}return true;}// 當前行非動態行標簽List<XWPFTableCell> cells = row.getTableCells();for (XWPFTableCell cell : cells) {//判斷單元格是否需要替換if (PoiWordUtils.checkText(cell.getText())) {List<XWPFParagraph> paragraphs = cell.getParagraphs();for (XWPFParagraph paragraph : paragraphs) {List<XWPFRun> runs = paragraph.getRuns();StringBuilder sb = new StringBuilder();for (XWPFRun run : runs) {sb.append(run.toString());run.setText("", 0);}placeholder(paragraph, runs, sb);}}}return false;}/*** 處理占位符** @param runs 當前段的runs* @param sb 當前段的內容* @throws Exception*/private void placeholder(XWPFParagraph currentPar, List<XWPFRun> runs, StringBuilder sb) throws Exception {if (runs.size() > 0) {String text = sb.toString();XWPFRun currRun = runs.get(0);if (PoiWordUtils.isPicture(text)) {// 該段落是圖片占位符ImageEntity imageEntity = (ImageEntity) PoiWordUtils.getValueByPlaceholder(paramMap, text);int indentationFirstLine = currentPar.getIndentationFirstLine();// 清除段落的格式,否則圖片的縮進有問題currentPar.getCTP().setPPr(null);//設置縮進currentPar.setIndentationFirstLine(indentationFirstLine); // addPicture(currRun, imageEntity);} else {changeValue(currRun, text, paramMap);}}}/*** 添加圖片* @param currRun 當前run* @param imageEntity 圖片對象* @throws InvalidFormatException* @throws FileNotFoundException*//*private void addPicture(XWPFRun currRun, ImageEntity imageEntity) throws InvalidFormatException, FileNotFoundException {Integer typeId = imageEntity.getTypeId().getTypeId();String picId = currRun.getDocument().addPictureData(new FileInputStream(imageEntity.getUrl()), typeId);ImageUtils.createPicture(currRun, picId, templateDoc.getNextPicNameNumber(typeId),imageEntity.getWidth(), imageEntity.getHeight());}*//*** 添加行 標簽行不是新創建的** @param table* @param flagRow flagRow 表有標簽的行* @param paramMap 參數*/private List<XWPFTableRow> addAndGetRows(XWPFTable table, XWPFTableRow flagRow, Map<String, Object> paramMap) throws Exception {List<XWPFTableCell> flagRowCells = flagRow.getTableCells();XWPFTableCell flagCell = flagRowCells.get(0);String text = flagCell.getText();List<List<String>> dataList = (List<List<String>>) PoiWordUtils.getValueByPlaceholder(paramMap, text);if (dataList == null || dataList.size() <= 0) {return new ArrayList();}// 新添加的行List<XWPFTableRow> newRows = new ArrayList(dataList.size());XWPFTableRow currentRow = flagRow;int cellSize = flagRow.getTableCells().size();for (int i = 0, size = dataList.size(); i < size; i++) {if (i != 0) {currentRow = table.createRow();// 復制樣式if (flagRow.getCtRow() != null) {currentRow.getCtRow().setTrPr(flagRow.getCtRow().getTrPr());}}addRow(flagCell, currentRow, cellSize, dataList.get(i));newRows.add(currentRow);}return newRows;}/*** 添加重復多行 動態行 每一行都是新創建的** @param table* @param flagRow* @param paramMap* @return* @throws Exception*/private List<XWPFTableRow> addAndGetRepeatRows(XWPFTable table, XWPFTableRow flagRow, Map<String, Object> paramMap) throws Exception {List<XWPFTableCell> flagRowCells = flagRow.getTableCells();XWPFTableCell flagCell = flagRowCells.get(0);String text = flagCell.getText();List<List<String>> dataList = (List<List<String>>) PoiWordUtils.getValueByPlaceholder(paramMap, text);String tbRepeatMatrix = PoiWordUtils.getTbRepeatMatrix(text);//Assert.assertNotNull("模板矩陣不能為空", tbRepeatMatrix);// 新添加的行if (dataList == null || dataList.size() <= 0) {return new ArrayList();}List<XWPFTableRow> newRows = new ArrayList(dataList.size());String[] split = tbRepeatMatrix.split(PoiWordUtils.tbRepeatMatrixSeparator);int startRow = Integer.parseInt(split[0]);int endRow = Integer.parseInt(split[1]);int startCell = Integer.parseInt(split[2]);int endCell = Integer.parseInt(split[3]);XWPFTableRow currentRow;for (int i = 0, size = dataList.size(); i < size; i++) {int flagRowIndex = i % (endRow - startRow + 1);XWPFTableRow repeatFlagRow = table.getRow(flagRowIndex);// 清除占位符那行if (i == 0) {table.removeRow(currentRowIndex);}currentRow = table.createRow();// 復制樣式if (repeatFlagRow.getCtRow() != null) {currentRow.getCtRow().setTrPr(repeatFlagRow.getCtRow().getTrPr());}addRowRepeat(startCell, endCell, currentRow, repeatFlagRow, dataList.get(i));newRows.add(currentRow);}return newRows;}/*** 根據模板cell添加新行** @param flagCell 模板列(標記占位符的那個cell)* @param row 新增的行* @param cellSize 每行的列數量(用來補列補足的情況)* @param rowDataList 每行的數據*/private void addRow(XWPFTableCell flagCell, XWPFTableRow row, int cellSize, List<String> rowDataList) {for (int i = 0; i < cellSize; i++) {XWPFTableCell cell = row.getCell(i);cell = cell == null ? row.createCell() : row.getCell(i);if (i < rowDataList.size()) {PoiWordUtils.copyCellAndSetValue(flagCell, cell, rowDataList.get(i));} else {// 數據不滿整行時,添加空列PoiWordUtils.copyCellAndSetValue(flagCell, cell, "");}}}/*** 根據模板cell 添加重復行** @param startCell 模板列的開始位置* @param endCell 模板列的結束位置* @param currentRow 創建的新行* @param repeatFlagRow 模板列所在的行* @param rowDataList 每行的數據*/private void addRowRepeat(int startCell, int endCell, XWPFTableRow currentRow, XWPFTableRow repeatFlagRow, List<String> rowDataList) {int cellSize = repeatFlagRow.getTableCells().size();for (int i = 0; i < cellSize; i++) {XWPFTableCell cell = currentRow.getCell(i);cell = cell == null ? currentRow.createCell() : currentRow.getCell(i);int flagCellIndex = i % (endCell - startCell + 1);XWPFTableCell repeatFlagCell = repeatFlagRow.getCell(flagCellIndex);if (i < rowDataList.size()) {PoiWordUtils.copyCellAndSetValue(repeatFlagCell, cell, rowDataList.get(i));} else {// 數據不滿整行時,添加空列PoiWordUtils.copyCellAndSetValue(repeatFlagCell, cell, "");}}}/*** 復制段落** @param sourcePar 原段落* @param targetPar* @param texts*/private void copyParagraph(XWPFParagraph sourcePar, XWPFParagraph targetPar, String... texts) {targetPar.setAlignment(sourcePar.getAlignment());targetPar.setVerticalAlignment(sourcePar.getVerticalAlignment());// 設置布局targetPar.setAlignment(sourcePar.getAlignment());targetPar.setVerticalAlignment(sourcePar.getVerticalAlignment());if (texts != null && texts.length > 0) {String[] arr = texts;XWPFRun xwpfRun = sourcePar.getRuns().isEmpty() ? sourcePar.getRuns().get(0) : null;for (int i = 0, len = texts.length; i < len; i++) {String text = arr[i];XWPFRun run = targetPar.createRun();if (xwpfRun != null) {String fontFamily = xwpfRun.getFontFamily();run.setText(text);run.setFontFamily(fontFamily);int fontSize = xwpfRun.getFontSize();run.setFontSize((fontSize == -1) ? DEFAULT_FONT_SIZE : fontSize);run.setBold(xwpfRun.isBold());run.setItalic(xwpfRun.isItalic());} else {run.setFontFamily("仿宋_GB2312");int fontSize = -1;run.setFontSize((fontSize == -1) ? DEFAULT_FONT_SIZE : fontSize);run.setBold(false);run.setItalic(false);}}}}public void setParamMap(Map<String, Object> paramMap) {this.paramMap = paramMap;} }

FreeMarkerUtil類

package com.midea.dmr.cont.ctr;import com.itextpdf.text.Document; import com.itextpdf.text.Font; import com.itextpdf.text.PageSize; import com.itextpdf.text.Paragraph; import com.itextpdf.text.pdf.BaseFont; import com.itextpdf.text.pdf.PdfWriter; import com.itextpdf.tool.xml.XMLWorkerFontProvider; import com.midea.dmr.common.exception.ParamValidationException; import freemarker.cache.StringTemplateLoader; import freemarker.template.Configuration; import freemarker.template.Template;import java.io.*; import java.nio.charset.Charset; import java.util.Map; import java.util.logging.Logger;/*** freemarker工具類*/ public class FreeMarkerUtil {private static final Logger LOG = Logger.getLogger(FreeMarkerUtil.class.getName());private static final String ENCODE = "UTF-8";/*** freeMarker渲染** @param data* @param templateFile* @return* @throws*/public static String freeMarkerRender(Map<String, Object> data, byte[] templateFile) throws ParamValidationException {Writer writer = new StringWriter();try {Configuration configuration = initConfig();Template template = getTemplate(configuration, templateFile);template.process(data, writer);writer.flush();return writer.toString();} catch (Exception e) {LOG.info("freeMarker渲染異常:" + e.getMessage());throw new ParamValidationException("freeMarker渲染異常");} finally {try {writer.close();} catch (IOException ioe) {LOG.info("關閉文件流異常:" + ioe.getMessage());}}}/*** 模板轉換為pdf(使用默認頁眉頁腳)** @param templateFile* @return* @throws*/public static byte[] html2Pdf(String templateFile) throws Exception {ByteArrayOutputStream baos = new ByteArrayOutputStream();Document document = null;try {document = new Document(PageSize.A4, 90, 90, 60, 60);PdfWriter writer = PdfWriter.getInstance(document, baos);PDFBuilder builder = new PDFBuilder();writer.setPageEvent(builder);document.open();XMLWorkerFontProvider fontImp = new XMLWorkerFontProvider();LOG.info("html2Pdf.parseXHtml,開始");com.itextpdf.tool.xml.XMLWorkerHelper.getInstance().parseXHtml(writer, document, new ByteArrayInputStream(templateFile.getBytes(ENCODE)), null, Charset.forName(ENCODE), fontImp);LOG.info("html2Pdf.parseXHtml,結束");document.close();baos.flush();baos.close();} catch (Exception e) {LOG.info("轉換電子合同異常:" + e.getMessage());throw new Exception(e);}return baos.toByteArray();}/*** 模板轉換為pdf(使用默認頁眉頁腳)** @param templateFile* @return* @throws*/public static byte[] html2PdfNew(String templateFile) throws Exception {ByteArrayOutputStream baos = new ByteArrayOutputStream();Document document = null;try {document = new Document(PageSize.A4, 90, 90, 60, 60);BaseFont baseFont = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);Font font = new Font(baseFont);Paragraph p = new Paragraph();p.setFont(font);PdfWriter writer = PdfWriter.getInstance(document, baos);PDFBuilder builder = new PDFBuilder();writer.setPageEvent(builder);document.open();document.add(p);XMLWorkerFontProvider fontImp = new XMLWorkerFontProvider();LOG.info("html2Pdf1.parseXHtml,開始");com.itextpdf.tool.xml.XMLWorkerHelper.getInstance().parseXHtml(writer, document, new ByteArrayInputStream(templateFile.getBytes(ENCODE)), null, Charset.forName(ENCODE), fontImp);LOG.info("html2Pdf1.parseXHtml,結束");document.close();baos.flush();baos.close();} catch (Exception e) {LOG.info("轉換電子合同異常1:" + e.getMessage());throw new Exception(e);}return baos.toByteArray();}/*** 模板轉換為pdf(使用自定義頁眉頁腳)** @param templateFile* @param builder* @return* @throws*/public static byte[] html2Pdf(String templateFile, PDFBuilder builder) throws ParamValidationException {ByteArrayOutputStream baos = new ByteArrayOutputStream();try {Document document = new Document(PageSize.A4, 90, 90, 60, 60);PdfWriter writer = PdfWriter.getInstance(document, baos);writer.setPageEvent(builder);document.open();XMLWorkerFontProvider fontImp = new XMLWorkerFontProvider();com.itextpdf.tool.xml.XMLWorkerHelper.getInstance().parseXHtml(writer, document, new ByteArrayInputStream(templateFile.getBytes()), null, Charset.forName(ENCODE), fontImp);document.close();baos.flush();baos.close();} catch (Exception e) {LOG.info("轉換電子合同異常:" + e.getMessage());throw new ParamValidationException("轉換電子合同異常");}return baos.toByteArray();}/*** 模板參數初始化** @return*/public static Configuration initConfig() {Configuration configuration = new Configuration();configuration.setDefaultEncoding(ENCODE);return configuration;}/*** 獲取模板** @param configuration* @return* @throws*/public static Template getTemplate(Configuration configuration, byte[] templateFile) throws ParamValidationException {StringTemplateLoader stl = new StringTemplateLoader();stl.putTemplate("template", new String(templateFile));configuration.setTemplateLoader(stl);try {return configuration.getTemplate("template");} catch (Exception e) {LOG.info("獲取模板異常:" + e.getMessage());throw new ParamValidationException("獲取模板異常");}} }

ImageEntity類

package com.midea.dmr.cont.ctr;/*** Create by IntelliJ Idea 2018.2* <p>* 圖片實體對象** @author: qyp* Date: 2019-10-26 21:52*/ public class ImageEntity {/*** 圖片寬度*/private int width = 400;/*** 圖片高度*/private int height = 300;/*** 圖片地址*/private String url;public int getWidth() {return width;}public void setWidth(int width) {this.width = width;}public int getHeight() {return height;}public void setHeight(int height) {this.height = height;}public String getUrl() {return url;}public void setUrl(String url) {this.url = url;} }

ImageUtils類

package com.midea.dmr.cont.ctr;import org.apache.poi.xwpf.usermodel.XWPFDocument; import org.apache.poi.xwpf.usermodel.XWPFRun; import org.apache.xmlbeans.XmlException; import org.apache.xmlbeans.XmlToken; import org.openxmlformats.schemas.drawingml.x2006.main.CTNonVisualDrawingProps; import org.openxmlformats.schemas.drawingml.x2006.main.CTPositiveSize2D; import org.openxmlformats.schemas.drawingml.x2006.wordprocessingDrawing.CTInline;/*** Create by IntelliJ Idea 2018.2** @author: qyp* Date: 2019-10-26 21:55*/ public class ImageUtils {/*** 圖片類型枚舉*/enum ImageType {/*** 支持四種類型 JPG/JPEG, GIT, BMP, PNG*/JPG("JPG", XWPFDocument.PICTURE_TYPE_JPEG),JPEG("JPEG", XWPFDocument.PICTURE_TYPE_JPEG),PNG("PNG", XWPFDocument.PICTURE_TYPE_PNG);private String name;private Integer typeId;ImageType(String name, Integer type) {this.name = name;this.typeId = type;}public String getName() {return name;}public Integer getTypeId() {return typeId;}}public static void createPicture(XWPFRun run, String blipId, int id, int width, int height) {final int EMU = 9525;width *= EMU;height *= EMU;CTInline inline = run.getCTR().addNewDrawing().addNewInline();String picXml = "" +"<a:graphic xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\">" +" <a:graphicData uri=\"http://schemas.openxmlformats.org/drawingml/2006/picture\">" +" <pic:pic xmlns:pic=\"http://schemas.openxmlformats.org/drawingml/2006/picture\">" +" <pic:nvPicPr>" +" <pic:cNvPr id=\"" + id + "\" name=\"Generated\"/>" +" <pic:cNvPicPr/>" +" </pic:nvPicPr>" +" <pic:blipFill>" +" <a:blip r:embed=\"" + blipId + "\" xmlns:r=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships\"/>" +" <a:stretch>" +" <a:fillRect/>" +" </a:stretch>" +" </pic:blipFill>" +" <pic:spPr>" +" <a:xfrm>" +" <a:off x=\"0\" y=\"0\"/>" +" <a:ext cx=\"" + width + "\" cy=\"" + height + "\"/>" +" </a:xfrm>" +" <a:prstGeom prst=\"rect\">" +" <a:avLst/>" +" </a:prstGeom>" +" </pic:spPr>" +" </pic:pic>" +" </a:graphicData>" +"</a:graphic>";XmlToken xmlToken = null;try {xmlToken = XmlToken.Factory.parse(picXml);} catch(XmlException xe) {xe.printStackTrace();}inline.set(xmlToken);inline.setDistT(0);inline.setDistB(0);inline.setDistL(0);inline.setDistR(0);CTPositiveSize2D extent = inline.addNewExtent();extent.setCx(width);extent.setCy(height);CTNonVisualDrawingProps docPr = inline.addNewDocPr();docPr.setId(id);docPr.setName("Picture " + id);docPr.setDescr("Generated");}}

MapperUtils類

package com.midea.dmr.cont.ctr;import ma.glasnost.orika.MapperFacade; import ma.glasnost.orika.MapperFactory; import ma.glasnost.orika.impl.DefaultMapperFactory;public class MapperUtils {private static MapperFactory mapperFactory = new DefaultMapperFactory.Builder().build();private static MapperFacade mapper = null;static {mapper = mapperFactory.getMapperFacade();}public static MapperFacade getMapper() {return mapper;}public static void main(String[] args) {}}

PDFBuilder類

package com.midea.dmr.cont.ctr;import com.itextpdf.text.*; import com.itextpdf.text.pdf.*;/*** 設置頁眉頁腳處理類*/ public class PDFBuilder extends PdfPageEventHelper {// 頁眉private String header = " 2020年V1.0版";// 頁腳private String footer = "";// 字體大小private int presentFontSize = 9;// 紙張大小private Rectangle pageSize = PageSize.A4;// 模板private PdfTemplate pdfTemplate;// 基礎字體對象private BaseFont baseFont = null;// 利用基礎字體生成的字體對象,一般用于生成中文文字private Font headerFont = null;private Font footerFont = null;public PDFBuilder() {}public PDFBuilder(String header, int presentFontSize, Rectangle pageSize) {this.header = header;this.presentFontSize = presentFontSize;this.pageSize = pageSize;}public PDFBuilder(String header, String footer, int presentFontSize, Rectangle pageSize) {this.header = header;this.footer = footer;this.presentFontSize = presentFontSize;this.pageSize = pageSize;}/*** 文檔打開時初始化** @param writer* @param document*/@Overridepublic void onOpenDocument(PdfWriter writer, Document document) {// 設置邊框長寬pdfTemplate = writer.getDirectContent().createTemplate(50, 50);// 共 頁 的矩形的長寬高try {if (baseFont == null) {baseFont = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", false);}// 設置字體if (headerFont == null) {headerFont = new Font(baseFont, presentFontSize, Font.UNDERLINE);// 數據體字體}if (footerFont == null) {footerFont = new Font(baseFont, presentFontSize, Font.NORMAL);// 數據體字體}} catch (Exception e) { // LogUtil.error("初始化異常:", e); // throw new ServiceException("初始化異常");}}/*** 每頁關閉寫入頁眉頁腳** @param writer* @param document*/@Overridepublic void onEndPage(PdfWriter writer, Document document) {try {if (baseFont == null) { // baseFont = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", false);baseFont = BaseFont.createFont();}if (footerFont == null) {// 數據體字體footerFont = new Font(baseFont, presentFontSize, Font.NORMAL);}float right = 505.0f;float top = 782.0f;float rightMargin = 90.0f;float leftMargin = 90.0f;float left = 90.0f;float bottom = 60.0f;if (document != null) {right = document.right();top = document.top();rightMargin = document.rightMargin();leftMargin = document.leftMargin();left = document.left();bottom = document.bottom();}// 1.寫入頁眉ColumnText.showTextAligned(writer.getDirectContent(), Element.ALIGN_RIGHT, new Phrase(header, headerFont), right, top + 20, 0);// 2.寫入前半部分的 第 X頁/共String foot1 = "";int align; // if (footer.isEmpty()) {if (org.apache.commons.lang.StringUtils.isBlank(this.footer)) {int pageS = writer.getPageNumber();foot1 = " " + pageS + " /";align = Element.ALIGN_CENTER;} else {foot1 = this.footer;align = Element.ALIGN_LEFT;}Phrase phrase = new Phrase(foot1, footerFont);TabSettings tabSettings = new TabSettings();// 3.計算前半部分的foot1的長度,后面好定位最后一部分的'Y頁'這倆字的x軸坐標,字體長度也要計算進去 = lenfloat len = baseFont.getWidthPoint(foot1, presentFontSize);// 4.拿到當前的PdfContentBytePdfContentByte cb = writer.getDirectContent();// 5.寫入頁腳1,x軸就是(右margin+左margin + right() -left()- len)/2.0FColumnText.showTextAligned(cb, align, phrase, (rightMargin + right + leftMargin - left - len) / 2.0F + 20F, bottom - 20, 0);// 6.寫入頁腳2的模板(就是頁腳的Y頁這倆字)添加到文檔中,計算模板的和Y軸,X=(右邊界-左邊界 - 前半部分的len值)/2.0F +// len , y 軸和之前的保持一致,底邊界-20cb.addTemplate(pdfTemplate, (rightMargin + right + leftMargin - left) / 2.0F + 20F, bottom - 20); // 調節模版顯示的位置} catch (Exception e) { // LogUtil.error("系統異常:", e);System.err.println(e.getMessage());return;}}/*** 文檔關閉時寫入頁眉頁腳** @param writer* @param document*/@Overridepublic void onCloseDocument(PdfWriter writer, Document document) {// 關閉文檔的時候,將模板替換成實際的 Y 值,至此,page x of y 制作完畢。pdfTemplate.beginText();pdfTemplate.setFontAndSize(baseFont, presentFontSize);// 生成的模版的字體、顏色String foot2 = ""; // if (footer.isEmpty()) {if (org.apache.commons.lang.StringUtils.isBlank(footer)) {foot2 = " " + (writer.getPageNumber()) + " ";}pdfTemplate.showText(foot2);// 模版顯示的內容pdfTemplate.endText();pdfTemplate.closePath();} }

PDFUtil類

package com.midea.dmr.cont.ctr;import com.itextpdf.text.DocumentException; import com.itextpdf.text.Image; import com.itextpdf.text.pdf.*; import org.apache.commons.io.output.ByteArrayOutputStream; import org.apache.pdfbox.pdmodel.PDDocument;import javax.imageio.IIOImage; import javax.imageio.ImageIO; import javax.imageio.ImageWriteParam; import javax.imageio.ImageWriter; import java.awt.image.BufferedImage; import java.awt.image.ColorModel; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import java.util.Map;//import com.midea.jr.ecr.common.log.util.LogUtil;public class PDFUtil {/*** 獲取PDDocument對象** @param bytes* @return*/public static PDDocument getPDDocument(byte[] bytes) {PDDocument pdf = null;try {pdf = PDDocument.load(bytes);return pdf;} catch (Exception e) {//LogUtil.error("", e);}return null;}/*** 獲取PDDocument對象** @param file* @return*/public static PDDocument getPDDocument(File file) {PDDocument pdf = null;try {pdf = PDDocument.load(file);return pdf;} catch (Exception e) {//LogUtil.error("", e);}return null;}/*** 獲取PDDocument對象** @param fileInputStream* @return*/public static PDDocument getPDDocument(FileInputStream fileInputStream) {PDDocument pdf = null;try {pdf = PDDocument.load(fileInputStream);return pdf;} catch (Exception e) {//LogUtil.error("", e);}return null;}/*** 獲取PDDocument對象** @param pdfFilePath* @return*/public static PDDocument getPDDocument(String pdfFilePath) {try {File file = new File(pdfFilePath);if (file.exists()) {throw new Exception("路徑" + pdfFilePath + "文件不存在");}if (!file.isFile()) {throw new Exception("路徑" + pdfFilePath + "不是文件");}if (!file.canRead()) {throw new Exception("文件" + pdfFilePath + "無法讀取");}return getPDDocument(file);} catch (Exception e) {//LogUtil.error("", e);}return null;}/*** 自己設置壓縮質量來把圖片壓縮成byte[]** @param image* 壓縮源圖片* @param quality* 壓縮質量,在0-1之間,* @return 返回的字節數組*/public static byte[] bufferedImageTobytes(BufferedImage image, float quality) {// 如果圖片空,返回空if (image == null) {return null;}// 得到指定Format圖片的writerIterator<ImageWriter> iter = ImageIO.getImageWritersByFormatName("jpeg");// 得到迭代器ImageWriter writer = iter.next(); // 得到writer// 得到指定writer的輸出參數設置(ImageWriteParam )ImageWriteParam iwp = writer.getDefaultWriteParam();iwp.setCompressionMode(ImageWriteParam.MODE_EXPLICIT); // 設置可否壓縮iwp.setCompressionQuality(quality); // 設置壓縮質量參數iwp.setProgressiveMode(ImageWriteParam.MODE_DISABLED);ColorModel colorModel = ColorModel.getRGBdefault();// 指定壓縮時使用的色彩模式iwp.setDestinationType(new javax.imageio.ImageTypeSpecifier(colorModel, colorModel.createCompatibleSampleModel(16, 16)));// 開始打包圖片,寫入byte[]ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); // 取得內存輸出流IIOImage iIamge = new IIOImage(image, null, null);byte[] bytes = null;try {// 此處因為ImageWriter中用來接收write信息的output要求必須是ImageOutput// 通過ImageIo中的靜態方法,得到byteArrayOutputStream的ImageOutputwriter.setOutput(ImageIO.createImageOutputStream(byteArrayOutputStream));writer.write(null, iIamge, iwp);bytes = byteArrayOutputStream.toByteArray();} catch (IOException e) {//LogUtil.error("", e);}return bytes;}/*** 向pdf表單填充數據** @param fields* @param map* @throws IOException* @throws DocumentException*/public static void fillData(AcroFields fields, Map<String, Object> map) throws IOException, DocumentException {List<String> keys = new ArrayList<String>();Map<String, AcroFields.Item> formFields = fields.getFields();for (String key : map.keySet()) {if (formFields.containsKey(key)) {String value = String.valueOf(map.get(key));fields.setField(key,value/*,true*/); // 為字段賦值,注意字段名稱是區分大小寫的keys.add(key);}}Iterator<String> itemsKey = formFields.keySet().iterator();while (itemsKey.hasNext()) {String itemKey = itemsKey.next();if (!keys.contains(itemKey)) {fields.setField(itemKey, " ");}}}/*** itext生成pdf** @param map* @param file* @return*/public static byte[] generatePDF(Map<String, Object> map, byte[] file) {try{ByteArrayOutputStream bos = new ByteArrayOutputStream();PdfReader reader = new PdfReader(file);PdfStamper ps = new PdfStamper(reader, bos);/* 使用中文字體 */BaseFont bf = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);ArrayList<BaseFont> fontList = new ArrayList<BaseFont>();fontList.add(bf);/* 取出報表模板中的所有字段 */AcroFields fields = ps.getAcroFields();fields.setSubstitutionFonts(fontList);fillData(fields, map);/* 必須要調用這個,否則文檔不會生成的 如果為false那么生成的PDF文件還能編輯,一定要設為true */ps.setFormFlattening(true);ps.close();return bos.toByteArray();} catch (Exception e) {//LogUtil.error("", e);}return null;}/*** 給pdf文件添加水印* @param InPdfFile* @param markImagePath* @return*/public static byte[] addPdfMark(byte[] InPdfFile, byte[] markImagePath) {try {ByteArrayOutputStream bos = new ByteArrayOutputStream();PdfReader reader = new PdfReader(InPdfFile, "PDF".getBytes());PdfStamper stamp = new PdfStamper(reader, bos);Image img = Image.getInstance(markImagePath);// 插入水印int pageSize = reader.getNumberOfPages();// 原pdf文件的總頁數for(int i = 1; i <= pageSize; i++) {float pageWidth = reader.getPageSize(i).getWidth();float pageHeight = reader.getPageSize(i).getHeight();PdfContentByte under = stamp.getUnderContent(i); //水印在文本之下 // PdfGState gs = new PdfGState(); // gs.setFillOpacity(0.8f);// 設置透明度 // under.setGState(gs);float per =(pageWidth/img.getWidth()) <(pageHeight/img.getHeight())?(pageWidth/img.getWidth()):(pageHeight/img.getHeight());img.scalePercent(per*100);//依照比例縮放img.scaleAbsolute(pageWidth,pageHeight);//自定義大小img.setAbsolutePosition((pageWidth-img.getWidth())/2, (pageHeight-img.getHeight())/2);//圖片坐標--居中under.addImage(img);}stamp.close();return bos.toByteArray();}catch(Exception e){//LogUtil.error("", e);}return null;}/*** 給pdf文件添加水印 -cfca用* @param InPdfFile* @param markImagePath* @return*/public static byte[] addPdfMarkToCfca(byte[] InPdfFile, byte[] markImagePath) {try {ByteArrayOutputStream bos = new ByteArrayOutputStream(); // try (ByteArrayOutputStream bos = new ByteArrayOutputStream();){PdfReader reader = new PdfReader(InPdfFile, "PDF".getBytes());PdfStamper stamp = new PdfStamper(reader, bos);Image img = Image.getInstance(markImagePath);// 插入水印int pageSize = reader.getNumberOfPages();// 原pdf文件的總頁數for(int i = 1; i <= pageSize; i++) {float pageWidth = reader.getPageSize(i).getWidth();float pageHeight = reader.getPageSize(i).getHeight();PdfContentByte under = stamp.getUnderContent(i); //水印在文本之下 // PdfGState gs = new PdfGState(); // gs.setFillOpacity(0.8f);// 設置透明度 // under.setGState(gs); // img.scalePercent(50);//依照比例縮放float per =(pageWidth/img.getWidth()) <(pageHeight/img.getHeight())?(pageWidth/img.getWidth()):(pageHeight/img.getHeight());img.scalePercent(per*100);//依照比例縮放//img.scaleAbsolute(pageWidth,pageHeight);//自定義大小img.setAbsolutePosition(0, 0);//圖片坐標--居中under.addImage(img);}stamp.close();return bos.toByteArray();}catch(Exception e){//LogUtil.error("", e);}return null;} }

PoiWordUtils類

package com.midea.dmr.cont.ctr;import org.apache.poi.xwpf.usermodel.*;import java.util.List; import java.util.Map;/*** Create by IntelliJ Idea 2018.2** @author: qyp* Date: 2019-10-26 2:12*/ public class PoiWordUtils {/*** 占位符第一個字符*/public static final String PREFIX_FIRST = "$";/*** 占位符第二個字符*/public static final String PREFIX_SECOND = "{";/*** 占位符的前綴*/public static final String PLACEHOLDER_PREFIX = PREFIX_FIRST + PREFIX_SECOND;/*** 占位符后綴*/public static final String PLACEHOLDER_END = "}";/*** 表格中需要動態添加行的獨特標記*/public static final String addRowText = "tbAddRow:";public static final String addRowRepeatText = "tbAddRowRepeat:";/*** 表格中占位符的開頭 ${tbAddRow: 例如${tbAddRow:tb1}*/public static final String addRowFlag = PLACEHOLDER_PREFIX + addRowText;/*** 表格中占位符的開頭 ${tbAddRowRepeat: 例如 ${tbAddRowRepeat:0,2,0,1} 第0行到第2行,第0列到第1列 為模板樣式*/public static final String addRowRepeatFlag = PLACEHOLDER_PREFIX + addRowRepeatText;/*** 重復矩陣的分隔符 比如:${tbAddRowRepeat:0,2,0,1} 分隔符為 ,*/public static final String tbRepeatMatrixSeparator = ",";/*** 占位符的后綴*/public static final String PLACEHOLDER_SUFFIX = "}";/*** 圖片占位符的前綴*/public static final String PICTURE_PREFIX = PLACEHOLDER_PREFIX + "image:";/*** 判斷當前行是不是標志表格中需要添加行** @param row* @return*/public static boolean isAddRow(XWPFTableRow row) {return isDynRow(row, addRowFlag);}/*** 添加重復模板動態行(以多行為模板)* @param row* @return*/public static boolean isAddRowRepeat(XWPFTableRow row) {return isDynRow(row, addRowRepeatFlag);}private static boolean isDynRow(XWPFTableRow row, String dynFlag) {if (row == null) {return false;}List<XWPFTableCell> tableCells = row.getTableCells();if (tableCells != null) {XWPFTableCell cell = tableCells.get(0);if (cell != null) {String text = cell.getText();if (text != null && text.startsWith(dynFlag)) {return true;}}}return false;}/*** 從參數map中獲取占位符對應的值** @param paramMap* @param key* @return*/public static Object getValueByPlaceholder(Map<String, Object> paramMap, String key) {if (paramMap != null) {if (key != null) {return paramMap.get(getKeyFromPlaceholder(key));}}return null;}/*** 后去占位符的重復行列矩陣* @param key 占位符* @return {0,2,0,1}*/public static String getTbRepeatMatrix(String key) {//Assert.assertNotNull("占位符為空", key);String $1 = key.replaceAll("\\" + PREFIX_FIRST + "\\" + PREFIX_SECOND + addRowRepeatText + "(.*)" + "\\" + PLACEHOLDER_SUFFIX, "$1");return $1;}/*** 從占位符中獲取key** @return*/public static String getKeyFromPlaceholder(String placeholder) { // return Optional.ofNullable(placeholder).map(p -> p.replaceAll("[\\$\\{\\}]", "")).get();return placeholder.replaceAll("[\\$\\{\\}]", "");}public static void main(String[] args) {String s = "${aa}";s = s.replaceAll(PLACEHOLDER_PREFIX + PLACEHOLDER_SUFFIX , "");System.out.println(s); // String keyFromPlaceholder = getKeyFromPlaceholder("${tbAddRow:tb1}"); // System.out.println(keyFromPlaceholder);}/*** 復制列的樣式,并且設置值* @param sourceCell* @param targetCell* @param text*/public static void copyCellAndSetValue(XWPFTableCell sourceCell, XWPFTableCell targetCell, String text) {//段落屬性List<XWPFParagraph> sourceCellParagraphs = sourceCell.getParagraphs();if (sourceCellParagraphs == null || sourceCellParagraphs.size() <= 0) {return;}XWPFParagraph sourcePar = sourceCellParagraphs.get(0);XWPFParagraph targetPar = targetCell.getParagraphs().get(0);// 設置段落的樣式targetPar.getCTP().setPPr(sourcePar.getCTP().getPPr());List<XWPFRun> sourceParRuns = sourcePar.getRuns();if (sourceParRuns != null && sourceParRuns.size() > 0) {// 如果當前cell中有runList<XWPFRun> runs = targetPar.getRuns(); // Optional.ofNullable(runs).ifPresent(rs -> rs.stream().forEach(r -> r.setText("", 0)));if (runs != null && runs.size() > 0) {runs.get(0).setText(text, 0);} else {XWPFRun cellR = targetPar.createRun();cellR.setText(text, 0);// 設置列的樣式位模板的樣式targetCell.getCTTc().setTcPr(sourceCell.getCTTc().getTcPr());}setTypeface(sourcePar, targetPar);} else {targetCell.setText(text);}}/*** 復制字體*/private static void setTypeface(XWPFParagraph sourcePar, XWPFParagraph targetPar) {XWPFRun sourceRun = sourcePar.getRuns().get(0);String fontFamily = sourceRun.getFontFamily();int fontSize = sourceRun.getFontSize(); // String color = sourceRun.getColor(); // String fontName = sourceRun.getFontName();boolean bold = sourceRun.isBold();boolean italic = sourceRun.isItalic(); // int kerning = sourceRun.getKerning(); // String style = sourcePar.getStyle();UnderlinePatterns underline = sourceRun.getUnderline();List<XWPFRun> runs = targetPar.getRuns();if(runs.isEmpty()){return;}XWPFRun targetRun = targetPar.getRuns().get(0);targetRun.setFontFamily(fontFamily); // targetRun.setFontSize(fontSize == -1 ? 10 : fontSize);targetRun.setBold(bold); // targetRun.setColor(color);targetRun.setItalic(italic); // targetRun.setKerning(kerning);targetRun.setUnderline(underline);//targetRun.setFontSize(fontSize);}/*** 判斷文本中時候包含$* @param text 文本* @return 包含返回true,不包含返回false*/public static boolean checkText(String text){boolean check = false;if(text.indexOf(PLACEHOLDER_PREFIX)!= -1){check = true;}return check;}/*** 獲得占位符替換的正則表達式* @return*/public static String getPlaceholderReg(String text) {return "\\" + PREFIX_FIRST + "\\" + PREFIX_SECOND + text + "\\" + PLACEHOLDER_SUFFIX;}public static String getDocKey(String mapKey) {return PLACEHOLDER_PREFIX + mapKey + PLACEHOLDER_SUFFIX;}/*** 判斷當前占位符是不是一個圖片占位符* @param text* @return*/public static boolean isPicture(String text) {return text.startsWith(PICTURE_PREFIX);}/*** 刪除一行的列* @param row*/public static void removeCells(XWPFTableRow row) {int size = row.getTableCells().size();try {for (int i = 0; i < size; i++) { // row.removeCell(i);}} catch (Exception e) {}} }

總結

以上是生活随笔為你收集整理的Java 填充模板的全部內容,希望文章能夠幫你解決所遇到的問題。

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

久久中文字幕导航 | 成人午夜电影在线播放 | 免费视频区 | 中文字幕日韩国产 | 久久精品久久精品 | 国产精品99久久免费黑人 | 在线免费精品视频 | 成人av高清在线 | 99久久99久久精品 | 亚洲精品www久久久久久 | 久久午夜精品视频 | 开心激情婷婷 | 五月婷婷网站 | 一区 在线 影院 | 久久精品国产成人精品 | 色综合久久久久综合体桃花网 | 久久综合狠狠 | av日韩精品 | 免费在线观看一区 | 在线观看中文字幕第一页 | 麻豆国产电影 | 成人黄色小说网 | 2023国产精品自产拍在线观看 | 日韩精品在线播放 | 欧美一区二区三区在线观看 | 天堂在线免费视频 | 久久久久综合网 | 午夜123| 国产精品一区专区欧美日韩 | 中文字幕日韩免费视频 | 一区二区三区播放 | 天天在线免费视频 | 黄色一级片视频 | 欧女人精69xxxxxx | 日韩在线免费高清视频 | 99精品电影| 免费高清看电视网站 | 天天躁日日躁狠狠躁av中文 | 正在播放一区二区 | 国产免费三级在线观看 | 亚洲国产电影在线观看 | а天堂中文最新一区二区三区 | 青青久草在线视频 | 成人99免费视频 | 99色在线观看视频 | 色五婷婷| 欧美成人黄色 | 久操操 | 欧美日韩视频在线观看免费 | 在线久草视频 | 国产在线精品一区二区 | 91黄色视屏 | 这里只有精品视频在线 | 色先锋av资源中文字幕 | 欧美成人在线网站 | 色噜噜狠狠狠狠色综合久不 | 一级欧美黄 | 国产手机av在线 | 五月天亚洲婷婷 | 国产手机在线观看 | 免费视频91蜜桃 | 免费涩涩网站 | 丁香久久 | 狠狠狠狠狠狠狠狠 | www.五月天| 亚洲欧洲久久久 | 手机av网站 | 欧美性精品 | 国产中出在线观看 | 天天操天天干天天 | 成人毛片在线观看 | 亚洲精品在线二区 | 国产视频亚洲视频 | 日韩精品字幕 | 国产精品99久久久久久久久 | 亚洲一区免费在线 | 天天狠狠干 | 欧美精品午夜 | 欧美黑吊大战白妞欧美 | 久久伦理视频 | 欧美日韩国产在线一区 | 97精品电影院 | 激情xxxx | 日韩一二区在线观看 | 正在播放国产一区二区 | 国产亚洲欧美在线视频 | www.com在线观看 | 免费av网站在线看 | 久久激情视频免费观看 | 久久免费视频国产 | 最近中文字幕国语免费高清6 | 国产精品久久久久久久久大全 | 久久人人爽人人 | 国内精品久久久久久 | 美女av免费看 | 久久五月婷婷丁香社区 | 日韩精品在线观看视频 | 久久中文字幕在线视频 | 久久视频在线观看免费 | 黄色a大片 | 欧美片一区二区三区 | 五月天六月婷婷 | 日韩精品无 | 美女av电影 | 人人爽人人爽人人片av免 | 国产精品视频专区 | 日本资源中文字幕在线 | 欧美日韩精品在线一区二区 | 日韩高清免费观看 | 免费99精品国产自在在线 | 国产精品专区在线观看 | 久久久久黄 | 天天曰天天爽 | 国产精品欧美久久久久天天影视 | 在线观看亚洲a | 久久五月情影视 | 99国产在线 | 国产精品九九热 | 婷婷综合av | 一区三区视频在线观看 | 国产精品9区 | 蜜臀久久99精品久久久久久网站 | 国产精品久久久久久久久岛 | 国产香蕉视频在线观看 | 欧美激情va永久在线播放 | 久久国产日韩 | 国产精品午夜久久 | www.黄色片网站 | 中文字幕乱码电影 | 色偷偷97 | 国产污视频在线观看 | www.888av| 亚洲精品www | 狠狠色丁香久久婷婷综合_中 | 日日摸日日爽 | av免费看在线 | 在线成人看片 | 最近中文字幕国语免费av | 日韩大片在线免费观看 | 成人三级网站在线观看 | 丁香五月亚洲综合在线 | 天堂av官网 | 一级黄色免费网站 | 天天干夜夜 | 亚州精品天堂中文字幕 | 亚洲涩涩网站 | 91免费试看 | 午夜久久精品 | 日韩精品久久久 | 在线观看电影av | 亚洲精品9| 久久日韩精品 | 国产精品9999 | 亚洲综合视频网 | 成人91在线 | 欧美日韩电影在线播放 | 成人一区二区三区在线 | 久久久久久久国产精品 | 顶级欧美色妇4khd | 日日日爽爽爽 | 天天综合久久 | 久章操 | 欧美日韩在线观看一区二区 | 在线观看的黄色 | www.狠狠操.com| 欧美日韩视频在线观看免费 | 国产在线观看黄 | 在线精品视频免费播放 | 国产色婷婷精品综合在线手机播放 | 久久精品视频网址 | 天天天综合 | 亚洲精品一区中文字幕乱码 | 久久国产精品区 | 久久久久久久久久亚洲精品 | 国产午夜精品视频 | 国产精品久久久av久久久 | 视频国产区 | 日日夜夜操av | 香蕉视频日本 | 91人人爽久久涩噜噜噜 | 中文在线天堂资源 | 国产麻豆剧果冻传媒视频播放量 | 黄免费在线观看 | 成人a在线观看高清电影 | 在线精品视频免费播放 | 日韩精品一区二区久久 | 国产精品一区在线播放 | 欧美一级久久久久 | 9999精品 | 久久午夜网 | 91在线国内视频 | 亚洲精品影院在线观看 | 国产一级二级视频 | 午夜av在线电影 | 91精品国产入口 | 国产精品久久久久久爽爽爽 | 亚洲精品中文字幕在线 | 欧美亚洲一区二区在线 | 亚洲国产精品一区二区久久,亚洲午夜 | 久草在线免费看视频 | 亚洲欧洲国产精品 | 三级黄色在线 | 日韩在线 | 欧美黑人巨大xxxxx | 日韩欧三级 | 色搞搞| 91福利视频一区 | 在线观看av免费观看 | 国产1区2区3区精品美女 | 日韩黄色在线观看 | 日本中文字幕在线看 | 亚洲蜜桃在线 | 又黄又刺激 | 97精品国产97久久久久久免费 | 亚州欧美视频 | 欧美激情片在线观看 | 特级黄色一级 | 摸bbb搡bbb搡bbbb| 亚州精品天堂中文字幕 | 国产xvideos免费视频播放 | 不卡精品| 国产最新福利 | 99999精品视频 | 久久久久伊人 | 狠狠躁日日躁夜夜躁av | 欧美 日韩 国产 中文字幕 | 午夜精选视频 | 毛片基地黄久久久久久天堂 | 欧美与欧洲交xxxx免费观看 | 天天爽天天摸 | 国产精品视频在线观看 | 中文字幕丝袜美腿 | 韩日精品在线观看 | 国产亚洲精品久 | 婷婷色网视频在线播放 | 久久狠狠婷婷 | 午夜精品一区二区三区视频免费看 | 天天干天天插 | 日韩有码在线观看视频 | 一区二区视频免费在线观看 | 四虎国产精品成人免费影视 | 999成人免费视频 | 人人爽久久久噜噜噜电影 | 亚洲精品美女久久17c | 中文字幕一区二区三区乱码在线 | 激情久久一区二区三区 | 一级免费av | 午夜久久久精品 | 77国产精品| 国产精品一区二区三区电影 | 九九九热 | 黄色一级动作片 | 美女视频黄是免费的 | 亚洲精品一区二区三区高潮 | 久av电影| 久久久久久久免费观看 | 在线观看中文字幕dvd播放 | 欧美色久| 久久在线免费观看 | 婷婷综合av| 乱子伦av| 91粉色视频 | 日韩大片在线免费观看 | 久久看片网站 | 国产性天天综合网 | 国产精品日韩在线 | 精品一区精品二区 | 国产精品一区二区免费在线观看 | www.com黄| 在线看不卡av | 99r在线精品 | 亚洲精品乱码久久久久久蜜桃不爽 | 99一级片| 91av免费在线观看 | 日本中文字幕免费观看 | 91成人免费看 | 少妇资源站 | 久久伊人婷婷 | 在线国产高清 | 国产特级毛片aaaaaa | 超碰av免费 | 亚洲精选久久 | 亚洲美女久久 | 在线亚洲天堂网 | 国内精品视频在线 | 狠色狠色综合久久 | 在线观看视频在线观看 | www.久久视频 | 91视频在线免费 | 99久久精| 91桃色视频| 天天操天天操天天爽 | 四虎欧美| 久久99精品久久久久久 | 日韩久久午夜一级啪啪 | 中文字幕在线播放一区 | 亚洲午夜在线视频 | 久久国内精品99久久6app | 亚洲视频h | 91夫妻自拍 | 人人干天天射 | 91成人短视频在线观看 | www.国产在线| 久久成人高清 | 99久久精品视频免费 | 插插插色综合 | 精品中文字幕在线 | 欧美在线观看视频 | 国产 字幕 制服 中文 在线 | 色综合天天天天做夜夜夜夜做 | 欧美日韩国产在线观看 | 日本黄色免费电影网站 | 欧美在线观看视频一区二区三区 | 久久久久久久久久久影视 | 久久午夜精品视频 | 日韩成人精品一区二区 | 91人人网 | 2018亚洲男人天堂 | 探花视频在线观看 | 黄色精品国产 | 久久久这里有精品 | 99热手机在线 | 成人av高清在线 | 91高清免费在线观看 | 久要激情网 | 精品亚洲成a人在线观看 | 日韩精品网址 | 婷婷国产在线 | 在线免费高清视频 | 91九色视频网站 | 亚洲色视频 | 视频国产一区二区三区 | 高清免费av在线 | 亚洲区另类春色综合小说校园片 | 日韩激情久久 | 久久免费播放 | 黄网站色成年免费观看 | 毛片一级免费一级 | 久久久久久亚洲精品 | 久久久久婷 | www黄免费 | 国产激情小视频在线观看 | 色狠狠婷婷| 成人三级av | 一区电影| 亚洲另类在线视频 | 99亚洲视频 | av久久久| 亚洲一区二区三区91 | 久久亚洲影视 | 2019免费中文字幕 | 激情文学综合丁香 | 久久久久久高潮国产精品视 | 国产一级片在线播放 | 中文字幕av日韩 | 欧美老女人xx| 99亚洲精品 | 日本三级全黄少妇三2023 | 成人影音在线 | 免费 在线 中文 日本 | 在线观看免费视频你懂的 | 福利视频入口 | 日本不卡123区 | 特级毛片爽www免费版 | 三级av在线免费观看 | 99色免费视频 | 粉嫩av一区二区三区四区在线观看 | 国内精品久久久久国产 | 成人在线视频观看 | 干干夜夜 | 91av短视频| 中国一级片在线播放 | a视频免费 | 91精品国自产在线观看欧美 | 久草综合视频 | 五月婷婷视频在线 | 国产精品理论片在线播放 | 久久免费电影 | 国产精品久久久久久久妇 | 精品国产免费一区二区三区五区 | 一区二区三区视频网站 | 91久久偷偷做嫩草影院 | 91在线看视频 | 99色视频 | 五月天综合在线 | 在线中文视频 | 欧美日韩午夜爽爽 | 国产精品一区二区精品视频免费看 | 国产高清在线免费 | 亚洲毛片久久 | 国产日韩在线观看一区 | 狠狠色狠狠色综合日日小说 | 亚洲国产精品久久久久婷婷884 | 91麻豆看国产在线紧急地址 | 成人h在线观看 | 97品白浆高清久久久久久 | 亚洲天堂精品视频 | 黄色网址中文字幕 | 日韩欧美精品在线观看 | 99久久精品免费看国产一区二区三区 | 国产精品成人av在线 | 青草视频在线 | 一区二区影院 | 91传媒免费观看 | 久草在线免费资源 | 免费色视频网址 | 日韩高清一区在线 | 日韩在线不卡视频 | 亚洲欧美日韩精品一区二区 | 99热 精品在线 | 四季av综合网站 | 日韩av免费观看网站 | 国产欧美最新羞羞视频在线观看 | 天天射天天干天天爽 | 毛片一二区 | 天天干婷婷 | 日韩免费中文 | 日日爽天天操 | 欧美激情精品久久久久久免费 | 免费看精品久久片 | 九九热视频在线播放 | www一起操 | 午夜精品三区 | 日女人电影 | 欧美在线1区| 91中文字幕| 中文字幕 欧美性 | 亚洲三级性片 | 国产成人香蕉 | 久久久www成人免费毛片麻豆 | 亚洲小视频在线观看 | 色婷婷激情电影 | 国产网红在线观看 | 精品免费99久久 | 2021av在线| 欧美精品成人在线 | 亚洲一区视频在线播放 | 精品91| 午夜久久久精品 | 免费亚洲黄色 | 久久久一本精品99久久精品66 | 丝袜av网站| 天天色视频 | 日韩三级免费观看 | 久久,天天综合 | 国产精品三级视频 | 日日夜夜综合网 | 久久一区国产 | 亚洲精品中文字幕在线观看 | 久久久久久国产精品999 | 99色在线观看视频 | 亚洲女同videos| 中文字幕中文字幕中文字幕 | 国产免费片| 99久久夜色精品国产亚洲 | 久久综合影院 | a天堂一码二码专区 | 国产精品久久久久婷婷 | 亚洲午夜久久久影院 | 91香蕉视频黄色 | 日韩中午字幕 | 精品视频99| 国产精品一区二区av日韩在线 | 中文字幕在线专区 | 欧美久久久久久久久久久 | 99久久久久成人国产免费 | 国产亚洲精品久 | 18性欧美xxxⅹ性满足 | 亚洲综合欧美激情 | 天堂网中文在线 | av在线亚洲天堂 | 91精彩在线视频 | 最近中文字幕免费 | 五月天久久激情 | 国产精品久久毛片 | 久久国产午夜精品理论片最新版本 | 亚洲精品在线免费播放 | 黄色一级大片在线免费看国产一 | 综合网在线视频 | 激情片av | 国产短视频在线播放 | 97精品国产97久久久久久粉红 | 久久这里只有精品视频99 | 欧美va天堂在线电影 | 亚洲欧美精品一区 | 欧美大片在线观看一区 | 黄色av电影在线观看 | 一区二区三区日韩在线 | 日本高清dvd | 久久国产女人 | 午夜精品在线看 | 夜夜爽88888免费视频4848 | 天天综合狠狠精品 | 99热这里只有精品国产首页 | 超碰在线97免费 | 91网站观看 | 精品亚洲va在线va天堂资源站 | 精品一区二区在线免费观看 | 成人va视频 | 欧美一级免费在线 | 最新午夜 | av免费观看高清 | 九九综合九九 | 美女网色| 在线观看理论 | 欧美成年黄网站色视频 | 最新91在线视频 | 久久久综合九色合综国产精品 | 黄网站免费久久 | 亚洲伦理中文字幕 | 一本一本久久a久久精品综合 | 亚洲 欧美 日韩 综合 | 国产精品色视频 | 97电影在线 | 久99精品| 国产资源中文字幕 | 999免费视频 | 婷婷在线精品视频 | 日韩在线视 | 精品视频一区在线观看 | 国产精品高潮呻吟久久久久 | 精品久久久久一区二区国产 | 在线韩国电影免费观影完整版 | 亚洲va综合va国产va中文 | www久久精品 | 国产精品久久9 | 午夜影院一级 | 国产99久久精品一区二区300 | 日本精品一区二区三区在线观看 | 国产区av在线 | 国产精品一区二区果冻传媒 | 亚洲黄色在线观看 | 精品福利在线视频 | 亚洲黄色在线观看 | 99精品电影 | 国产视频99 | 亚洲人人精品 | 成人影片在线免费观看 | 国产色啪 | 99久久影视 | 97精品国产97久久久久久粉红 | 久久久香蕉视频 | 欧美动漫一区二区三区 | 天天爽天天做 | 蜜臀91丨九色丨蝌蚪老版 | 精品在线观看一区二区三区 | 最新av在线免费观看 | 精品欧美乱码久久久久久 | 久久精品国产一区二区电影 | 在线视频观看亚洲 | 在线观看911视频 | 亚洲精品乱码久久久久久9色 | 中文字幕在线专区 | 在线观看黄色av | 欧美人人 | 精品国产99国产精品 | 91大片网站| 五月婷婷综合在线视频 | 手机av资源 | 国产精品久久久影视 | 天天爱天天操天天爽 | 国产电影一区二区三区四区 | 久久96国产精品久久99漫画 | 色视频网站在线观看一=区 a视频免费在线观看 | 久久精品www人人爽人人 | 91精品一区国产高清在线gif | 日日摸日日添夜夜爽97 | 91av在线不卡 | www.xxxx欧美| 国产精品资源网 | 国内精品久久久久影院一蜜桃 | 亚洲 欧美 变态 国产 另类 | 亚洲欧洲精品一区二区精品久久久 | 99精品国产视频 | 亚洲人av免费网站 | 日韩免费看视频 | a特级毛片| 91视频在线播放视频 | 亚洲精品av中文字幕在线在线 | 视频一区二区免费 | 亚洲黄色精品 | 国产精品18videosex性欧美 | 精品国产一二三四区 | 国产精品毛片一区二区在线 | 黄网站app在线观看免费视频 | 91av在线精品| 国产福利一区二区在线 | 久久av免费观看 | 在线观看黄色大片 | 欧美精品亚州精品 | 中文字幕在线免费看线人 | 伊人亚洲综合 | 久久成人国产精品 | 日韩精品一区二区三区三炮视频 | 黄色综合 | 久久久久激情电影 | 999电影免费在线观看 | 国产精品久久久久久999 | 久久呀 | 久久久久久久久久久久电影 | 最近中文字幕免费观看 | 国产精品久免费的黄网站 | 超碰在线资源 | 色婷婷激情电影 | 女人久久久久 | 在线观看91久久久久久 | 欧美xxxx性xxxxx高清 | 99九九视频 | av在线直接看 | 日韩啪视频 | 国产在线91精品 | 不卡的av中文字幕 | 日韩欧美第二页 | 草久在线观看视频 | 中文字幕在线一区二区三区 | 亚洲欧美日韩一二三区 | 久久99久久99 | 亚洲最大免费成人网 | 免费三级在线 | 99热网站| www.狠狠操 | av日韩不卡| 五月婷综合 | 在线电影 一区 | 久久这里只精品 | 日韩欧美一区二区在线播放 | 日韩二区三区在线观看 | 久久激情五月婷婷 | 美女av电影 | 激情欧美一区二区三区免费看 | 激情综合色综合久久 | 日韩视频免费 | 久久免费视频网站 | 久草在线最新免费 | 中文字幕美女免费在线 | 91cn国产在线| 国产做aⅴ在线视频播放 | 久久人人爽人人爽人人片av软件 | 国产午夜精品久久久久久久久久 | 国产69精品久久久久99 | 国产黄色精品在线观看 | 日韩特级黄色片 | 国产精品白浆视频 | 激情欧美xxxx | 欧美福利久久 | 日韩精品一区二区三区丰满 | 91porny九色91啦中文 | 中文字幕日韩免费视频 | 91资源在线播放 | 欧美资源在线观看 | 中文字幕 国产视频 | 中文字幕在线看片 | 中文字幕在线国产精品 | 91福利小视频 | 日韩美女高潮 | 99精品国自产在线 | 国产精品系列在线观看 | 三级黄免费看 | 久久丝袜视频 | 国产精品久久久久久久毛片 | 久久一区二区三区超碰国产精品 | 色综合婷婷 | 欧洲精品视频一区二区 | 日黄网站 | 欧美午夜一区二区福利视频 | 亚洲欧洲国产日韩精品 | wwwav视频 | 国产五月色婷婷六月丁香视频 | 精品国产91亚洲一区二区三区www | 成年性视频 | 99视频在线精品国自产拍免费观看 | 国产一级不卡视频 | www.国产视频 | 日日精品 | 欧美性极品xxxx做受 | 欧美日韩精品免费观看视频 | 麻豆成人网| 91亚洲夫妻| 国产91勾搭技师精品 | 日韩av一区二区在线 | 日韩一区二区三区高清在线观看 | av网址在线播放 | 九色琪琪久久综合网天天 | av高清免费在线 | 国产一级二级在线播放 | 波多野结衣小视频 | 国产一区二区不卡视频 | 91禁在线看 | 欧美日韩激情视频8区 | 天天操天天操一操 | 91亚洲影院 | 日韩av一区在线观看 | 国产欧美日韩视频 | 九月婷婷综合网 | 美女久久久久 | 涩涩网站在线观看 | 亚洲综合五月 | 999久久a精品合区久久久 | 亚洲欧美国内爽妇网 | 天天艹天天干天天 | 久久亚洲私人国产精品 | 一级欧美一级日韩 | 亚洲国产天堂av | 美女网站在线看 | 中文字幕在线观看完整 | av视屏在线 | 国产1区2区 | 久久99国产精品久久99 | 婷婷色网址| 一本一本久久a久久精品综合妖精 | 成人免费视频网 | 91丨九色丨国产丨porny精品 | 国产精品一区二区三区免费视频 | 精品美女国产在线 | 久久久久久久久久免费视频 | 日韩欧美一区二区三区视频 | 就要干b | 成人黄色毛片视频 | 激情综合亚洲精品 | 久草视频在线免费看 | 国产免费观看久久 | 久久成人黄色 | 岛国av在线免费 | 欧美一区日韩精品 | 国产超碰在线 | 免费开视频 | 国产中文字幕一区 | 丁香网五月天 | 久久久久这里只有精品 | 亚洲一区二区高潮无套美女 | 亚洲视频,欧洲视频 | 久久激情五月激情 | 欧美精品国产综合久久 | av爱干| 国产精品成人自拍 | 在线观看视频一区二区三区 | 国产原创在线视频 | 一本一本久久a久久精品牛牛影视 | 国产精品 中文字幕 亚洲 欧美 | 午夜av不卡 | 亚洲精品成人免费 | 中文字幕久久精品一区 | 精品成人在线 | 国产一级高清 | 五月婷婷av | 欧美激情操 | 成人性生交大片免费观看网站 | 欧美日韩午夜爽爽 | 少妇性xxx| 亚洲免费婷婷 | 国产精品久久久久久av | 成人国产精品久久久久久亚洲 | 国产欧美精品在线观看 | 黄色影院在线免费观看 | 日本九九视频 | 婷婷丁香在线视频 | 亚洲 欧洲 国产 日本 综合 | 一区二区三区在线看 | 免费久久久久久 | 一区二区三区四区久久 | 天天操天天操天天 | 激情小说 五月 | 日本中文字幕系列 | 夜添久久精品亚洲国产精品 | 激情欧美日韩一区二区 | 叶爱av在线| 日韩在线视频不卡 | 欧美极品xxxxx | 久久黄色免费观看 | 久久国产香蕉视频 | 日韩视频一二三区 | 在线观看色视频 | 久久视频国产精品免费视频在线 | 亚洲精品99久久久久中文字幕 | 欧美日韩一区二区三区视频 | 国产精品成人免费 | wwxxx日本| 丁香亚洲| 99理论片 | 中文av字幕在线观看 | 国产高清视频在线播放 | 日日天天狠狠 | 国产精品不卡在线 | 精品一区二区在线免费观看 | 特级毛片在线 | 91av欧美 | 亚洲成a人片在线观看网站口工 | 亚洲精品色视频 | 久草网免费 | 9797在线看片亚洲精品 | 成人91在线 | 欧美黄色特级片 | 天天综合网天天综合色 | 欧美一级免费 | 国产精品成人久久久久久久 | 午夜少妇av| 国产高清绿奴videos | 成年人在线观看 | 97电影在线看视频 | 美女国产免费 | 在线电影日韩 | 日韩欧美中文 | 久久草在线免费 | 欧美精品网站 | 国产裸体bbb视频 | 亚洲国产欧美在线看片xxoo | 久久久免费在线观看 | 六月丁香久久 | 久草视频在线播放 | 成人毛片一区 | 日本黄色大片免费 | 黄色成人av在线 | 在线观看一区二区精品 | 色多视频在线观看 | 波多野结衣在线观看视频 | 91成人免费在线视频 | 国产精品高清在线 | 五月天久久激情 | 男女啪啪视屏 | 亚洲手机天堂 | 久草在线视频国产 | 欧美一区二区在线免费观看 | 国产午夜精品一区二区三区欧美 | 久久视频免费 | 免费a现在观看 | 免费看污网站 | 美女福利视频网 | 色a资源在线 | 精品一二区 | 一级黄色a视频 | 激情婷婷av | 精品国产三级 | 美女精品国产 | 精品久久久久一区二区国产 | 天天拍天天草 | 91最新网址 | 日本公妇在线观看高清 | 91精品中文字幕 | 日韩av免费观看网站 | 亚洲天堂网站视频 | 夜夜躁狠狠躁日日躁 | 91精选在线 | 麻豆久久一区二区 | 超碰人人99| 精品一二区 | 三上悠亚在线免费 | 欧美日韩一区二区三区免费视频 | 91精品一区在线观看 | 奇人奇案qvod| 91九色porny蝌蚪视频 | 亚洲精品在线免费 | 久久激情婷婷 | 亚洲国产视频网站 | 亚洲精品电影在线 | 日日夜夜噜噜噜 | 九九在线精品视频 | 久久久一本精品99久久精品 | 久草综合视频 | 欧美午夜精品久久久久久浪潮 | 日韩a在线看 | 欧美精品免费在线观看 | 亚洲丁香日韩 | 亚洲一区二区三区毛片 | 亚洲手机天堂 | 亚洲国产日本 | 婷婷在线资源 | 免费网站黄 | 91中文字幕| 日韩欧美视频一区二区 | 91中文视频 | 国产精品成人一区二区 | 国产在线成人 | 精品久久久久久久 | 黄av在线| 91视频高清完整版 | 国产精品久久久久久久久免费看 | 黄色片免费看 | 日韩在线色 | 黄色视屏在线免费观看 | 国产午夜麻豆影院在线观看 | 亚洲作爱 | 久久最新网址 | 免费日韩一级片 | 九色琪琪久久综合网天天 | av日韩av| 国产一级在线观看 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 欧美激情综合色 | 国产精品a级 | 伊人欧美 | 国产精品岛国久久久久久久久红粉 | 色午夜影院 | 91大神精品视频在线观看 | 又黄又爽又色无遮挡免费 | 午夜久久网站 | 中文字幕乱码电影 | 98福利在线 | 久福利 | 在线免费观看黄色大片 | 色综合天天天天做夜夜夜夜做 | 麻豆极品 | 久久久精品综合 | 日本h视频在线观看 | 中文在线亚洲 | 伊人天天综合 | 日本中文一级片 | 91精品视频免费在线观看 | 亚洲精品国产欧美在线观看 | 日批在线观看 | 福利视频一区二区 | 久久久精品综合 | 黄网站免费大全入口 | 天天干人人干 | 天天天综合网 | 成人黄色毛片 | 国产福利精品视频 | 国产尤物一区二区三区 | 日本免费一二三区 | 欧美激情第一区 | 狠狠狠操| 亚洲视频六区 | 91免费看片黄 | 亚洲少妇激情 | 韩国av免费观看 | 精品视频成人 | 91成人免费在线视频 | 精品国产观看 | 天天人人 | 黄色三级av | 成人av免费电影 | 在线中文字幕播放 | 精品一二三区视频 | 97超级碰碰碰视频在线观看 | 17videosex性欧美 | 国产精彩视频一区二区 | 日韩免费电影网站 | 在线免费观看视频 | 国产综合久久 | 51久久夜色精品国产麻豆 | 国产精品国产三级在线专区 | 新版资源中文在线观看 | 欧美日韩免费看 | 亚洲天堂精品视频 | 日韩电影在线观看一区 | 日韩二区在线 | 手机av永久免费 | 伊人久久婷婷 | 久草热视频 | 色综合久久88色综合天天6 | 成人免费影院 | 免费视频久久久久久久 | 狠狠狠色丁香综合久久天下网 | av一二三区 | 日韩欧美xxx | 久久五月情影视 | 国产91免费在线观看 | 免费av网址大全 | 免费观看的黄色 | 天天干天天干天天操 | 五月婷婷激情综合 | 国产亚洲精品美女 | 欧美激情综合五月色丁香 | 免费在线国产视频 | 香蕉视频在线看 | 99综合电影在线视频 | 欧美色图一区 | 五月天婷婷在线观看视频 | 成人av电影免费观看 | 激情婷婷综合网 | 99久久久成人国产精品 | 中文字幕人成不卡一区 | 91久久精品一区二区二区 | 久久超级碰视频 | 五月激情姐姐 | 成年人看片网站 | av高清一区二区三区 | 日韩天堂在线观看 | 午夜精品久久久久 | 亚洲国产视频a | 久久视频这里只有精品 | 成人av资源网 | 美女视频黄免费网站 | 黄色资源网站 | 亚洲精欧美一区二区精品 | 欧美日韩午夜爽爽 | 中文字幕在线观看你懂的 | www.在线观看视频 | 激情开心站 | 日本精品视频在线 | 久久久av电影 | 一区二区三区在线免费播放 | www国产在线| 中文字幕在线观看第一区 | 亚洲精品综合在线观看 | 日韩电影中文 | 国产美女精品久久久 | 久久伊人国产精品 | 国产精品一区二区在线播放 |