mirror of
				https://gitee.com/kekingcn/file-online-preview.git
				synced 2025-10-25 02:09:09 +08:00 
			
		
		
		
	引入cpdetector解决文件编码识别问题
This commit is contained in:
		
							
								
								
									
										
											BIN
										
									
								
								server/lib/cpdetector-1.04.jar
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								server/lib/cpdetector-1.04.jar
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -193,6 +193,14 @@ | |||||||
|             <scope>system</scope> |             <scope>system</scope> | ||||||
|             <systemPath>${basedir}/lib/aspose-cad-19.9.jar</systemPath> |             <systemPath>${basedir}/lib/aspose-cad-19.9.jar</systemPath> | ||||||
|         </dependency> |         </dependency> | ||||||
|  |         <!-- 编码识别 --> | ||||||
|  |         <dependency> | ||||||
|  |             <groupId>cpdetector</groupId> | ||||||
|  |             <artifactId>cpdetector</artifactId> | ||||||
|  |             <version>1.04</version> | ||||||
|  |             <scope>system</scope> | ||||||
|  |             <systemPath>${basedir}/lib/cpdetector-1.04.jar</systemPath> | ||||||
|  |         </dependency> | ||||||
|     </dependencies> |     </dependencies> | ||||||
|     <build> |     <build> | ||||||
|         <resources> |         <resources> | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| package cn.keking.utils; | package cn.keking.service; | ||||||
| 
 | 
 | ||||||
| import cn.keking.config.ConfigConstants; | import cn.keking.config.ConfigConstants; | ||||||
| import cn.keking.model.FileType; | import cn.keking.model.FileType; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.utils.FileUtils; | ||||||
| import cn.keking.web.filter.BaseUrlFilter; | import cn.keking.web.filter.BaseUrlFilter; | ||||||
| import com.fasterxml.jackson.core.JsonProcessingException; | import com.fasterxml.jackson.core.JsonProcessingException; | ||||||
| import com.fasterxml.jackson.databind.ObjectMapper; | import com.fasterxml.jackson.databind.ObjectMapper; | ||||||
| @@ -26,22 +26,19 @@ import java.util.regex.Matcher; | |||||||
| import java.util.regex.Pattern; | import java.util.regex.Pattern; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * |  | ||||||
|  * @author yudian-it |  * @author yudian-it | ||||||
|  * @date 2017/11/27 |  * create 2017/11/27 | ||||||
|  */ |  */ | ||||||
| @Component | @Component | ||||||
| public class ZipReader { | public class CompressFileReader { | ||||||
|     static Pattern pattern = Pattern.compile("^\\d+"); |  | ||||||
| 
 |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |  | ||||||
| 
 | 
 | ||||||
|  |     private static final Pattern pattern = Pattern.compile("^\\d+"); | ||||||
|  |     private final FileHandlerService fileHandlerService; | ||||||
|     private final String fileDir = ConfigConstants.getFileDir(); |     private final String fileDir = ConfigConstants.getFileDir(); | ||||||
| 
 |  | ||||||
|     private final ExecutorService executors = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors()); |     private final ExecutorService executors = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors()); | ||||||
| 
 | 
 | ||||||
