|
|
|
package com.alibaba.excel.context;
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
import java.io.FileOutputStream;
|
|
|
|
import java.io.OutputStream;
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.UUID;
|
|
|
|
|
|
|
|
import com.alibaba.excel.enums.WriteTypeEnum;
|
|
|
|
import com.alibaba.excel.exception.ExcelGenerateException;
|
|
|
|
import com.alibaba.excel.metadata.CellData;
|
|
|
|
import com.alibaba.excel.metadata.Head;
|
|
|
|
import com.alibaba.excel.support.ExcelTypeEnum;
|
|
|
|
import com.alibaba.excel.util.DateUtils;
|
|
|
|
import com.alibaba.excel.util.FileUtils;
|
|
|
|
import com.alibaba.excel.util.NumberDataFormatterUtils;
|
|
|
|
import com.alibaba.excel.util.StringUtils;
|
|
|
|
import com.alibaba.excel.util.WorkBookUtil;
|
|
|
|
import com.alibaba.excel.util.WriteHandlerUtils;
|
|
|
|
import com.alibaba.excel.write.metadata.WriteSheet;
|
|
|
|
import com.alibaba.excel.write.metadata.WriteTable;
|
|
|
|
import com.alibaba.excel.write.metadata.WriteWorkbook;
|
|
|
|
import com.alibaba.excel.write.metadata.holder.WriteHolder;
|
|
|
|
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
|
|
|
|
import com.alibaba.excel.write.metadata.holder.WriteTableHolder;
|
|
|
|
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder;
|
|
|
|
import com.alibaba.excel.write.property.ExcelWriteHeadProperty;
|
|
|
|
|
|
|
|
import org.apache.poi.hssf.record.crypto.Biff8EncryptionKey;
|
|
|
|
import org.apache.poi.openxml4j.opc.OPCPackage;
|
|
|
|
import org.apache.poi.openxml4j.opc.PackageAccess;
|
|
|
|
import org.apache.poi.poifs.crypt.EncryptionInfo;
|
|
|
|
import org.apache.poi.poifs.crypt.EncryptionMode;
|
|
|
|
import org.apache.poi.poifs.crypt.Encryptor;
|
|
|
|
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
|
|
|
import org.apache.poi.ss.usermodel.Cell;
|
|
|
|
import org.apache.poi.ss.usermodel.Row;
|
|
|
|
import org.apache.poi.ss.usermodel.Sheet;
|
|
|
|
import org.apache.poi.ss.usermodel.Workbook;
|
|
|
|
import org.apache.poi.ss.util.CellRangeAddress;
|
|
|
|
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A context is the main anchorage point of a excel writer.
|
|
|
|
*
|
|
|
|
* @author jipengfei
|
|
|
|
*/
|
|
|
|
public class WriteContextImpl implements WriteContext {
|
|
|
|
|
|
|
|
private static final Logger LOGGER = LoggerFactory.getLogger(WriteContextImpl.class);
|
|
|
|
private static final String NO_SHEETS="no sheets";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The Workbook currently written
|
|
|
|
*/
|
|
|
|
private WriteWorkbookHolder writeWorkbookHolder;
|
|
|
|
/**
|
|
|
|
* Current sheet holder
|
|
|
|
*/
|
|
|
|
private WriteSheetHolder writeSheetHolder;
|
|
|
|
/**
|
|
|
|
* The table currently written
|
|
|
|
*/
|
|
|
|
private WriteTableHolder writeTableHolder;
|
|
|
|
/**
|
|
|
|
* Configuration of currently operated cell
|
|
|
|
*/
|
|
|
|
private WriteHolder currentWriteHolder;
|
|
|
|
/**
|
|
|
|
* Prevent multiple shutdowns
|
|
|
|
*/
|
|
|
|
private boolean finished = false;
|
|
|
|
|
|
|
|
public WriteContextImpl(WriteWorkbook writeWorkbook) {
|
|
|
|
if (writeWorkbook == null) {
|
|
|
|
throw new IllegalArgumentException("Workbook argument cannot be null");
|
|
|
|
}
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("Begin to Initialization 'WriteContextImpl'");
|
|
|
|
}
|
|
|
|
initCurrentWorkbookHolder(writeWorkbook);
|
|
|
|
WriteHandlerUtils.beforeWorkbookCreate(this);
|
|
|
|
try {
|
|
|
|
WorkBookUtil.createWorkBook(writeWorkbookHolder);
|
|
|
|
} catch (Exception e) {
|
|
|
|
throw new ExcelGenerateException("Create workbook failure", e);
|
|
|
|
}
|
|
|
|
WriteHandlerUtils.afterWorkbookCreate(this);
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("Initialization 'WriteContextImpl' complete");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void initCurrentWorkbookHolder(WriteWorkbook writeWorkbook) {
|
|
|
|
writeWorkbookHolder = new WriteWorkbookHolder(writeWorkbook);
|
|
|
|
currentWriteHolder = writeWorkbookHolder;
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("CurrentConfiguration is writeWorkbookHolder");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param writeSheet
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public void currentSheet(WriteSheet writeSheet, WriteTypeEnum writeType) {
|
|
|
|
if (writeSheet == null) {
|
|
|
|
throw new IllegalArgumentException("Sheet argument cannot be null");
|
|
|
|
}
|
|
|
|
if (selectSheetFromCache(writeSheet)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
initCurrentSheetHolder(writeSheet);
|
|
|
|
|
|
|
|
// Workbook handler need to supplementary execution
|
|
|
|
WriteHandlerUtils.beforeWorkbookCreate(this, true);
|
|
|
|
WriteHandlerUtils.afterWorkbookCreate(this, true);
|
|
|
|
|
|
|
|
// Initialization current sheet
|
|
|
|
initSheet(writeType);
|
|
|
|
}
|
|
|
|
|
|
|
|
private boolean selectSheetFromCache(WriteSheet writeSheet) {
|
|
|
|
writeSheetHolder = null;
|
|
|
|
Integer sheetNo = writeSheet.getSheetNo();
|
|
|
|
if (sheetNo == null && StringUtils.isEmpty(writeSheet.getSheetName())) {
|
|
|
|
sheetNo = 0;
|
|
|
|
}
|
|
|
|
if (sheetNo != null) {
|
|
|
|
writeSheetHolder = writeWorkbookHolder.getHasBeenInitializedSheetIndexMap().get(sheetNo);
|
|
|
|
}
|
|
|
|
if (writeSheetHolder == null && !StringUtils.isEmpty(writeSheet.getSheetName())) {
|
|
|
|
writeSheetHolder = writeWorkbookHolder.getHasBeenInitializedSheetNameMap().get(writeSheet.getSheetName());
|
|
|
|
}
|
|
|
|
if (writeSheetHolder == null) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("Sheet:{} is already existed", writeSheet.getSheetNo());
|
|
|
|
}
|
|
|
|
writeSheetHolder.setNewInitialization(Boolean.FALSE);
|
|
|
|
writeTableHolder = null;
|
|
|
|
currentWriteHolder = writeSheetHolder;
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("CurrentConfiguration is writeSheetHolder");
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
private void initCurrentSheetHolder(WriteSheet writeSheet) {
|
|
|
|
writeSheetHolder = new WriteSheetHolder(writeSheet, writeWorkbookHolder);
|
|
|
|
writeTableHolder = null;
|
|
|
|
currentWriteHolder = writeSheetHolder;
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("CurrentConfiguration is writeSheetHolder");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void initSheet(WriteTypeEnum writeType) {
|
|
|
|
WriteHandlerUtils.beforeSheetCreate(this);
|
|
|
|
Sheet currentSheet;
|
|
|
|
try {
|
|
|
|
if (writeSheetHolder.getSheetNo() != null) {
|
|
|
|
// When the add default sort order of appearance
|
|
|
|
if (WriteTypeEnum.ADD.equals(writeType) && writeWorkbookHolder.getTempTemplateInputStream() == null) {
|
|
|
|
currentSheet = createSheet();
|
|
|
|
} else {
|
|
|
|
currentSheet = writeWorkbookHolder.getWorkbook().getSheetAt(writeSheetHolder.getSheetNo());
|
|
|
|
writeSheetHolder
|
|
|
|
.setCachedSheet(
|
|
|
|
writeWorkbookHolder.getCachedWorkbook().getSheetAt(writeSheetHolder.getSheetNo()));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// sheet name must not null
|
|
|
|
currentSheet = writeWorkbookHolder.getWorkbook().getSheet(writeSheetHolder.getSheetName());
|
|
|
|
writeSheetHolder
|
|
|
|
.setCachedSheet(writeWorkbookHolder.getCachedWorkbook().getSheet(writeSheetHolder.getSheetName()));
|
|
|
|
}
|
|
|
|
} catch (IllegalArgumentException e) {
|
|
|
|
if (e.getMessage() != null && e.getMessage().contains(NO_SHEETS)) {
|
|
|
|
currentSheet = createSheet();
|
|
|
|
} else {
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (currentSheet == null) {
|
|
|
|
currentSheet = createSheet();
|
|
|
|
}
|
|
|
|
writeSheetHolder.setSheet(currentSheet);
|
|
|
|
WriteHandlerUtils.afterSheetCreate(this);
|
|
|
|
if (WriteTypeEnum.ADD.equals(writeType)) {
|
|
|
|
// Initialization head
|
|
|
|
initHead(writeSheetHolder.excelWriteHeadProperty());
|
|
|
|
}
|
|
|
|
writeWorkbookHolder.getHasBeenInitializedSheetIndexMap().put(writeSheetHolder.getSheetNo(), writeSheetHolder);
|
|
|
|
writeWorkbookHolder.getHasBeenInitializedSheetNameMap().put(writeSheetHolder.getSheetName(), writeSheetHolder);
|
|
|
|
}
|
|
|
|
|
|
|
|
private Sheet createSheet() {
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("Can not find sheet:{} ,now create it", writeSheetHolder.getSheetNo());
|
|
|
|
}
|
|
|
|
if (StringUtils.isEmpty(writeSheetHolder.getSheetName())) {
|
|
|
|
writeSheetHolder.setSheetName(writeSheetHolder.getSheetNo().toString());
|
|
|
|
}
|
|
|
|
Sheet currentSheet =
|
|
|
|
WorkBookUtil.createSheet(writeWorkbookHolder.getWorkbook(), writeSheetHolder.getSheetName());
|
|
|
|
writeSheetHolder.setCachedSheet(currentSheet);
|
|
|
|
return currentSheet;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void initHead(ExcelWriteHeadProperty excelWriteHeadProperty) {
|
|
|
|
if (!currentWriteHolder.needHead() || !currentWriteHolder.excelWriteHeadProperty().hasHead()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
int newRowIndex = writeSheetHolder.getNewRowIndexAndStartDoWrite();
|
|
|
|
newRowIndex += currentWriteHolder.relativeHeadRowIndex();
|
|
|
|
// Combined head
|
|
|
|
if (currentWriteHolder.automaticMergeHead()) {
|
|
|
|
addMergedRegionToCurrentSheet(excelWriteHeadProperty, newRowIndex);
|
|
|
|
}
|
|
|
|
for (int relativeRowIndex = 0, i = newRowIndex; i < excelWriteHeadProperty.getHeadRowNumber()
|
|
|
|
+ newRowIndex; i++, relativeRowIndex++) {
|
|
|
|
WriteHandlerUtils.beforeRowCreate(this, newRowIndex, relativeRowIndex, Boolean.TRUE);
|
|
|
|
Row row = WorkBookUtil.createRow(writeSheetHolder.getSheet(), i);
|
|
|
|
WriteHandlerUtils.afterRowCreate(this, row, relativeRowIndex, Boolean.TRUE);
|
|
|
|
addOneRowOfHeadDataToExcel(row, excelWriteHeadProperty.getHeadMap(), relativeRowIndex);
|
|
|
|
WriteHandlerUtils.afterRowDispose(this, row, relativeRowIndex, Boolean.TRUE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void addMergedRegionToCurrentSheet(ExcelWriteHeadProperty excelWriteHeadProperty, int rowIndex) {
|
|
|
|
for (com.alibaba.excel.metadata.CellRange cellRangeModel : excelWriteHeadProperty.headCellRangeList()) {
|
|
|
|
writeSheetHolder.getSheet()
|
|
|
|
.addMergedRegionUnsafe(new CellRangeAddress(cellRangeModel.getFirstRow() + rowIndex,
|
|
|
|
cellRangeModel.getLastRow() + rowIndex, cellRangeModel.getFirstCol(), cellRangeModel.getLastCol()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void addOneRowOfHeadDataToExcel(Row row, Map<Integer, Head> headMap, int relativeRowIndex) {
|
|
|
|
for (Map.Entry<Integer, Head> entry : headMap.entrySet()) {
|
|
|
|
Head head = entry.getValue();
|
|
|
|
int columnIndex = entry.getKey();
|
|
|
|
WriteHandlerUtils.beforeCellCreate(this, row, head, columnIndex, relativeRowIndex, Boolean.TRUE);
|
|
|
|
Cell cell = row.createCell(columnIndex);
|
|
|
|
WriteHandlerUtils.afterCellCreate(this, cell, head, relativeRowIndex, Boolean.TRUE);
|
|
|
|
cell.setCellValue(head.getHeadNameList().get(relativeRowIndex));
|
|
|
|
WriteHandlerUtils.afterCellDispose(this, (CellData) null, cell, head, relativeRowIndex, Boolean.TRUE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void currentTable(WriteTable writeTable) {
|
|
|
|
if (writeTable == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (writeTable.getTableNo() == null || writeTable.getTableNo() <= 0) {
|
|
|
|
writeTable.setTableNo(0);
|
|
|
|
}
|
|
|
|
if (writeSheetHolder.getHasBeenInitializedTable().containsKey(writeTable.getTableNo())) {
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("Table:{} is already existed", writeTable.getTableNo());
|
|
|
|
}
|
|
|
|
writeTableHolder = writeSheetHolder.getHasBeenInitializedTable().get(writeTable.getTableNo());
|
|
|
|
writeTableHolder.setNewInitialization(Boolean.FALSE);
|
|
|
|
currentWriteHolder = writeTableHolder;
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("CurrentConfiguration is writeTableHolder");
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
initCurrentTableHolder(writeTable);
|
|
|
|
|
|
|
|
// Workbook and sheet handler need to supplementary execution
|
|
|
|
WriteHandlerUtils.beforeWorkbookCreate(this, true);
|
|
|
|
WriteHandlerUtils.afterWorkbookCreate(this, true);
|
|
|
|
WriteHandlerUtils.beforeSheetCreate(this, true);
|
|
|
|
WriteHandlerUtils.afterSheetCreate(this, true);
|
|
|
|
|
|
|
|
initHead(writeTableHolder.excelWriteHeadProperty());
|
|
|
|
}
|
|
|
|
|
|
|
|
private void initCurrentTableHolder(WriteTable writeTable) {
|
|
|
|
writeTableHolder = new WriteTableHolder(writeTable, writeSheetHolder, writeWorkbookHolder);
|
|
|
|
writeSheetHolder.getHasBeenInitializedTable().put(writeTable.getTableNo(), writeTableHolder);
|
|
|
|
currentWriteHolder = writeTableHolder;
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("CurrentConfiguration is writeTableHolder");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public WriteWorkbookHolder writeWorkbookHolder() {
|
|
|
|
return writeWorkbookHolder;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public WriteSheetHolder writeSheetHolder() {
|
|
|
|
return writeSheetHolder;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public WriteTableHolder writeTableHolder() {
|
|
|
|
return writeTableHolder;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public WriteHolder currentWriteHolder() {
|
|
|
|
return currentWriteHolder;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void finish(boolean onException) {
|
|
|
|
if (finished) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
finished = true;
|
|
|
|
WriteHandlerUtils.afterWorkbookDispose(this);
|
|
|
|
if (writeWorkbookHolder == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
Throwable throwable = null;
|
|
|
|
boolean isOutputStreamEncrypt = false;
|
|
|
|
// Determine if you need to write excel
|
|
|
|
boolean writeExcel = !onException;
|
|
|
|
if (writeWorkbookHolder.getWriteExcelOnException()) {
|
|
|
|
writeExcel = Boolean.TRUE;
|
|
|
|
}
|
|
|
|
// No data is written if an exception is thrown
|
|
|
|
if (writeExcel) {
|
|
|
|
try {
|
|
|
|
isOutputStreamEncrypt = doOutputStreamEncrypt07();
|
|
|
|
} catch (Throwable t) {
|
|
|
|
throwable = t;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!isOutputStreamEncrypt) {
|
|
|
|
try {
|
|
|
|
if (writeExcel) {
|
|
|
|
writeWorkbookHolder.getWorkbook().write(writeWorkbookHolder.getOutputStream());
|
|
|
|
}
|
|
|
|
writeWorkbookHolder.getWorkbook().close();
|
|
|
|
} catch (Throwable t) {
|
|
|
|
throwable = t;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
Workbook workbook = writeWorkbookHolder.getWorkbook();
|
|
|
|
if (workbook instanceof SXSSFWorkbook) {
|
|
|
|
((SXSSFWorkbook) workbook).dispose();
|
|
|
|
}
|
|
|
|
} catch (Throwable t) {
|
|
|
|
throwable = t;
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
if (writeWorkbookHolder.getAutoCloseStream() && writeWorkbookHolder.getOutputStream() != null) {
|
|
|
|
writeWorkbookHolder.getOutputStream().close();
|
|
|
|
}
|
|
|
|
} catch (Throwable t) {
|
|
|
|
throwable = t;
|
|
|
|
}
|
|
|
|
if (writeExcel && !isOutputStreamEncrypt) {
|
|
|
|
try {
|
|
|
|
doFileEncrypt07();
|
|
|
|
} catch (Throwable t) {
|
|
|
|
throwable = t;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
if (writeWorkbookHolder.getTempTemplateInputStream() != null) {
|
|
|
|
writeWorkbookHolder.getTempTemplateInputStream().close();
|
|
|
|
}
|
|
|
|
} catch (Throwable t) {
|
|
|
|
throwable = t;
|
|
|
|
}
|
|
|
|
clearEncrypt03();
|
|
|
|
removeThreadLocalCache();
|
|
|
|
if (throwable != null) {
|
|
|
|
throw new ExcelGenerateException("Can not close IO.", throwable);
|
|
|
|
}
|
|
|
|
if (LOGGER.isDebugEnabled()) {
|
|
|
|
LOGGER.debug("Finished write.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void removeThreadLocalCache() {
|
|
|
|
NumberDataFormatterUtils.removeThreadLocalCache();
|
|
|
|
DateUtils.removeThreadLocalCache();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Sheet getCurrentSheet() {
|
|
|
|
return writeSheetHolder.getSheet();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean needHead() {
|
|
|
|
return writeSheetHolder.needHead();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public OutputStream getOutputStream() {
|
|
|
|
return writeWorkbookHolder.getOutputStream();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Workbook getWorkbook() {
|
|
|
|
return writeWorkbookHolder.getWorkbook();
|
|
|
|
}
|
|
|
|
|
|
|
|
private void clearEncrypt03() {
|
|
|
|
if (StringUtils.isEmpty(writeWorkbookHolder.getPassword())
|
|
|
|
|| !ExcelTypeEnum.XLS.equals(writeWorkbookHolder.getExcelType())) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
Biff8EncryptionKey.setCurrentUserPassword(null);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* To encrypt
|
|
|
|
*/
|
|
|
|
private boolean doOutputStreamEncrypt07() throws Exception {
|
|
|
|
if (StringUtils.isEmpty(writeWorkbookHolder.getPassword())
|
|
|
|
|| !ExcelTypeEnum.XLSX.equals(writeWorkbookHolder.getExcelType())) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (writeWorkbookHolder.getFile() != null) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
File tempXlsx = FileUtils.createTmpFile(UUID.randomUUID().toString() + ".xlsx");
|
|
|
|
FileOutputStream tempFileOutputStream = new FileOutputStream(tempXlsx);
|
|
|
|
try {
|
|
|
|
writeWorkbookHolder.getWorkbook().write(tempFileOutputStream);
|
|
|
|
} finally {
|
|
|
|
try {
|
|
|
|
writeWorkbookHolder.getWorkbook().close();
|
|
|
|
tempFileOutputStream.close();
|
|
|
|
} catch (Exception e) {
|
|
|
|
if (!tempXlsx.delete()) {
|
|
|
|
throw new ExcelGenerateException("Can not delete temp File!");
|
|
|
|
}
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
POIFSFileSystem fileSystem = null;
|
|
|
|
try {
|
|
|
|
fileSystem = openFileSystemAndEncrypt(tempXlsx);
|
|
|
|
fileSystem.writeFilesystem(writeWorkbookHolder.getOutputStream());
|
|
|
|
} finally {
|
|
|
|
if (fileSystem != null) {
|
|
|
|
fileSystem.close();
|
|
|
|
}
|
|
|
|
if (!tempXlsx.delete()) {
|
|
|
|
throw new ExcelGenerateException("Can not delete temp File!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* To encrypt
|
|
|
|
*/
|
|
|
|
private void doFileEncrypt07() throws Exception {
|
|
|
|
if (StringUtils.isEmpty(writeWorkbookHolder.getPassword())
|
|
|
|
|| !ExcelTypeEnum.XLSX.equals(writeWorkbookHolder.getExcelType())) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (writeWorkbookHolder.getFile() == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
FileOutputStream fileOutputStream = null;
|
|
|
|
POIFSFileSystem fileSystem = null;
|
|
|
|
try {
|
|
|
|
fileSystem = openFileSystemAndEncrypt(writeWorkbookHolder.getFile());
|
|
|
|
fileOutputStream = new FileOutputStream(writeWorkbookHolder.getFile());
|
|
|
|
fileSystem.writeFilesystem(fileOutputStream);
|
|
|
|
} finally {
|
|
|
|
if (fileOutputStream != null) {
|
|
|
|
fileOutputStream.close();
|
|
|
|
}
|
|
|
|
if (fileSystem != null) {
|
|
|
|
fileSystem.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private POIFSFileSystem openFileSystemAndEncrypt(File file) throws Exception {
|
|
|
|
POIFSFileSystem fileSystem = new POIFSFileSystem();
|
|
|
|
Encryptor encryptor = new EncryptionInfo(EncryptionMode.standard).getEncryptor();
|
|
|
|
encryptor.confirmPassword(writeWorkbookHolder.getPassword());
|
|
|
|
OPCPackage opcPackage = null;
|
|
|
|
try {
|
|
|
|
opcPackage = OPCPackage.open(file, PackageAccess.READ_WRITE);
|
|
|
|
OutputStream outputStream = encryptor.getDataStream(fileSystem);
|
|
|
|
opcPackage.save(outputStream);
|
|
|
|
} finally {
|
|
|
|
if (opcPackage != null) {
|
|
|
|
opcPackage.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return fileSystem;
|
|
|
|
}
|
|
|
|
}
|