2020-12-26 16:44:05 +08:00
|
|
|
|
package cn.keking.service;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
|
2019-04-11 14:45:22 +08:00
|
|
|
|
import cn.keking.config.ConfigConstants;
|
2018-01-17 17:51:53 +08:00
|
|
|
|
import cn.keking.model.FileAttribute;
|
|
|
|
|
import cn.keking.model.FileType;
|
2019-04-08 17:50:13 +08:00
|
|
|
|
import cn.keking.service.cache.CacheService;
|
2020-12-27 01:43:50 +08:00
|
|
|
|
import cn.keking.utils.WebUtils;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
import org.springframework.stereotype.Component;
|
2019-06-17 14:21:16 +08:00
|
|
|
|
import org.springframework.util.StringUtils;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
|
2020-12-25 22:47:30 +08:00
|
|
|
|
import javax.servlet.http.HttpServletRequest;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
import java.io.*;
|
2020-05-15 18:09:19 +08:00
|
|
|
|
import java.nio.charset.StandardCharsets;
|
2020-12-26 19:13:50 +08:00
|
|
|
|
import java.util.List;
|
|
|
|
|
import java.util.Map;
|
2018-01-17 14:10:40 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @author yudian-it
|
|
|
|
|
* @date 2017/11/13
|
|
|
|
|
*/
|
|
|
|
|
@Component
|
2020-12-26 19:13:50 +08:00
|
|
|
|
public class FileHandlerService {
|
2019-10-25 13:59:29 +08:00
|
|
|
|
|
2020-05-19 11:04:53 +08:00
|
|
|
|
private static final String DEFAULT_CONVERTER_CHARSET = System.getProperty("sun.jnu.encoding");
|
|
|
|
|
private final String fileDir = ConfigConstants.getFileDir();
|
2020-05-15 18:09:19 +08:00
|
|
|
|
private final CacheService cacheService;
|
2018-01-17 17:51:53 +08:00
|
|
|
|
|
2020-12-26 19:13:50 +08:00
|
|
|
|
public FileHandlerService(CacheService cacheService) {
|
2020-05-15 18:09:19 +08:00
|
|
|
|
this.cacheService = cacheService;
|
|
|
|
|
}
|
2019-04-08 17:50:13 +08:00
|
|
|
|
|
2018-01-17 14:10:40 +08:00
|
|
|
|
/**
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @return 已转换过的文件集合(缓存)
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
|
|
|
|
public Map<String, String> listConvertedFiles() {
|
2019-04-08 17:50:13 +08:00
|
|
|
|
return cacheService.getPDFCache();
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @return 已转换过的文件,根据文件名获取
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
|
|
|
|
public String getConvertedFile(String key) {
|
2019-04-08 17:50:13 +08:00
|
|
|
|
return cacheService.getPDFCache(key);
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
|
|
|
|
|
2019-04-25 18:39:58 +08:00
|
|
|
|
/**
|
|
|
|
|
* @param key pdf本地路径
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @return 已将pdf转换成图片的图片本地相对路径
|
2019-04-25 18:39:58 +08:00
|
|
|
|
*/
|
|
|
|
|
public Integer getConvertedPdfImage(String key) {
|
|
|
|
|
return cacheService.getPdfImageCache(key);
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-17 14:10:40 +08:00
|
|
|
|
/**
|
|
|
|
|
* 查看文件类型(防止参数中存在.点号或者其他特殊字符,所以先抽取文件名,然后再获取文件类型)
|
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param url url
|
|
|
|
|
* @return 文件类型
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
2018-01-17 17:51:53 +08:00
|
|
|
|
public FileType typeFromUrl(String url) {
|
2020-05-15 18:09:19 +08:00
|
|
|
|
String nonPramStr = url.substring(0, url.contains("?") ? url.indexOf("?") : url.length());
|
2018-01-17 14:10:40 +08:00
|
|
|
|
String fileName = nonPramStr.substring(nonPramStr.lastIndexOf("/") + 1);
|
2020-12-26 16:44:05 +08:00
|
|
|
|
return this.typeFromFileName(fileName);
|
2019-06-17 14:21:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private FileType typeFromFileName(String fileName) {
|
2018-01-17 14:10:40 +08:00
|
|
|
|
String fileType = fileName.substring(fileName.lastIndexOf(".") + 1);
|
2020-12-26 16:44:05 +08:00
|
|
|
|
return FileType.to(fileType);
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
2020-12-25 22:47:30 +08:00
|
|
|
|
|
2018-01-17 14:10:40 +08:00
|
|
|
|
/**
|
|
|
|
|
* 从url中剥离出文件名
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-12-26 00:56:48 +08:00
|
|
|
|
* @param url 格式如:http://www.com.cn/20171113164107_月度绩效表模板(新).xls?UCloudPublicKey=ucloudtangshd@weifenf.com14355492830001993909323&Expires=&Signature=I D1NOFtAJSPT16E6imv6JWuq0k=
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @return 文件名
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
|
|
|
|
public String getFileNameFromURL(String url) {
|
|
|
|
|
// 因为url的参数中可能会存在/的情况,所以直接url.lastIndexOf("/")会有问题
|
|
|
|
|
// 所以先从?处将url截断,然后运用url.lastIndexOf("/")获取文件名
|
2020-12-25 22:47:30 +08:00
|
|
|
|
String noQueryUrl = url.substring(0, url.contains("?") ? url.indexOf("?") : url.length());
|
2020-05-15 18:09:19 +08:00
|
|
|
|
return noQueryUrl.substring(noQueryUrl.lastIndexOf("/") + 1);
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* 从路径中获取文件负
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
|
|
|
|
* @param path 类似这种:C:\Users\yudian-it\Downloads
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @return 文件名
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
|
|
|
|
public String getFileNameFromPath(String path) {
|
|
|
|
|
return path.substring(path.lastIndexOf(File.separator) + 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取相对路径
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param absolutePath 绝对路径
|
|
|
|
|
* @return 相对路径
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
|
|
|
|
public String getRelativePath(String absolutePath) {
|
|
|
|
|
return absolutePath.substring(fileDir.length());
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-15 18:09:19 +08:00
|
|
|
|
/**
|
|
|
|
|
* 添加转换后PDF缓存
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param fileName pdf文件名
|
2020-12-25 22:47:30 +08:00
|
|
|
|
* @param value 缓存相对路径
|
2020-05-15 18:09:19 +08:00
|
|
|
|
*/
|
2020-12-25 22:47:30 +08:00
|
|
|
|
public void addConvertedFile(String fileName, String value) {
|
2019-04-08 17:50:13 +08:00
|
|
|
|
cacheService.putPDFCache(fileName, value);
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
|
|
|
|
|
2019-04-25 18:39:58 +08:00
|
|
|
|
/**
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* 添加转换后图片组缓存
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param pdfFilePath pdf文件绝对路径
|
2020-12-25 22:47:30 +08:00
|
|
|
|
* @param num 图片张数
|
2019-04-25 18:39:58 +08:00
|
|
|
|
*/
|
2020-12-25 22:47:30 +08:00
|
|
|
|
public void addConvertedPdfImage(String pdfFilePath, int num) {
|
2019-04-25 18:39:58 +08:00
|
|
|
|
cacheService.putPdfImageCache(pdfFilePath, num);
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-17 14:10:40 +08:00
|
|
|
|
/**
|
|
|
|
|
* 获取redis中压缩包内图片文件
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param fileKey fileKey
|
|
|
|
|
* @return 图片文件访问url列表
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
2020-12-25 22:47:30 +08:00
|
|
|
|
public List<String> getImgCache(String fileKey) {
|
2019-04-08 17:50:13 +08:00
|
|
|
|
return cacheService.getImgCache(fileKey);
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 设置redis中压缩包内图片文件
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param fileKey fileKey
|
2020-12-25 22:47:30 +08:00
|
|
|
|
* @param imgs 图片文件访问url列表
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
2020-12-25 22:47:30 +08:00
|
|
|
|
public void putImgCache(String fileKey, List<String> imgs) {
|
2019-04-08 17:50:13 +08:00
|
|
|
|
cacheService.putImgCache(fileKey, imgs);
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|
2020-12-25 22:47:30 +08:00
|
|
|
|
|
2018-01-17 14:10:40 +08:00
|
|
|
|
/**
|
|
|
|
|
* 对转换后的文件进行操作(改变编码方式)
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param outFilePath 文件绝对路径
|
2018-01-17 14:10:40 +08:00
|
|
|
|
*/
|
|
|
|
|
public void doActionConvertedFile(String outFilePath) {
|
2020-05-15 18:09:19 +08:00
|
|
|
|
StringBuilder sb = new StringBuilder();
|
2018-01-17 14:10:40 +08:00
|
|
|
|
try (InputStream inputStream = new FileInputStream(outFilePath);
|
2020-12-25 22:47:30 +08:00
|
|
|
|
BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, DEFAULT_CONVERTER_CHARSET))) {
|
2018-01-17 14:10:40 +08:00
|
|
|
|
String line;
|
2020-12-25 22:47:30 +08:00
|
|
|
|
while (null != (line = reader.readLine())) {
|
2018-01-17 14:10:40 +08:00
|
|
|
|
if (line.contains("charset=gb2312")) {
|
|
|
|
|
line = line.replace("charset=gb2312", "charset=utf-8");
|
|
|
|
|
}
|
|
|
|
|
sb.append(line);
|
|
|
|
|
}
|
|
|
|
|
// 添加sheet控制头
|
|
|
|
|
sb.append("<script src=\"js/jquery-3.0.0.min.js\" type=\"text/javascript\"></script>");
|
|
|
|
|
sb.append("<script src=\"js/excel.header.js\" type=\"text/javascript\"></script>");
|
2020-05-13 19:40:31 +08:00
|
|
|
|
sb.append("<link rel=\"stylesheet\" href=\"bootstrap/css/bootstrap.min.css\">");
|
2018-01-17 14:10:40 +08:00
|
|
|
|
} catch (IOException e) {
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
}
|
|
|
|
|
// 重新写入文件
|
2020-12-25 22:47:30 +08:00
|
|
|
|
try (FileOutputStream fos = new FileOutputStream(outFilePath);
|
|
|
|
|
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(fos, StandardCharsets.UTF_8))) {
|
2018-01-17 14:10:40 +08:00
|
|
|
|
writer.write(sb.toString());
|
|
|
|
|
} catch (IOException e) {
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-12-25 22:47:30 +08:00
|
|
|
|
|
2018-01-17 17:51:53 +08:00
|
|
|
|
/**
|
|
|
|
|
* 获取文件后缀
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param url url
|
|
|
|
|
* @return 文件后缀
|
2018-01-17 17:51:53 +08:00
|
|
|
|
*/
|
|
|
|
|
private String suffixFromUrl(String url) {
|
2020-05-15 18:09:19 +08:00
|
|
|
|
String nonPramStr = url.substring(0, url.contains("?") ? url.indexOf("?") : url.length());
|
2018-01-17 17:51:53 +08:00
|
|
|
|
String fileName = nonPramStr.substring(nonPramStr.lastIndexOf("/") + 1);
|
2019-06-17 14:21:16 +08:00
|
|
|
|
return suffixFromFileName(fileName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private String suffixFromFileName(String fileName) {
|
2020-05-15 18:09:19 +08:00
|
|
|
|
return fileName.substring(fileName.lastIndexOf(".") + 1);
|
2018-01-17 17:51:53 +08:00
|
|
|
|
}
|
|
|
|
|
|
2020-05-15 18:09:19 +08:00
|
|
|
|
/**
|
|
|
|
|
* 获取文件属性
|
2020-12-25 22:47:30 +08:00
|
|
|
|
*
|
2020-05-15 18:09:19 +08:00
|
|
|
|
* @param url url
|
|
|
|
|
* @return 文件属性
|
|
|
|
|
*/
|
2020-12-25 22:47:30 +08:00
|
|
|
|
public FileAttribute getFileAttribute(String url, HttpServletRequest req) {
|
|
|
|
|
FileAttribute attribute = new FileAttribute();
|
2019-06-17 14:21:16 +08:00
|
|
|
|
String suffix;
|
2020-12-26 00:56:48 +08:00
|
|
|
|
FileType type;
|
|
|
|
|
String fileName;
|
2020-12-27 01:43:50 +08:00
|
|
|
|
String fullFileName = WebUtils.getUrlParameterReg(url, "fullfilename");
|
2020-12-25 16:59:11 +08:00
|
|
|
|
if (StringUtils.hasText(fullFileName)) {
|
2020-12-26 00:56:48 +08:00
|
|
|
|
fileName = fullFileName;
|
2020-12-26 16:44:05 +08:00
|
|
|
|
type = this.typeFromFileName(fullFileName);
|
2020-12-25 22:47:30 +08:00
|
|
|
|
suffix = suffixFromFileName(fullFileName);
|
2019-06-17 14:21:16 +08:00
|
|
|
|
} else {
|
2020-12-26 00:56:48 +08:00
|
|
|
|
fileName = getFileNameFromURL(url);
|
|
|
|
|
type = typeFromUrl(url);
|
2019-06-17 14:21:16 +08:00
|
|
|
|
suffix = suffixFromUrl(url);
|
2018-01-17 17:51:53 +08:00
|
|
|
|
}
|
2020-12-26 00:56:48 +08:00
|
|
|
|
attribute.setType(type);
|
|
|
|
|
attribute.setName(fileName);
|
2020-12-25 22:47:30 +08:00
|
|
|
|
attribute.setSuffix(suffix);
|
2020-12-26 00:56:48 +08:00
|
|
|
|
attribute.setUrl(url);
|
2020-12-25 22:47:30 +08:00
|
|
|
|
if (req != null) {
|
2020-12-26 00:56:48 +08:00
|
|
|
|
String officePreviewType = req.getParameter("officePreviewType");
|
2020-12-26 19:13:50 +08:00
|
|
|
|
String fileKey = req.getParameter("fileKey");
|
|
|
|
|
if (StringUtils.hasText(officePreviewType)) {
|
2020-12-26 00:56:48 +08:00
|
|
|
|
attribute.setOfficePreviewType(officePreviewType);
|
|
|
|
|
}
|
2020-12-26 19:13:50 +08:00
|
|
|
|
if (StringUtils.hasText(fileKey)) {
|
2020-12-26 01:52:52 +08:00
|
|
|
|
attribute.setFileKey(fileKey);
|
|
|
|
|
}
|
2020-12-25 22:47:30 +08:00
|
|
|
|
}
|
|
|
|
|
return attribute;
|
2018-01-17 17:51:53 +08:00
|
|
|
|
}
|
2018-01-17 14:10:40 +08:00
|
|
|
|
}
|