|     public ZipReader(FilePreviewCommonService filePreviewCommonService) { |     public CompressFileReader(FileHandlerService fileHandlerService) { | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public String readZipFile(String filePath, String fileKey) { |     public String readZipFile(String filePath, String fileKey) { | ||||||
| @@ -49,9 +46,9 @@ public class ZipReader { | |||||||
|         Map<String, FileNode> appender = new HashMap<>(); |         Map<String, FileNode> appender = new HashMap<>(); | ||||||
|         List<String> imgUrls = new LinkedList<>(); |         List<String> imgUrls = new LinkedList<>(); | ||||||
|         String baseUrl = BaseUrlFilter.getBaseUrl(); |         String baseUrl = BaseUrlFilter.getBaseUrl(); | ||||||
|         String archiveFileName = filePreviewCommonService.getFileNameFromPath(filePath); |         String archiveFileName = fileHandlerService.getFileNameFromPath(filePath); | ||||||
|         try { |         try { | ||||||
|             ZipFile zipFile = new ZipFile(filePath, filePreviewCommonService.getFileEncodeUTFGBK(filePath)); |             ZipFile zipFile = new ZipFile(filePath, FileUtils.getFileEncode(filePath)); | ||||||
|             Enumeration<ZipArchiveEntry> entries = zipFile.getEntries(); |             Enumeration<ZipArchiveEntry> entries = zipFile.getEntries(); | ||||||
|             // 排序 |             // 排序 | ||||||
|             entries = sortZipEntries(entries); |             entries = sortZipEntries(entries); | ||||||
| @@ -70,7 +67,7 @@ public class ZipReader { | |||||||
|                 } |                 } | ||||||
|                 String parentName = getLast2FileName(fullName, archiveSeparator, archiveFileName); |                 String parentName = getLast2FileName(fullName, archiveSeparator, archiveFileName); | ||||||
|                 parentName = (level - 1) + "_" + parentName; |                 parentName = (level - 1) + "_" + parentName; | ||||||
|                 FileType type= filePreviewCommonService.typeFromUrl(childName); |                 FileType type = fileHandlerService.typeFromUrl(childName); | ||||||
|                 if (type.equals(FileType.picture)) {//添加图片文件到图片列表 |                 if (type.equals(FileType.picture)) {//添加图片文件到图片列表 | ||||||
|                     imgUrls.add(baseUrl + childName); |                     imgUrls.add(baseUrl + childName); | ||||||
|                 } |                 } | ||||||
| @@ -80,7 +77,7 @@ public class ZipReader { | |||||||
|             } |             } | ||||||
|             // 开启新的线程处理文件解压 |             // 开启新的线程处理文件解压 | ||||||
|             executors.submit(new ZipExtractorWorker(entriesToBeExtracted, zipFile, filePath)); |             executors.submit(new ZipExtractorWorker(entriesToBeExtracted, zipFile, filePath)); | ||||||
|             filePreviewCommonService.putImgCache(fileKey,imgUrls); |             fileHandlerService.putImgCache(fileKey, imgUrls); | ||||||
|             return new ObjectMapper().writeValueAsString(appender.get("")); |             return new ObjectMapper().writeValueAsString(appender.get("")); | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
| @@ -102,10 +99,10 @@ public class ZipReader { | |||||||
|         List<String> imgUrls = new ArrayList<>(); |         List<String> imgUrls = new ArrayList<>(); | ||||||
|         String baseUrl = BaseUrlFilter.getBaseUrl(); |         String baseUrl = BaseUrlFilter.getBaseUrl(); | ||||||
|         try { |         try { | ||||||
|             Archive archive = new Archive(new FileInputStream(new File(filePath))); |             Archive archive = new Archive(new FileInputStream(filePath)); | ||||||
|             List<FileHeader> headers = archive.getFileHeaders(); |             List<FileHeader> headers = archive.getFileHeaders(); | ||||||
|             headers = sortedHeaders(headers); |             headers = sortedHeaders(headers); | ||||||
|             String archiveFileName = filePreviewCommonService.getFileNameFromPath(filePath); |             String archiveFileName = fileHandlerService.getFileNameFromPath(filePath); | ||||||
|             List<Map<String, FileHeader>> headersToBeExtracted = new ArrayList<>(); |             List<Map<String, FileHeader>> headersToBeExtracted = new ArrayList<>(); | ||||||
|             for (FileHeader header : headers) { |             for (FileHeader header : headers) { | ||||||
|                 String fullName; |                 String fullName; | ||||||
| @@ -123,7 +120,7 @@ public class ZipReader { | |||||||
|                     headersToBeExtracted.add(Collections.singletonMap(childName, header)); |                     headersToBeExtracted.add(Collections.singletonMap(childName, header)); | ||||||
|                 } |                 } | ||||||
|                 String parentName = getLast2FileName(fullName, "\\", archiveFileName); |                 String parentName = getLast2FileName(fullName, "\\", archiveFileName); | ||||||
|                 FileType type = filePreviewCommonService.typeFromUrl(childName); |                 FileType type = fileHandlerService.typeFromUrl(childName); | ||||||
|                 if (type.equals(FileType.picture)) {//添加图片文件到图片列表 |                 if (type.equals(FileType.picture)) {//添加图片文件到图片列表 | ||||||
|                     imgUrls.add(baseUrl + childName); |                     imgUrls.add(baseUrl + childName); | ||||||
|                 } |                 } | ||||||
| @@ -132,7 +129,7 @@ public class ZipReader { | |||||||
|                 appender.put(childName, node); |                 appender.put(childName, node); | ||||||
|             } |             } | ||||||
|             executors.submit(new RarExtractorWorker(headersToBeExtracted, archive, filePath)); |             executors.submit(new RarExtractorWorker(headersToBeExtracted, archive, filePath)); | ||||||
|             filePreviewCommonService.putImgCache(fileKey,imgUrls); |             fileHandlerService.putImgCache(fileKey, imgUrls); | ||||||
|             return new ObjectMapper().writeValueAsString(appender.get("")); |             return new ObjectMapper().writeValueAsString(appender.get("")); | ||||||
|         } catch (RarException | IOException e) { |         } catch (RarException | IOException e) { | ||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
| @@ -145,7 +142,7 @@ public class ZipReader { | |||||||
|         Map<String, FileNode> appender = new HashMap<>(); |         Map<String, FileNode> appender = new HashMap<>(); | ||||||
|         List<String> imgUrls = new ArrayList<>(); |         List<String> imgUrls = new ArrayList<>(); | ||||||
|         String baseUrl = BaseUrlFilter.getBaseUrl(); |         String baseUrl = BaseUrlFilter.getBaseUrl(); | ||||||
|         String archiveFileName = filePreviewCommonService.getFileNameFromPath(filePath); |         String archiveFileName = fileHandlerService.getFileNameFromPath(filePath); | ||||||
|         try { |         try { | ||||||
|             SevenZFile zipFile = new SevenZFile(new File(filePath)); |             SevenZFile zipFile = new SevenZFile(new File(filePath)); | ||||||
|             Iterable<SevenZArchiveEntry> entries = zipFile.getEntries(); |             Iterable<SevenZArchiveEntry> entries = zipFile.getEntries(); | ||||||
| @@ -166,7 +163,7 @@ public class ZipReader { | |||||||
|                 } |                 } | ||||||
|                 String parentName = getLast2FileName(fullName, archiveSeparator, archiveFileName); |                 String parentName = getLast2FileName(fullName, archiveSeparator, archiveFileName); | ||||||
|                 parentName = (level - 1) + "_" + parentName; |                 parentName = (level - 1) + "_" + parentName; | ||||||
|                 FileType type= filePreviewCommonService.typeFromUrl(childName); |                 FileType type = fileHandlerService.typeFromUrl(childName); | ||||||
|                 if (type.equals(FileType.picture)) {//添加图片文件到图片列表 |                 if (type.equals(FileType.picture)) {//添加图片文件到图片列表 | ||||||
|                     imgUrls.add(baseUrl + childName); |                     imgUrls.add(baseUrl + childName); | ||||||
|                 } |                 } | ||||||
| @@ -176,7 +173,7 @@ public class ZipReader { | |||||||
|             } |             } | ||||||
|             // 开启新的线程处理文件解压 |             // 开启新的线程处理文件解压 | ||||||
|             executors.submit(new SevenZExtractorWorker(entriesToBeExtracted, filePath)); |             executors.submit(new SevenZExtractorWorker(entriesToBeExtracted, filePath)); | ||||||
|             filePreviewCommonService.putImgCache(fileKey,imgUrls); |             fileHandlerService.putImgCache(fileKey, imgUrls); | ||||||
|             return new ObjectMapper().writeValueAsString(appender.get("")); |             return new ObjectMapper().writeValueAsString(appender.get("")); | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
| @@ -248,6 +245,7 @@ public class ZipReader { | |||||||
| 
 | 
 | ||||||
|     public static Comparator<FileNode> sortComparator = new Comparator<FileNode>() { |     public static Comparator<FileNode> sortComparator = new Comparator<FileNode>() { | ||||||
|         final Collator cmp = Collator.getInstance(Locale.US); |         final Collator cmp = Collator.getInstance(Locale.US); | ||||||
|  | 
 | ||||||
|         @Override |         @Override | ||||||
|         public int compare(FileNode o1, FileNode o2) { |         public int compare(FileNode o1, FileNode o2) { | ||||||
|             // 判断两个对比对象是否是开头包含数字,如果包含数字则获取数字并按数字真正大小进行排序 |             // 判断两个对比对象是否是开头包含数字,如果包含数字则获取数字并按数字真正大小进行排序 | ||||||
| @@ -287,6 +285,7 @@ public class ZipReader { | |||||||
|             this.childList = childList; |             this.childList = childList; | ||||||
|             this.directory = directory; |             this.directory = directory; | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|         public FileNode(String originName, String fileName, String parentFileName, List<FileNode> childList, boolean directory, String fileKey) { |         public FileNode(String originName, String fileName, String parentFileName, List<FileNode> childList, boolean directory, String fileKey) { | ||||||
|             this.originName = originName; |             this.originName = originName; | ||||||
|             this.fileName = fileName; |             this.fileName = fileName; | ||||||
| @@ -295,6 +294,7 @@ public class ZipReader { | |||||||
|             this.directory = directory; |             this.directory = directory; | ||||||
|             this.fileKey = fileKey; |             this.fileKey = fileKey; | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|         public String getFileKey() { |         public String getFileKey() { | ||||||
|             return fileKey; |             return fileKey; | ||||||
|         } |         } | ||||||
| @@ -382,9 +382,7 @@ public class ZipReader { | |||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 e.printStackTrace(); |                 e.printStackTrace(); | ||||||
|             } |             } | ||||||
|             if (new File(filePath).exists()) { |             FileUtils.deleteFileByPath(filePath); | ||||||
|                 new File(filePath).delete(); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void extractZipFile(String childName, InputStream zipFile) { |         private void extractZipFile(String childName, InputStream zipFile) { | ||||||
| @@ -441,10 +439,7 @@ public class ZipReader { | |||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 e.printStackTrace(); |                 e.printStackTrace(); | ||||||
|             } |             } | ||||||
| 
 |             FileUtils.deleteFileByPath(filePath); | ||||||
|             if (new File(filePath).exists()) { |  | ||||||
|                 new File(filePath).delete(); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @@ -473,9 +468,7 @@ public class ZipReader { | |||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 e.printStackTrace(); |                 e.printStackTrace(); | ||||||
|             } |             } | ||||||
|             if (new File(filePath).exists()) { |             FileUtils.deleteFileByPath(filePath); | ||||||
|                 new File(filePath).delete(); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void extractRarFile(String childName, FileHeader header, Archive archive) { |         private void extractRarFile(String childName, FileHeader header, Archive archive) { | ||||||
| @@ -21,18 +21,18 @@ public class FileConvertQueueTask { | |||||||
|     private final Logger logger = LoggerFactory.getLogger(getClass()); |     private final Logger logger = LoggerFactory.getLogger(getClass()); | ||||||
|     private final FilePreviewFactory previewFactory; |     private final FilePreviewFactory previewFactory; | ||||||
|     private final CacheService cacheService; |     private final CacheService cacheService; | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|     public FileConvertQueueTask(FilePreviewFactory previewFactory, CacheService cacheService, FilePreviewCommonService filePreviewCommonService) { |     public FileConvertQueueTask(FilePreviewFactory previewFactory, CacheService cacheService, FileHandlerService fileHandlerService) { | ||||||
|         this.previewFactory = previewFactory; |         this.previewFactory = previewFactory; | ||||||
|         this.cacheService = cacheService; |         this.cacheService = cacheService; | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @PostConstruct |     @PostConstruct | ||||||
|     public void startTask(){ |     public void startTask(){ | ||||||
|         ExecutorService executorService = Executors.newFixedThreadPool(1); |         ExecutorService executorService = Executors.newFixedThreadPool(1); | ||||||
|         executorService.submit(new ConvertTask(previewFactory, cacheService, filePreviewCommonService)); |         executorService.submit(new ConvertTask(previewFactory, cacheService, fileHandlerService)); | ||||||
|         logger.info("队列处理文件转换任务启动完成 "); |         logger.info("队列处理文件转换任务启动完成 "); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -41,14 +41,14 @@ public class FileConvertQueueTask { | |||||||
|         private final Logger logger = LoggerFactory.getLogger(ConvertTask.class); |         private final Logger logger = LoggerFactory.getLogger(ConvertTask.class); | ||||||
|         private final FilePreviewFactory previewFactory; |         private final FilePreviewFactory previewFactory; | ||||||
|         private final CacheService cacheService; |         private final CacheService cacheService; | ||||||
|         private final FilePreviewCommonService filePreviewCommonService; |         private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|         public ConvertTask(FilePreviewFactory previewFactory, |         public ConvertTask(FilePreviewFactory previewFactory, | ||||||
|                            CacheService cacheService, |                            CacheService cacheService, | ||||||
|                            FilePreviewCommonService filePreviewCommonService) { |                            FileHandlerService fileHandlerService) { | ||||||
|             this.previewFactory = previewFactory; |             this.previewFactory = previewFactory; | ||||||
|             this.cacheService = cacheService; |             this.cacheService = cacheService; | ||||||
|             this.filePreviewCommonService = filePreviewCommonService; |             this.fileHandlerService = fileHandlerService; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
| @@ -58,7 +58,7 @@ public class FileConvertQueueTask { | |||||||
|                 try { |                 try { | ||||||
|                     url = cacheService.takeQueueTask(); |                     url = cacheService.takeQueueTask(); | ||||||
|                     if(url != null){ |                     if(url != null){ | ||||||
|                         FileAttribute fileAttribute = filePreviewCommonService.getFileAttribute(url,null); |                         FileAttribute fileAttribute = fileHandlerService.getFileAttribute(url,null); | ||||||
|                         FileType fileType = fileAttribute.getType(); |                         FileType fileType = fileAttribute.getType(); | ||||||
|                         logger.info("正在处理预览转换任务,url:{},预览类型:{}", url, fileType); |                         logger.info("正在处理预览转换任务,url:{},预览类型:{}", url, fileType); | ||||||
|                         if(fileType.equals(FileType.compress) || fileType.equals(FileType.office) || fileType.equals(FileType.cad)) { |                         if(fileType.equals(FileType.compress) || fileType.equals(FileType.office) || fileType.equals(FileType.cad)) { | ||||||
|   | |||||||
| @@ -9,23 +9,23 @@ import org.springframework.util.StringUtils; | |||||||
| 
 | 
 | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
| import java.io.*; | import java.io.*; | ||||||
| import java.nio.charset.Charset; |  | ||||||
| import java.nio.charset.StandardCharsets; | import java.nio.charset.StandardCharsets; | ||||||
| import java.util.*; | import java.util.HashMap; | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.Map; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * @author yudian-it |  * @author yudian-it | ||||||
|  * @date 2017/11/13 |  * @date 2017/11/13 | ||||||
|  */ |  */ | ||||||
| @Component | @Component | ||||||
| public class FilePreviewCommonService { | public class FileHandlerService { | ||||||
| 
 | 
 | ||||||
|     private static final String DEFAULT_CONVERTER_CHARSET = System.getProperty("sun.jnu.encoding"); |     private static final String DEFAULT_CONVERTER_CHARSET = System.getProperty("sun.jnu.encoding"); | ||||||
| 
 |  | ||||||
|     private final String fileDir = ConfigConstants.getFileDir(); |     private final String fileDir = ConfigConstants.getFileDir(); | ||||||
|     private final CacheService cacheService; |     private final CacheService cacheService; | ||||||
| 
 | 
 | ||||||
|     public FilePreviewCommonService(CacheService cacheService) { |     public FileHandlerService(CacheService cacheService) { | ||||||
|         this.cacheService = cacheService; |         this.cacheService = cacheService; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @@ -141,31 +141,6 @@ public class FilePreviewCommonService { | |||||||
|         cacheService.putImgCache(fileKey, imgs); |         cacheService.putImgCache(fileKey, imgs); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * 判断文件编码格式 |  | ||||||
|      * |  | ||||||
|      * @param path 绝对路径 |  | ||||||
|      * @return 编码格式 |  | ||||||
|      */ |  | ||||||
|     public String getFileEncodeUTFGBK(String path) { |  | ||||||
|         String enc = Charset.forName("GBK").name(); |  | ||||||
|         File file = new File(path); |  | ||||||
|         InputStream in; |  | ||||||
|         try { |  | ||||||
|             in = new FileInputStream(file); |  | ||||||
|             byte[] b = new byte[3]; |  | ||||||
|             in.read(b); |  | ||||||
|             in.close(); |  | ||||||
|             if (b[0] == -17 && b[1] == -69 && b[2] == -65) { |  | ||||||
|                 enc = StandardCharsets.UTF_8.name(); |  | ||||||
|             } |  | ||||||
|         } catch (IOException e) { |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |  | ||||||
|         System.out.println("文件编码格式为:" + enc); |  | ||||||
|         return enc; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * 对转换后的文件进行操作(改变编码方式) |      * 对转换后的文件进行操作(改变编码方式) | ||||||
|      * |      * | ||||||
| @@ -1,6 +1,5 @@ | |||||||
| package cn.keking.service; | package cn.keking.service; | ||||||
|  |  | ||||||
| import cn.keking.config.ConfigConstants; |  | ||||||
| import cn.keking.model.FileAttribute; | import cn.keking.model.FileAttribute; | ||||||
| import org.springframework.ui.Model; | import org.springframework.ui.Model; | ||||||
|  |  | ||||||
| @@ -9,9 +8,5 @@ import org.springframework.ui.Model; | |||||||
|  * Content : |  * Content : | ||||||
|  */ |  */ | ||||||
| public interface FilePreview { | public interface FilePreview { | ||||||
|  |  | ||||||
|     String TEXT_TYPE = "textType"; |  | ||||||
|     String DEFAULT_TEXT_TYPE = "simText"; |  | ||||||
|  |  | ||||||
|     String filePreviewHandle(String url, Model model, FileAttribute fileAttribute); |     String filePreviewHandle(String url, Model model, FileAttribute fileAttribute); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -32,9 +32,9 @@ import java.util.Properties; | |||||||
|  */ |  */ | ||||||
| @Component | @Component | ||||||
| @Order(Ordered.HIGHEST_PRECEDENCE) | @Order(Ordered.HIGHEST_PRECEDENCE) | ||||||
| public class OfficeProcessManager { | public class OfficePluginManager { | ||||||
| 
 | 
 | ||||||
|     private final Logger logger = LoggerFactory.getLogger(OfficeProcessManager.class); |     private final Logger logger = LoggerFactory.getLogger(OfficePluginManager.class); | ||||||
| 
 | 
 | ||||||
|     private OfficeManager officeManager; |     private OfficeManager officeManager; | ||||||
| 
 | 
 | ||||||
| @@ -10,10 +10,10 @@ import java.io.File; | |||||||
|  */ |  */ | ||||||
| @Component | @Component | ||||||
| public class OfficeToPdfService { | public class OfficeToPdfService { | ||||||
|     private final OfficeProcessManager officeProcessManager; |     private final OfficePluginManager officePluginManager; | ||||||
|  |  | ||||||
|     public OfficeToPdfService(OfficeProcessManager officeProcessManager) { |     public OfficeToPdfService(OfficePluginManager officePluginManager) { | ||||||
|         this.officeProcessManager = officeProcessManager; |         this.officePluginManager = officePluginManager; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void openOfficeToPDF(String inputFilePath, String outputFilePath) { |     public void openOfficeToPDF(String inputFilePath, String outputFilePath) { | ||||||
| @@ -33,7 +33,7 @@ public class OfficeToPdfService { | |||||||
|  |  | ||||||
|  |  | ||||||
|     public void office2pdf(String inputFilePath, String outputFilePath) { |     public void office2pdf(String inputFilePath, String outputFilePath) { | ||||||
|         OfficeDocumentConverter converter = officeProcessManager.getDocumentConverter(); |         OfficeDocumentConverter converter = officePluginManager.getDocumentConverter(); | ||||||
|         if (null != inputFilePath) { |         if (null != inputFilePath) { | ||||||
|             File inputFile = new File(inputFilePath); |             File inputFile = new File(inputFilePath); | ||||||
|             // 判断目标文件路径是否为空 |             // 判断目标文件路径是否为空 | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import cn.keking.model.ReturnResponse; | |||||||
| import cn.keking.service.FilePreview; | import cn.keking.service.FilePreview; | ||||||
| import cn.keking.utils.CadUtils; | import cn.keking.utils.CadUtils; | ||||||
| import cn.keking.utils.DownloadUtils; | import cn.keking.utils.DownloadUtils; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import cn.keking.utils.PdfUtils; | import cn.keking.utils.PdfUtils; | ||||||
| import cn.keking.web.filter.BaseUrlFilter; | import cn.keking.web.filter.BaseUrlFilter; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @@ -22,7 +22,7 @@ import static cn.keking.service.impl.OfficeFilePreviewImpl.getPreviewType; | |||||||
| @Service | @Service | ||||||
| public class CadFilePreviewImpl implements FilePreview { | public class CadFilePreviewImpl implements FilePreview { | ||||||
|  |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|     private final DownloadUtils downloadUtils; |     private final DownloadUtils downloadUtils; | ||||||
|  |  | ||||||
| @@ -30,11 +30,11 @@ public class CadFilePreviewImpl implements FilePreview { | |||||||
|  |  | ||||||
|     private final PdfUtils pdfUtils; |     private final PdfUtils pdfUtils; | ||||||
|  |  | ||||||
|     public CadFilePreviewImpl(FilePreviewCommonService filePreviewCommonService, |     public CadFilePreviewImpl(FileHandlerService fileHandlerService, | ||||||
|                               DownloadUtils downloadUtils, |                               DownloadUtils downloadUtils, | ||||||
|                               CadUtils cadUtils, |                               CadUtils cadUtils, | ||||||
|                               PdfUtils pdfUtils) { |                               PdfUtils pdfUtils) { | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|         this.downloadUtils = downloadUtils; |         this.downloadUtils = downloadUtils; | ||||||
|         this.cadUtils = cadUtils; |         this.cadUtils = cadUtils; | ||||||
|         this.pdfUtils = pdfUtils; |         this.pdfUtils = pdfUtils; | ||||||
| @@ -56,7 +56,7 @@ public class CadFilePreviewImpl implements FilePreview { | |||||||
|         String pdfName = fileName.substring(0, fileName.lastIndexOf(".") + 1) + "pdf"; |         String pdfName = fileName.substring(0, fileName.lastIndexOf(".") + 1) + "pdf"; | ||||||
|         String outFilePath = FILE_DIR + pdfName; |         String outFilePath = FILE_DIR + pdfName; | ||||||
|         // 判断之前是否已转换过,如果转换过,直接返回,否则执行转换 |         // 判断之前是否已转换过,如果转换过,直接返回,否则执行转换 | ||||||
|         if (!filePreviewCommonService.listConvertedFiles().containsKey(pdfName) || !ConfigConstants.isCacheEnabled()) { |         if (!fileHandlerService.listConvertedFiles().containsKey(pdfName) || !ConfigConstants.isCacheEnabled()) { | ||||||
|             String filePath; |             String filePath; | ||||||
|             ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, null); |             ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, null); | ||||||
|             if (0 != response.getCode()) { |             if (0 != response.getCode()) { | ||||||
| @@ -74,7 +74,7 @@ public class CadFilePreviewImpl implements FilePreview { | |||||||
|                 } |                 } | ||||||
|                 if (ConfigConstants.isCacheEnabled()) { |                 if (ConfigConstants.isCacheEnabled()) { | ||||||
|                     // 加入缓存 |                     // 加入缓存 | ||||||
|                     filePreviewCommonService.addConvertedFile(pdfName, filePreviewCommonService.getRelativePath(outFilePath)); |                     fileHandlerService.addConvertedFile(pdfName, fileHandlerService.getRelativePath(outFilePath)); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -5,8 +5,8 @@ import cn.keking.model.FileAttribute; | |||||||
| import cn.keking.model.ReturnResponse; | import cn.keking.model.ReturnResponse; | ||||||
| import cn.keking.service.FilePreview; | import cn.keking.service.FilePreview; | ||||||
| import cn.keking.utils.DownloadUtils; | import cn.keking.utils.DownloadUtils; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import cn.keking.utils.ZipReader; | import cn.keking.service.CompressFileReader; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.ui.Model; | import org.springframework.ui.Model; | ||||||
| import org.springframework.util.StringUtils; | import org.springframework.util.StringUtils; | ||||||
| @@ -18,18 +18,14 @@ import org.springframework.util.StringUtils; | |||||||
| @Service | @Service | ||||||
| public class CompressFilePreviewImpl implements FilePreview { | public class CompressFilePreviewImpl implements FilePreview { | ||||||
|  |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|     private final DownloadUtils downloadUtils; |     private final DownloadUtils downloadUtils; | ||||||
|  |     private final CompressFileReader compressFileReader; | ||||||
|  |  | ||||||
|     private final ZipReader zipReader; |     public CompressFilePreviewImpl(FileHandlerService fileHandlerService, DownloadUtils downloadUtils, CompressFileReader compressFileReader) { | ||||||
|  |         this.fileHandlerService = fileHandlerService; | ||||||
|     public CompressFilePreviewImpl(FilePreviewCommonService filePreviewCommonService, |  | ||||||
|                                    DownloadUtils downloadUtils, |  | ||||||
|                                    ZipReader zipReader) { |  | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |  | ||||||
|         this.downloadUtils = downloadUtils; |         this.downloadUtils = downloadUtils; | ||||||
|         this.zipReader = zipReader; |         this.compressFileReader = compressFileReader; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -38,7 +34,7 @@ public class CompressFilePreviewImpl implements FilePreview { | |||||||
|         String suffix=fileAttribute.getSuffix(); |         String suffix=fileAttribute.getSuffix(); | ||||||
|         String fileTree = null; |         String fileTree = null; | ||||||
|         // 判断文件名是否存在(redis缓存读取) |         // 判断文件名是否存在(redis缓存读取) | ||||||
|         if (!StringUtils.hasText(filePreviewCommonService.getConvertedFile(fileName))  || !ConfigConstants.isCacheEnabled()) { |         if (!StringUtils.hasText(fileHandlerService.getConvertedFile(fileName))  || !ConfigConstants.isCacheEnabled()) { | ||||||
|             ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, fileName); |             ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, fileName); | ||||||
|             if (0 != response.getCode()) { |             if (0 != response.getCode()) { | ||||||
|                 model.addAttribute("fileType", suffix); |                 model.addAttribute("fileType", suffix); | ||||||
| @@ -47,17 +43,17 @@ public class CompressFilePreviewImpl implements FilePreview { | |||||||
|             } |             } | ||||||
|             String filePath = response.getContent(); |             String filePath = response.getContent(); | ||||||
|             if ("zip".equalsIgnoreCase(suffix) || "jar".equalsIgnoreCase(suffix) || "gzip".equalsIgnoreCase(suffix)) { |             if ("zip".equalsIgnoreCase(suffix) || "jar".equalsIgnoreCase(suffix) || "gzip".equalsIgnoreCase(suffix)) { | ||||||
|                 fileTree = zipReader.readZipFile(filePath, fileName); |                 fileTree = compressFileReader.readZipFile(filePath, fileName); | ||||||
|             } else if ("rar".equalsIgnoreCase(suffix)) { |             } else if ("rar".equalsIgnoreCase(suffix)) { | ||||||
|                 fileTree = zipReader.unRar(filePath, fileName); |                 fileTree = compressFileReader.unRar(filePath, fileName); | ||||||
|             } else if ("7z".equalsIgnoreCase(suffix)) { |             } else if ("7z".equalsIgnoreCase(suffix)) { | ||||||
|                 fileTree = zipReader.read7zFile(filePath, fileName); |                 fileTree = compressFileReader.read7zFile(filePath, fileName); | ||||||
|             } |             } | ||||||
|             if (fileTree != null && !"null".equals(fileTree) && ConfigConstants.isCacheEnabled()) { |             if (fileTree != null && !"null".equals(fileTree) && ConfigConstants.isCacheEnabled()) { | ||||||
|                 filePreviewCommonService.addConvertedFile(fileName, fileTree); |                 fileHandlerService.addConvertedFile(fileName, fileTree); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             fileTree = filePreviewCommonService.getConvertedFile(fileName); |             fileTree = fileHandlerService.getConvertedFile(fileName); | ||||||
|         } |         } | ||||||
|         if (fileTree != null && !"null".equals(fileTree)) { |         if (fileTree != null && !"null".equals(fileTree)) { | ||||||
|             model.addAttribute("fileTree", fileTree); |             model.addAttribute("fileTree", fileTree); | ||||||
|   | |||||||
| @@ -5,6 +5,8 @@ import cn.keking.service.FilePreview; | |||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.ui.Model; | import org.springframework.ui.Model; | ||||||
|  |  | ||||||
|  | import static com.sun.glass.ui.Clipboard.TEXT_TYPE; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @author kl (http://kailing.pub) |  * @author kl (http://kailing.pub) | ||||||
|  * @since 2020/12/25 |  * @since 2020/12/25 | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import cn.keking.model.FileAttribute; | |||||||
| import cn.keking.model.ReturnResponse; | import cn.keking.model.ReturnResponse; | ||||||
| import cn.keking.service.FilePreview; | import cn.keking.service.FilePreview; | ||||||
| import cn.keking.utils.DownloadUtils; | import cn.keking.utils.DownloadUtils; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import cn.keking.web.filter.BaseUrlFilter; | import cn.keking.web.filter.BaseUrlFilter; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.ui.Model; | import org.springframework.ui.Model; | ||||||
| @@ -19,12 +19,12 @@ public class MediaFilePreviewImpl implements FilePreview { | |||||||
|  |  | ||||||
|     private final DownloadUtils downloadUtils; |     private final DownloadUtils downloadUtils; | ||||||
|  |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|     public MediaFilePreviewImpl(DownloadUtils downloadUtils, |     public MediaFilePreviewImpl(DownloadUtils downloadUtils, | ||||||
|                                 FilePreviewCommonService filePreviewCommonService) { |                                 FileHandlerService fileHandlerService) { | ||||||
|         this.downloadUtils = downloadUtils; |         this.downloadUtils = downloadUtils; | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -37,7 +37,7 @@ public class MediaFilePreviewImpl implements FilePreview { | |||||||
|                 model.addAttribute("msg", response.getMsg()); |                 model.addAttribute("msg", response.getMsg()); | ||||||
|                 return "fileNotSupported"; |                 return "fileNotSupported"; | ||||||
|             } else { |             } else { | ||||||
|                 model.addAttribute("mediaUrl", BaseUrlFilter.getBaseUrl() + filePreviewCommonService.getRelativePath(response.getContent())); |                 model.addAttribute("mediaUrl", BaseUrlFilter.getBaseUrl() + fileHandlerService.getRelativePath(response.getContent())); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             model.addAttribute("mediaUrl", url); |             model.addAttribute("mediaUrl", url); | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import cn.keking.model.FileAttribute; | |||||||
| import cn.keking.model.ReturnResponse; | import cn.keking.model.ReturnResponse; | ||||||
| import cn.keking.service.FilePreview; | import cn.keking.service.FilePreview; | ||||||
| import cn.keking.utils.DownloadUtils; | import cn.keking.utils.DownloadUtils; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import cn.keking.service.OfficeToPdfService; | import cn.keking.service.OfficeToPdfService; | ||||||
| import cn.keking.utils.PdfUtils; | import cn.keking.utils.PdfUtils; | ||||||
| import cn.keking.web.filter.BaseUrlFilter; | import cn.keking.web.filter.BaseUrlFilter; | ||||||
| @@ -22,13 +22,13 @@ import java.util.List; | |||||||
| @Service | @Service | ||||||
| public class OfficeFilePreviewImpl implements FilePreview { | public class OfficeFilePreviewImpl implements FilePreview { | ||||||
|  |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|     private final PdfUtils pdfUtils; |     private final PdfUtils pdfUtils; | ||||||
|     private final DownloadUtils downloadUtils; |     private final DownloadUtils downloadUtils; | ||||||
|     private final OfficeToPdfService officeToPdfService; |     private final OfficeToPdfService officeToPdfService; | ||||||
|  |  | ||||||
|     public OfficeFilePreviewImpl(FilePreviewCommonService filePreviewCommonService, PdfUtils pdfUtils, DownloadUtils downloadUtils, OfficeToPdfService officeToPdfService) { |     public OfficeFilePreviewImpl(FileHandlerService fileHandlerService, PdfUtils pdfUtils, DownloadUtils downloadUtils, OfficeToPdfService officeToPdfService) { | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|         this.pdfUtils = pdfUtils; |         this.pdfUtils = pdfUtils; | ||||||
|         this.downloadUtils = downloadUtils; |         this.downloadUtils = downloadUtils; | ||||||
|         this.officeToPdfService = officeToPdfService; |         this.officeToPdfService = officeToPdfService; | ||||||
| @@ -49,7 +49,7 @@ public class OfficeFilePreviewImpl implements FilePreview { | |||||||
|         String pdfName = fileName.substring(0, fileName.lastIndexOf(".") + 1) + (isHtml ? "html" : "pdf"); |         String pdfName = fileName.substring(0, fileName.lastIndexOf(".") + 1) + (isHtml ? "html" : "pdf"); | ||||||
|         String outFilePath = FILE_DIR + pdfName; |         String outFilePath = FILE_DIR + pdfName; | ||||||
|         // 判断之前是否已转换过,如果转换过,直接返回,否则执行转换 |         // 判断之前是否已转换过,如果转换过,直接返回,否则执行转换 | ||||||
|         if (!filePreviewCommonService.listConvertedFiles().containsKey(pdfName) || !ConfigConstants.isCacheEnabled()) { |         if (!fileHandlerService.listConvertedFiles().containsKey(pdfName) || !ConfigConstants.isCacheEnabled()) { | ||||||
|             String filePath; |             String filePath; | ||||||
|             ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, null); |             ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, null); | ||||||
|             if (0 != response.getCode()) { |             if (0 != response.getCode()) { | ||||||
| @@ -62,11 +62,11 @@ public class OfficeFilePreviewImpl implements FilePreview { | |||||||
|                 officeToPdfService.openOfficeToPDF(filePath, outFilePath); |                 officeToPdfService.openOfficeToPDF(filePath, outFilePath); | ||||||
|                 if (isHtml) { |                 if (isHtml) { | ||||||
|                     // 对转换后的文件进行操作(改变编码方式) |                     // 对转换后的文件进行操作(改变编码方式) | ||||||
|                     filePreviewCommonService.doActionConvertedFile(outFilePath); |                     fileHandlerService.doActionConvertedFile(outFilePath); | ||||||
|                 } |                 } | ||||||
|                 if (ConfigConstants.isCacheEnabled()) { |                 if (ConfigConstants.isCacheEnabled()) { | ||||||
|                     // 加入缓存 |                     // 加入缓存 | ||||||
|                     filePreviewCommonService.addConvertedFile(pdfName, filePreviewCommonService.getRelativePath(outFilePath)); |                     fileHandlerService.addConvertedFile(pdfName, fileHandlerService.getRelativePath(outFilePath)); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import cn.keking.model.FileAttribute; | |||||||
| import cn.keking.model.ReturnResponse; | import cn.keking.model.ReturnResponse; | ||||||
| import cn.keking.service.FilePreview; | import cn.keking.service.FilePreview; | ||||||
| import cn.keking.utils.DownloadUtils; | import cn.keking.utils.DownloadUtils; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import cn.keking.utils.PdfUtils; | import cn.keking.utils.PdfUtils; | ||||||
| import cn.keking.web.filter.BaseUrlFilter; | import cn.keking.web.filter.BaseUrlFilter; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @@ -20,7 +20,7 @@ import java.util.List; | |||||||
| @Service | @Service | ||||||
| public class PdfFilePreviewImpl implements FilePreview { | public class PdfFilePreviewImpl implements FilePreview { | ||||||
|  |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|     private final PdfUtils pdfUtils; |     private final PdfUtils pdfUtils; | ||||||
|  |  | ||||||
| @@ -28,10 +28,10 @@ public class PdfFilePreviewImpl implements FilePreview { | |||||||
|  |  | ||||||
|     private static final String FILE_DIR = ConfigConstants.getFileDir(); |     private static final String FILE_DIR = ConfigConstants.getFileDir(); | ||||||
|  |  | ||||||
|     public PdfFilePreviewImpl(FilePreviewCommonService filePreviewCommonService, |     public PdfFilePreviewImpl(FileHandlerService fileHandlerService, | ||||||
|                               PdfUtils pdfUtils, |                               PdfUtils pdfUtils, | ||||||
|                               DownloadUtils downloadUtils) { |                               DownloadUtils downloadUtils) { | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|         this.pdfUtils = pdfUtils; |         this.pdfUtils = pdfUtils; | ||||||
|         this.downloadUtils = downloadUtils; |         this.downloadUtils = downloadUtils; | ||||||
|     } |     } | ||||||
| @@ -46,7 +46,7 @@ public class PdfFilePreviewImpl implements FilePreview { | |||||||
|         String outFilePath = FILE_DIR + pdfName; |         String outFilePath = FILE_DIR + pdfName; | ||||||
|         if (OfficeFilePreviewImpl.OFFICE_PREVIEW_TYPE_IMAGE.equals(officePreviewType) || OfficeFilePreviewImpl.OFFICE_PREVIEW_TYPE_ALL_IMAGES.equals(officePreviewType)) { |         if (OfficeFilePreviewImpl.OFFICE_PREVIEW_TYPE_IMAGE.equals(officePreviewType) || OfficeFilePreviewImpl.OFFICE_PREVIEW_TYPE_ALL_IMAGES.equals(officePreviewType)) { | ||||||
|             //当文件不存在时,就去下载 |             //当文件不存在时,就去下载 | ||||||
|             if (!filePreviewCommonService.listConvertedFiles().containsKey(pdfName) || !ConfigConstants.isCacheEnabled()) { |             if (!fileHandlerService.listConvertedFiles().containsKey(pdfName) || !ConfigConstants.isCacheEnabled()) { | ||||||
|                 ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, fileName); |                 ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, fileName); | ||||||
|                 if (0 != response.getCode()) { |                 if (0 != response.getCode()) { | ||||||
|                     model.addAttribute("fileType", suffix); |                     model.addAttribute("fileType", suffix); | ||||||
| @@ -56,7 +56,7 @@ public class PdfFilePreviewImpl implements FilePreview { | |||||||
|                 outFilePath = response.getContent(); |                 outFilePath = response.getContent(); | ||||||
|                 if (ConfigConstants.isCacheEnabled()) { |                 if (ConfigConstants.isCacheEnabled()) { | ||||||
|                     // 加入缓存 |                     // 加入缓存 | ||||||
|                     filePreviewCommonService.addConvertedFile(pdfName, filePreviewCommonService.getRelativePath(outFilePath)); |                     fileHandlerService.addConvertedFile(pdfName, fileHandlerService.getRelativePath(outFilePath)); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             List<String> imageUrls = pdfUtils.pdf2jpg(outFilePath, pdfName, baseUrl); |             List<String> imageUrls = pdfUtils.pdf2jpg(outFilePath, pdfName, baseUrl); | ||||||
| @@ -75,17 +75,17 @@ public class PdfFilePreviewImpl implements FilePreview { | |||||||
|         } else { |         } else { | ||||||
|             // 不是http开头,浏览器不能直接访问,需下载到本地 |             // 不是http开头,浏览器不能直接访问,需下载到本地 | ||||||
|             if (url != null && !url.toLowerCase().startsWith("http")) { |             if (url != null && !url.toLowerCase().startsWith("http")) { | ||||||
|                 if (!filePreviewCommonService.listConvertedFiles().containsKey(pdfName) || !ConfigConstants.isCacheEnabled()) { |                 if (!fileHandlerService.listConvertedFiles().containsKey(pdfName) || !ConfigConstants.isCacheEnabled()) { | ||||||
|                     ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, pdfName); |                     ReturnResponse<String> response = downloadUtils.downLoad(fileAttribute, pdfName); | ||||||
|                     if (0 != response.getCode()) { |                     if (0 != response.getCode()) { | ||||||
|                         model.addAttribute("fileType", suffix); |                         model.addAttribute("fileType", suffix); | ||||||
|                         model.addAttribute("msg", response.getMsg()); |                         model.addAttribute("msg", response.getMsg()); | ||||||
|                         return "fileNotSupported"; |                         return "fileNotSupported"; | ||||||
|                     } |                     } | ||||||
|                     model.addAttribute("pdfUrl", filePreviewCommonService.getRelativePath(response.getContent())); |                     model.addAttribute("pdfUrl", fileHandlerService.getRelativePath(response.getContent())); | ||||||
|                     if (ConfigConstants.isCacheEnabled()) { |                     if (ConfigConstants.isCacheEnabled()) { | ||||||
|                         // 加入缓存 |                         // 加入缓存 | ||||||
|                         filePreviewCommonService.addConvertedFile(pdfName, filePreviewCommonService.getRelativePath(outFilePath)); |                         fileHandlerService.addConvertedFile(pdfName, fileHandlerService.getRelativePath(outFilePath)); | ||||||
|                     } |                     } | ||||||
|                 } else { |                 } else { | ||||||
|                     model.addAttribute("pdfUrl", pdfName); |                     model.addAttribute("pdfUrl", pdfName); | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ import cn.keking.model.FileAttribute; | |||||||
| import cn.keking.model.ReturnResponse; | import cn.keking.model.ReturnResponse; | ||||||
| import cn.keking.service.FilePreview; | import cn.keking.service.FilePreview; | ||||||
| import cn.keking.utils.DownloadUtils; | import cn.keking.utils.DownloadUtils; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.ui.Model; | import org.springframework.ui.Model; | ||||||
| import org.springframework.util.CollectionUtils; | import org.springframework.util.CollectionUtils; | ||||||
| @@ -18,13 +18,13 @@ import java.util.List; | |||||||
| @Service | @Service | ||||||
| public class PictureFilePreviewImpl implements FilePreview { | public class PictureFilePreviewImpl implements FilePreview { | ||||||
|  |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|     private final DownloadUtils downloadUtils; |     private final DownloadUtils downloadUtils; | ||||||
|  |  | ||||||
|     public PictureFilePreviewImpl(FilePreviewCommonService filePreviewCommonService, |     public PictureFilePreviewImpl(FileHandlerService fileHandlerService, | ||||||
|                                   DownloadUtils downloadUtils) { |                                   DownloadUtils downloadUtils) { | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|         this.downloadUtils = downloadUtils; |         this.downloadUtils = downloadUtils; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -33,7 +33,7 @@ public class PictureFilePreviewImpl implements FilePreview { | |||||||
|         List<String> imgUrls = new ArrayList<>(); |         List<String> imgUrls = new ArrayList<>(); | ||||||
|         imgUrls.add(url); |         imgUrls.add(url); | ||||||
|         String fileKey = fileAttribute.getFileKey(); |         String fileKey = fileAttribute.getFileKey(); | ||||||
|         List<String> zipImgUrls = filePreviewCommonService.getImgCache(fileKey); |         List<String> zipImgUrls = fileHandlerService.getImgCache(fileKey); | ||||||
|         if (!CollectionUtils.isEmpty(zipImgUrls)) { |         if (!CollectionUtils.isEmpty(zipImgUrls)) { | ||||||
|             imgUrls.addAll(zipImgUrls); |             imgUrls.addAll(zipImgUrls); | ||||||
|         } |         } | ||||||
| @@ -45,7 +45,7 @@ public class PictureFilePreviewImpl implements FilePreview { | |||||||
|                 model.addAttribute("msg", response.getMsg()); |                 model.addAttribute("msg", response.getMsg()); | ||||||
|                 return "fileNotSupported"; |                 return "fileNotSupported"; | ||||||
|             } else { |             } else { | ||||||
|                 String file = filePreviewCommonService.getRelativePath(response.getContent()); |                 String file = fileHandlerService.getRelativePath(response.getContent()); | ||||||
|                 imgUrls.clear(); |                 imgUrls.clear(); | ||||||
|                 imgUrls.add(file); |                 imgUrls.add(file); | ||||||
|                 model.addAttribute("imgurls", imgUrls); |                 model.addAttribute("imgurls", imgUrls); | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| package cn.keking.service.impl; | package cn.keking.service.impl; | ||||||
|  |  | ||||||
| import cn.keking.model.FileAttribute; | import cn.keking.model.FileAttribute; | ||||||
| import cn.keking.model.FileType; |  | ||||||
| import cn.keking.model.ReturnResponse; | import cn.keking.model.ReturnResponse; | ||||||
| import cn.keking.service.FilePreview; | import cn.keking.service.FilePreview; | ||||||
| import cn.keking.utils.DownloadUtils; | import cn.keking.utils.DownloadUtils; | ||||||
| @@ -13,7 +12,6 @@ import org.springframework.util.Base64Utils; | |||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.nio.charset.StandardCharsets; | import java.nio.charset.StandardCharsets; | ||||||
| import java.nio.file.Files; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Created by kl on 2018/1/17. |  * Created by kl on 2018/1/17. | ||||||
| @@ -22,8 +20,10 @@ import java.nio.file.Files; | |||||||
| @Service | @Service | ||||||
| public class SimTextFilePreviewImpl implements FilePreview { | public class SimTextFilePreviewImpl implements FilePreview { | ||||||
|  |  | ||||||
|     private final DownloadUtils downloadUtils; |     public static final String TEXT_TYPE = "textType"; | ||||||
|  |     public static final String DEFAULT_TEXT_TYPE = "simText"; | ||||||
|  |  | ||||||
|  |     private final DownloadUtils downloadUtils; | ||||||
|  |  | ||||||
|     public SimTextFilePreviewImpl(DownloadUtils downloadUtils) { |     public SimTextFilePreviewImpl(DownloadUtils downloadUtils) { | ||||||
|         this.downloadUtils = downloadUtils; |         this.downloadUtils = downloadUtils; | ||||||
|   | |||||||
| @@ -5,6 +5,8 @@ import cn.keking.service.FilePreview; | |||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.ui.Model; | import org.springframework.ui.Model; | ||||||
|  |  | ||||||
|  | import static com.sun.glass.ui.Clipboard.TEXT_TYPE; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @author kl (http://kailing.pub) |  * @author kl (http://kailing.pub) | ||||||
|  * @since 2020/12/25 |  * @since 2020/12/25 | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import cn.keking.hutool.URLUtil; | |||||||
| import cn.keking.model.FileAttribute; | import cn.keking.model.FileAttribute; | ||||||
| import cn.keking.model.FileType; | import cn.keking.model.FileType; | ||||||
| import cn.keking.model.ReturnResponse; | import cn.keking.model.ReturnResponse; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
| @@ -21,20 +21,18 @@ import java.util.UUID; | |||||||
| @Component | @Component | ||||||
| public class DownloadUtils { | public class DownloadUtils { | ||||||
|  |  | ||||||
|     private final Logger logger = LoggerFactory.getLogger(DownloadUtils.class); |     private final static Logger logger = LoggerFactory.getLogger(DownloadUtils.class); | ||||||
|  |  | ||||||
|     private final String fileDir = ConfigConstants.getFileDir(); |     private final String fileDir = ConfigConstants.getFileDir(); | ||||||
|  |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |  | ||||||
|  |  | ||||||
|     public DownloadUtils(FilePreviewCommonService filePreviewCommonService) { |  | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private static final String URL_PARAM_FTP_USERNAME = "ftp.username"; |     private static final String URL_PARAM_FTP_USERNAME = "ftp.username"; | ||||||
|     private static final String URL_PARAM_FTP_PASSWORD = "ftp.password"; |     private static final String URL_PARAM_FTP_PASSWORD = "ftp.password"; | ||||||
|     private static final String URL_PARAM_FTP_CONTROL_ENCODING = "ftp.control.encoding"; |     private static final String URL_PARAM_FTP_CONTROL_ENCODING = "ftp.control.encoding"; | ||||||
|  |  | ||||||
|  |     private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|  |     public DownloadUtils(FileHandlerService fileHandlerService) { | ||||||
|  |         this.fileHandlerService = fileHandlerService; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @param fileAttribute fileAttribute |      * @param fileAttribute fileAttribute | ||||||
|      * @param fileName      文件名 |      * @param fileName      文件名 | ||||||
| @@ -52,8 +50,8 @@ public class DownloadUtils { | |||||||
|         } |         } | ||||||
|         String realPath = fileDir + fileName; |         String realPath = fileDir + fileName; | ||||||
|         File dirFile = new File(fileDir); |         File dirFile = new File(fileDir); | ||||||
|         if (!dirFile.exists()) { |         if (!dirFile.exists() && !dirFile.mkdirs()) { | ||||||
|             dirFile.mkdirs(); |             logger.error("创建目录【{}】失败,可能是权限不够,请检查", fileDir); | ||||||
|         } |         } | ||||||
|         try { |         try { | ||||||
|             URL url = new URL(urlStr); |             URL url = new URL(urlStr); | ||||||
| @@ -62,9 +60,9 @@ public class DownloadUtils { | |||||||
|                 OutputStream os = new FileOutputStream(realPath); |                 OutputStream os = new FileOutputStream(realPath); | ||||||
|                 saveBytesToOutStream(bytes, os); |                 saveBytesToOutStream(bytes, os); | ||||||
|             } else if (url.getProtocol() != null && "ftp".equalsIgnoreCase(url.getProtocol())) { |             } else if (url.getProtocol() != null && "ftp".equalsIgnoreCase(url.getProtocol())) { | ||||||
|                 String ftpUsername = filePreviewCommonService.getUrlParameterReg(fileAttribute.getUrl(), URL_PARAM_FTP_USERNAME); |                 String ftpUsername = fileHandlerService.getUrlParameterReg(fileAttribute.getUrl(), URL_PARAM_FTP_USERNAME); | ||||||
|                 String ftpPassword = filePreviewCommonService.getUrlParameterReg(fileAttribute.getUrl(), URL_PARAM_FTP_PASSWORD); |                 String ftpPassword = fileHandlerService.getUrlParameterReg(fileAttribute.getUrl(), URL_PARAM_FTP_PASSWORD); | ||||||
|                 String ftpControlEncoding = filePreviewCommonService.getUrlParameterReg(fileAttribute.getUrl(), URL_PARAM_FTP_CONTROL_ENCODING); |                 String ftpControlEncoding = fileHandlerService.getUrlParameterReg(fileAttribute.getUrl(), URL_PARAM_FTP_CONTROL_ENCODING); | ||||||
|                 FtpUtils.download(fileAttribute.getUrl(), realPath, ftpUsername, ftpPassword, ftpControlEncoding); |                 FtpUtils.download(fileAttribute.getUrl(), realPath, ftpUsername, ftpPassword, ftpControlEncoding); | ||||||
|             } else { |             } else { | ||||||
|                 response.setCode(1); |                 response.setCode(1); | ||||||
| @@ -74,7 +72,7 @@ public class DownloadUtils { | |||||||
|             response.setContent(realPath); |             response.setContent(realPath); | ||||||
|             response.setMsg(fileName); |             response.setMsg(fileName); | ||||||
|             if (FileType.simText.equals(fileAttribute.getType())) { |             if (FileType.simText.equals(fileAttribute.getType())) { | ||||||
|                 convertTextPlainFileCharsetToUtf8(realPath); |                 this.convertTextPlainFileCharsetToUtf8(realPath); | ||||||
|             } |             } | ||||||
|             return response; |             return response; | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
| @@ -92,17 +90,15 @@ public class DownloadUtils { | |||||||
|  |  | ||||||
|     public byte[] getBytesFromUrl(String urlStr) throws IOException { |     public byte[] getBytesFromUrl(String urlStr) throws IOException { | ||||||
|         InputStream is = getInputStreamFromUrl(urlStr); |         InputStream is = getInputStreamFromUrl(urlStr); | ||||||
|         if (is != null) { |         if (is == null) { | ||||||
|             return getBytesFromStream(is); |  | ||||||
|         } else { |  | ||||||
|             urlStr = URLUtil.normalize(urlStr, true, true); |             urlStr = URLUtil.normalize(urlStr, true, true); | ||||||
|             is = getInputStreamFromUrl(urlStr); |             is = getInputStreamFromUrl(urlStr); | ||||||
|             if (is == null) { |             if (is == null) { | ||||||
|                 logger.error("文件下载异常:url:{}", urlStr); |                 logger.error("文件下载异常:url:{}", urlStr); | ||||||
|                 throw new IOException("文件下载异常:url:" + urlStr); |                 throw new IOException("文件下载异常:url:" + urlStr); | ||||||
|             } |             } | ||||||
|             return getBytesFromStream(is); |  | ||||||
|         } |         } | ||||||
|  |         return getBytesFromStream(is); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void saveBytesToOutStream(byte[] b, OutputStream os) throws IOException { |     public void saveBytesToOutStream(byte[] b, OutputStream os) throws IOException { | ||||||
| @@ -127,7 +123,7 @@ public class DownloadUtils { | |||||||
|     private byte[] getBytesFromStream(InputStream is) throws IOException { |     private byte[] getBytesFromStream(InputStream is) throws IOException { | ||||||
|         ByteArrayOutputStream baos = new ByteArrayOutputStream(); |         ByteArrayOutputStream baos = new ByteArrayOutputStream(); | ||||||
|         byte[] buffer = new byte[1024]; |         byte[] buffer = new byte[1024]; | ||||||
|         int len = 0; |         int len; | ||||||
|         while ((len = is.read(buffer)) != -1) { |         while ((len = is.read(buffer)) != -1) { | ||||||
|             baos.write(buffer, 0, len); |             baos.write(buffer, 0, len); | ||||||
|         } |         } | ||||||
| @@ -140,22 +136,14 @@ public class DownloadUtils { | |||||||
|     /** |     /** | ||||||
|      * 转换文本文件编码为utf8 |      * 转换文本文件编码为utf8 | ||||||
|      * 探测源文件编码,探测到编码切不为utf8则进行转码 |      * 探测源文件编码,探测到编码切不为utf8则进行转码 | ||||||
|  |      * | ||||||
|      * @param filePath 文件路径 |      * @param filePath 文件路径 | ||||||
|      */ |      */ | ||||||
|   private static void convertTextPlainFileCharsetToUtf8(String filePath) throws IOException { |     private void convertTextPlainFileCharsetToUtf8(String filePath) throws IOException { | ||||||
|         File sourceFile = new File(filePath); |         File sourceFile = new File(filePath); | ||||||
|         if (sourceFile.exists() && sourceFile.isFile() && sourceFile.canRead()) { |         if (sourceFile.exists() && sourceFile.isFile() && sourceFile.canRead()) { | ||||||
|       String encoding = null; |             String encoding = FileUtils.getFileEncode(filePath); | ||||||
|       try { |             if (!FileUtils.DEFAULT_FILE_ENCODING.equals(encoding)) { | ||||||
|         FileCharsetDetector.Observer observer = FileCharsetDetector.guessFileEncoding(sourceFile); |  | ||||||
|         // 为准确探测到编码,不适用猜测的编码 |  | ||||||
|         encoding = observer.isFound()?observer.getEncoding():null; |  | ||||||
|         // 为准确探测到编码,可以考虑使用GBK  大部分文件都是windows系统产生的 |  | ||||||
|       } catch (IOException e) { |  | ||||||
|         // 编码探测失败, |  | ||||||
|         e.printStackTrace(); |  | ||||||
|       } |  | ||||||
|       if(encoding != null && !"UTF-8".equals(encoding)){ |  | ||||||
|                 // 不为utf8,进行转码 |                 // 不为utf8,进行转码 | ||||||
|                 File tmpUtf8File = new File(filePath + ".utf8"); |                 File tmpUtf8File = new File(filePath + ".utf8"); | ||||||
|                 Writer writer = new OutputStreamWriter(new FileOutputStream(tmpUtf8File), StandardCharsets.UTF_8); |                 Writer writer = new OutputStreamWriter(new FileOutputStream(tmpUtf8File), StandardCharsets.UTF_8); | ||||||
| @@ -168,9 +156,13 @@ public class DownloadUtils { | |||||||
|                 reader.close(); |                 reader.close(); | ||||||
|                 writer.close(); |                 writer.close(); | ||||||
|                 // 删除源文件 |                 // 删除源文件 | ||||||
|         sourceFile.delete(); |                 if (!sourceFile.delete()) { | ||||||
|  |                     logger.error("源文件【{}】删除失败,请检查文件目录权限!", filePath); | ||||||
|  |                 } | ||||||
|                 // 重命名 |                 // 重命名 | ||||||
|         tmpUtf8File.renameTo(sourceFile); |                 if (tmpUtf8File.renameTo(sourceFile)) { | ||||||
|  |                     logger.error("临时文件【{}】重命名失败,请检查文件路径权限!", tmpUtf8File.getPath()); | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,157 +0,0 @@ | |||||||
| package cn.keking.utils; |  | ||||||
|  |  | ||||||
| import java.io.BufferedInputStream; |  | ||||||
| import java.io.File; |  | ||||||
| import java.io.FileInputStream; |  | ||||||
| import java.io.FileNotFoundException; |  | ||||||
| import java.io.IOException; |  | ||||||
|  |  | ||||||
| import org.mozilla.intl.chardet.nsDetector; |  | ||||||
| import org.mozilla.intl.chardet.nsICharsetDetectionObserver; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * 文本文件编码探测工具类 |  | ||||||
|  * |  | ||||||
|  * @author HWliao |  | ||||||
|  * @date 2017-12-24 |  | ||||||
|  */ |  | ||||||
| public class FileCharsetDetector { |  | ||||||
|  |  | ||||||
|   /** |  | ||||||
|    * 传入一个文件(File)对象,检查文件编码 |  | ||||||
|    * |  | ||||||
|    * @param file File对象实例 |  | ||||||
|    * @return 文件编码,若无,则返回null |  | ||||||
|    * @throws FileNotFoundException |  | ||||||
|    * @throws IOException |  | ||||||
|    */ |  | ||||||
|   public static Observer guessFileEncoding(File file) |  | ||||||
|       throws FileNotFoundException, IOException { |  | ||||||
|     return guessFileEncoding(file, new nsDetector()); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   /** |  | ||||||
|    * <pre> |  | ||||||
|    * 获取文件的编码 |  | ||||||
|    * @param file |  | ||||||
|    *            File对象实例 |  | ||||||
|    * @param languageHint |  | ||||||
|    *            语言提示区域代码 @see #nsPSMDetector ,取值如下: |  | ||||||
|    *             1 : Japanese |  | ||||||
|    *             2 : Chinese |  | ||||||
|    *             3 : Simplified Chinese |  | ||||||
|    *             4 : Traditional Chinese |  | ||||||
|    *             5 : Korean |  | ||||||
|    *             6 : Dont know(default) |  | ||||||
|    * </pre> |  | ||||||
|    * |  | ||||||
|    * @return 文件编码,eg:UTF-8,GBK,GB2312形式(不确定的时候,返回可能的字符编码序列);若无,则返回null |  | ||||||
|    * @throws FileNotFoundException |  | ||||||
|    * @throws IOException |  | ||||||
|    */ |  | ||||||
|   public static Observer guessFileEncoding(File file, int languageHint) |  | ||||||
|       throws FileNotFoundException, IOException { |  | ||||||
|     return guessFileEncoding(file, new nsDetector(languageHint)); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   /** |  | ||||||
|    * 获取文件的编码 |  | ||||||
|    * |  | ||||||
|    * @param file |  | ||||||
|    * @param det |  | ||||||
|    * @return |  | ||||||
|    * @throws FileNotFoundException |  | ||||||
|    * @throws IOException |  | ||||||
|    */ |  | ||||||
|   private static Observer guessFileEncoding(File file, nsDetector det) |  | ||||||
|       throws FileNotFoundException, IOException { |  | ||||||
|     // new Observer |  | ||||||
|     Observer observer = new Observer(); |  | ||||||
|     // set Observer |  | ||||||
|     // The Notify() will be called when a matching charset is found. |  | ||||||
|     det.Init(observer); |  | ||||||
|  |  | ||||||
|     BufferedInputStream imp = new BufferedInputStream(new FileInputStream( |  | ||||||
|         file)); |  | ||||||
|     byte[] buf = new byte[1024]; |  | ||||||
|     int len; |  | ||||||
|     boolean done = false; |  | ||||||
|     boolean isAscii = false; |  | ||||||
|  |  | ||||||
|     while ((len = imp.read(buf, 0, buf.length)) != -1) { |  | ||||||
|       // Check if the stream is only ascii. |  | ||||||
|       isAscii = det.isAscii(buf, len); |  | ||||||
|       if (isAscii) { |  | ||||||
|         break; |  | ||||||
|       } |  | ||||||
|       // DoIt if non-ascii and not done yet. |  | ||||||
|       done = det.DoIt(buf, len, false); |  | ||||||
|       if (done) { |  | ||||||
|         break; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     imp.close(); |  | ||||||
|     det.DataEnd(); |  | ||||||
|  |  | ||||||
|     if (isAscii) { |  | ||||||
|       observer.encoding = "ASCII"; |  | ||||||
|       observer.found = true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (!observer.isFound()) { |  | ||||||
|       String[] prob = det.getProbableCharsets(); |  | ||||||
|       // // 这里将可能的字符集组合起来返回 |  | ||||||
|       // for (int i = 0; i < prob.length; i++) { |  | ||||||
|       // if (i == 0) { |  | ||||||
|       // encoding = prob[i]; |  | ||||||
|       // } else { |  | ||||||
|       // encoding += "," + prob[i]; |  | ||||||
|       // } |  | ||||||
|       // } |  | ||||||
|       if (prob.length > 0) { |  | ||||||
|         // 在没有发现情况下,去第一个可能的编码 |  | ||||||
|         observer.encoding = prob[0]; |  | ||||||
|       } else { |  | ||||||
|         observer.encoding = null; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     return observer; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   /** |  | ||||||
|    * @author liaohongwei |  | ||||||
|    * @Description: 文件字符编码观察者, 但判断出字符编码时候调用 |  | ||||||
|    * @date 2016年6月20日 下午2:27:06 |  | ||||||
|    */ |  | ||||||
|   public static class Observer implements nsICharsetDetectionObserver { |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * @Fields encoding : 字符编码 |  | ||||||
|      */ |  | ||||||
|     private String encoding = null; |  | ||||||
|     /** |  | ||||||
|      * @Fields found : 是否找到字符集 |  | ||||||
|      */ |  | ||||||
|     private boolean found = false; |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void Notify(String charset) { |  | ||||||
|       this.encoding = charset; |  | ||||||
|       this.found = true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public String getEncoding() { |  | ||||||
|       return encoding; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public boolean isFound() { |  | ||||||
|       return found; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public String toString() { |  | ||||||
|       return "Observer [encoding=" + encoding + ", found=" + found + "]"; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -1,14 +1,18 @@ | |||||||
| package cn.keking.utils; | package cn.keking.utils; | ||||||
| 
 | 
 | ||||||
|  | import cpdetector.CharsetPrinter; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| 
 | 
 | ||||||
| import java.io.File; | import java.io.File; | ||||||
|  | import java.io.IOException; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
| 
 | 
 | ||||||
| public class DeleteFileUtil { | public class FileUtils { | ||||||
| 
 | 
 | ||||||
|     private static final Logger LOGGER = LoggerFactory.getLogger(DeleteFileUtil.class); |     private static final Logger LOGGER = LoggerFactory.getLogger(FileUtils.class); | ||||||
|  | 
 | ||||||
|  |     public static final String DEFAULT_FILE_ENCODING = "UTF-8"; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 删除单个文件 |      * 删除单个文件 | ||||||
| @@ -17,7 +21,7 @@ public class DeleteFileUtil { | |||||||
|      *            要删除的文件的文件名 |      *            要删除的文件的文件名 | ||||||
|      * @return 单个文件删除成功返回true,否则返回false |      * @return 单个文件删除成功返回true,否则返回false | ||||||
|      */ |      */ | ||||||
|     public static boolean deleteFile(String fileName) { |     public static boolean deleteFileByName(String fileName) { | ||||||
|         File file = new File(fileName); |         File file = new File(fileName); | ||||||
|         // 如果文件路径所对应的文件存在,并且是一个文件,则直接删除 |         // 如果文件路径所对应的文件存在,并且是一个文件,则直接删除 | ||||||
|         if (file.exists() && file.isFile()) { |         if (file.exists() && file.isFile()) { | ||||||
| @@ -34,6 +38,36 @@ public class DeleteFileUtil { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 判断文件编码格式 | ||||||
|  |      * | ||||||
|  |      * @param filePath 绝对路径 | ||||||
|  |      * @return 编码格式 | ||||||
|  |      */ | ||||||
|  |     public static String getFileEncode(String filePath) { | ||||||
|  |         File file = new File(filePath); | ||||||
|  |         CharsetPrinter cp = new CharsetPrinter(); | ||||||
|  |         try { | ||||||
|  |             String encoding = cp.guessEncoding(file); | ||||||
|  |             LOGGER.info("检测到文件【{}】编码: {}", filePath, encoding); | ||||||
|  |             return encoding; | ||||||
|  |         } catch (IOException e) { | ||||||
|  |             LOGGER.warn("文件编码获取失败,采用默认的编码格式:UTF-8", e); | ||||||
|  |             return DEFAULT_FILE_ENCODING; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 根据文件路径删除文件 | ||||||
|  |      * | ||||||
|  |      * @param filePath 绝对路径 | ||||||
|  |      */ | ||||||
|  |     public static void deleteFileByPath(String filePath) { | ||||||
|  |         File file = new File(filePath); | ||||||
|  |         if (file.exists() && !file.delete()) { | ||||||
|  |             LOGGER.warn("压缩包源文件删除失败:{}!", filePath); | ||||||
|  |         } | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 删除目录及目录下的文件 |      * 删除目录及目录下的文件 | ||||||
| @@ -59,20 +93,20 @@ public class DeleteFileUtil { | |||||||
|         for (int i = 0; i < Objects.requireNonNull(files).length; i++) { |         for (int i = 0; i < Objects.requireNonNull(files).length; i++) { | ||||||
|             // 删除子文件 |             // 删除子文件 | ||||||
|             if (files[i].isFile()) { |             if (files[i].isFile()) { | ||||||
|                 flag = DeleteFileUtil.deleteFile(files[i].getAbsolutePath()); |                 flag = FileUtils.deleteFileByName(files[i].getAbsolutePath()); | ||||||
|                 if (!flag) { |                 if (!flag) { | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|             }  else if (files[i].isDirectory()) { |             }  else if (files[i].isDirectory()) { | ||||||
|                 // 删除子目录 |                 // 删除子目录 | ||||||
|                 flag = DeleteFileUtil.deleteDirectory(files[i].getAbsolutePath()); |                 flag = FileUtils.deleteDirectory(files[i].getAbsolutePath()); | ||||||
|                 if (!flag) { |                 if (!flag) { | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         dirFile.delete(); | 
 | ||||||
|         if (!flag) { |         if (!dirFile.delete() || !flag) { | ||||||
|             LOGGER.info("删除目录失败!"); |             LOGGER.info("删除目录失败!"); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| package cn.keking.utils; | package cn.keking.utils; | ||||||
|  |  | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import org.apache.pdfbox.pdmodel.PDDocument; | import org.apache.pdfbox.pdmodel.PDDocument; | ||||||
| import org.apache.pdfbox.rendering.ImageType; | import org.apache.pdfbox.rendering.ImageType; | ||||||
| import org.apache.pdfbox.rendering.PDFRenderer; | import org.apache.pdfbox.rendering.PDFRenderer; | ||||||
| @@ -23,18 +23,18 @@ public class PdfUtils { | |||||||
|  |  | ||||||
|     private final Logger logger = LoggerFactory.getLogger(PdfUtils.class); |     private final Logger logger = LoggerFactory.getLogger(PdfUtils.class); | ||||||
|  |  | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|  |  | ||||||
|     @Value("${server.tomcat.uri-encoding:UTF-8}") |     @Value("${server.tomcat.uri-encoding:UTF-8}") | ||||||
|     private String uriEncoding; |     private String uriEncoding; | ||||||
|  |  | ||||||
|     public PdfUtils(FilePreviewCommonService filePreviewCommonService) { |     public PdfUtils(FileHandlerService fileHandlerService) { | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public List<String> pdf2jpg(String pdfFilePath, String pdfName, String baseUrl) { |     public List<String> pdf2jpg(String pdfFilePath, String pdfName, String baseUrl) { | ||||||
|         List<String> imageUrls = new ArrayList<>(); |         List<String> imageUrls = new ArrayList<>(); | ||||||
|         Integer imageCount = filePreviewCommonService.getConvertedPdfImage(pdfFilePath); |         Integer imageCount = fileHandlerService.getConvertedPdfImage(pdfFilePath); | ||||||
|         String imageFileSuffix = ".jpg"; |         String imageFileSuffix = ".jpg"; | ||||||
|         String pdfFolder = pdfName.substring(0, pdfName.length() - 4); |         String pdfFolder = pdfName.substring(0, pdfName.length() - 4); | ||||||
|         String urlPrefix = null; |         String urlPrefix = null; | ||||||
| @@ -70,7 +70,7 @@ public class PdfUtils { | |||||||
|                 imageUrls.add(urlPrefix + "/" + pageIndex + imageFileSuffix); |                 imageUrls.add(urlPrefix + "/" + pageIndex + imageFileSuffix); | ||||||
|             } |             } | ||||||
|             doc.close(); |             doc.close(); | ||||||
|             filePreviewCommonService.addConvertedPdfImage(pdfFilePath, pageCount); |             fileHandlerService.addConvertedPdfImage(pdfFilePath, pageCount); | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
|             logger.error("Convert pdf to jpg exception, pdfFilePath:{}", pdfFilePath, e); |             logger.error("Convert pdf to jpg exception, pdfFilePath:{}", pdfFilePath, e); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ public class ShedulerClean { | |||||||
|     public void clean() { |     public void clean() { | ||||||
|         logger.info("Cache clean start"); |         logger.info("Cache clean start"); | ||||||
|         cacheService.cleanCache(); |         cacheService.cleanCache(); | ||||||
|         DeleteFileUtil.deleteDirectory(fileDir); |         FileUtils.deleteDirectory(fileDir); | ||||||
|         logger.info("Cache clean end"); |         logger.info("Cache clean end"); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import cn.keking.service.FilePreviewFactory; | |||||||
|  |  | ||||||
| import cn.keking.service.cache.CacheService; | import cn.keking.service.cache.CacheService; | ||||||
| import cn.keking.utils.DownloadUtils; | import cn.keking.utils.DownloadUtils; | ||||||
| import cn.keking.service.FilePreviewCommonService; | import cn.keking.service.FileHandlerService; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| import org.springframework.stereotype.Controller; | import org.springframework.stereotype.Controller; | ||||||
| @@ -32,12 +32,12 @@ public class OnlinePreviewController { | |||||||
|  |  | ||||||
|     private final FilePreviewFactory previewFactory; |     private final FilePreviewFactory previewFactory; | ||||||
|     private final CacheService cacheService; |     private final CacheService cacheService; | ||||||
|     private final FilePreviewCommonService filePreviewCommonService; |     private final FileHandlerService fileHandlerService; | ||||||
|     private final DownloadUtils downloadUtils; |     private final DownloadUtils downloadUtils; | ||||||
|  |  | ||||||
|     public OnlinePreviewController(FilePreviewFactory filePreviewFactory, FilePreviewCommonService filePreviewCommonService, CacheService cacheService, DownloadUtils downloadUtils) { |     public OnlinePreviewController(FilePreviewFactory filePreviewFactory, FileHandlerService fileHandlerService, CacheService cacheService, DownloadUtils downloadUtils) { | ||||||
|         this.previewFactory = filePreviewFactory; |         this.previewFactory = filePreviewFactory; | ||||||
|         this.filePreviewCommonService = filePreviewCommonService; |         this.fileHandlerService = fileHandlerService; | ||||||
|         this.cacheService = cacheService; |         this.cacheService = cacheService; | ||||||
|         this.downloadUtils = downloadUtils; |         this.downloadUtils = downloadUtils; | ||||||
|     } |     } | ||||||
| @@ -45,7 +45,7 @@ public class OnlinePreviewController { | |||||||
|  |  | ||||||
|     @RequestMapping(value = "/onlinePreview") |     @RequestMapping(value = "/onlinePreview") | ||||||
|     public String onlinePreview(String url, Model model, HttpServletRequest req) { |     public String onlinePreview(String url, Model model, HttpServletRequest req) { | ||||||
|         FileAttribute fileAttribute = filePreviewCommonService.getFileAttribute(url,req); |         FileAttribute fileAttribute = fileHandlerService.getFileAttribute(url,req); | ||||||
|         FilePreview filePreview = previewFactory.get(fileAttribute); |         FilePreview filePreview = previewFactory.get(fileAttribute); | ||||||
|         logger.info("预览文件url:{},previewType:{}", url, fileAttribute.getType()); |         logger.info("预览文件url:{},previewType:{}", url, fileAttribute.getType()); | ||||||
|         return filePreview.filePreviewHandle(url, model, fileAttribute); |         return filePreview.filePreviewHandle(url, model, fileAttribute); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 chenkailing
					chenkailing