| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  | package cn.keking.service;
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | import cn.keking.model.FileAttribute;
 | 
					
						
							|  |  |  |  | import cn.keking.model.FileType;
 | 
					
						
							| 
									
										
										
										
											2019-04-08 17:50:13 +08:00
										 |  |  |  | import cn.keking.service.cache.CacheService;
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  | import org.slf4j.Logger;
 | 
					
						
							|  |  |  |  | import org.slf4j.LoggerFactory;
 | 
					
						
							|  |  |  |  | import org.springframework.stereotype.Service;
 | 
					
						
							|  |  |  |  | import org.springframework.ui.ExtendedModelMap;
 | 
					
						
							|  |  |  |  | import javax.annotation.PostConstruct;
 | 
					
						
							|  |  |  |  | import java.util.concurrent.ExecutorService;
 | 
					
						
							|  |  |  |  | import java.util.concurrent.Executors;
 | 
					
						
							| 
									
										
										
										
											2020-12-27 14:06:06 +08:00
										 |  |  |  | import java.util.concurrent.TimeUnit;
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * Created by kl on 2018/1/19.
 | 
					
						
							|  |  |  |  |  * Content :消费队列中的转换文件
 | 
					
						
							|  |  |  |  |  */
 | 
					
						
							|  |  |  |  | @Service
 | 
					
						
							| 
									
										
										
										
											2020-05-15 18:09:19 +08:00
										 |  |  |  | public class FileConvertQueueTask {
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-15 18:09:19 +08:00
										 |  |  |  |     private final Logger logger = LoggerFactory.getLogger(getClass());
 | 
					
						
							|  |  |  |  |     private final FilePreviewFactory previewFactory;
 | 
					
						
							|  |  |  |  |     private final CacheService cacheService;
 | 
					
						
							| 
									
										
										
										
											2020-12-26 19:13:50 +08:00
										 |  |  |  |     private final FileHandlerService fileHandlerService;
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-26 19:13:50 +08:00
										 |  |  |  |     public FileConvertQueueTask(FilePreviewFactory previewFactory, CacheService cacheService, FileHandlerService fileHandlerService) {
 | 
					
						
							| 
									
										
										
										
											2020-05-15 18:09:19 +08:00
										 |  |  |  |         this.previewFactory = previewFactory;
 | 
					
						
							|  |  |  |  |         this.cacheService = cacheService;
 | 
					
						
							| 
									
										
										
										
											2020-12-26 19:13:50 +08:00
										 |  |  |  |         this.fileHandlerService = fileHandlerService;
 | 
					
						
							| 
									
										
										
										
											2020-05-15 18:09:19 +08:00
										 |  |  |  |     }
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     @PostConstruct
 | 
					
						
							|  |  |  |  |     public void startTask(){
 | 
					
						
							| 
									
										
										
										
											2020-12-26 16:44:05 +08:00
										 |  |  |  |         ExecutorService executorService = Executors.newFixedThreadPool(1);
 | 
					
						
							| 
									
										
										
										
											2020-12-26 19:13:50 +08:00
										 |  |  |  |         executorService.submit(new ConvertTask(previewFactory, cacheService, fileHandlerService));
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  |         logger.info("队列处理文件转换任务启动完成 ");
 | 
					
						
							|  |  |  |  |     }
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-18 09:46:52 +08:00
										 |  |  |  |     static class ConvertTask implements Runnable {
 | 
					
						
							| 
									
										
										
										
											2020-05-15 18:09:19 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |         private final Logger logger = LoggerFactory.getLogger(ConvertTask.class);
 | 
					
						
							|  |  |  |  |         private final FilePreviewFactory previewFactory;
 | 
					
						
							|  |  |  |  |         private final CacheService cacheService;
 | 
					
						
							| 
									
										
										
										
											2020-12-26 19:13:50 +08:00
										 |  |  |  |         private final FileHandlerService fileHandlerService;
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-15 18:09:19 +08:00
										 |  |  |  |         public ConvertTask(FilePreviewFactory previewFactory,
 | 
					
						
							|  |  |  |  |                            CacheService cacheService,
 | 
					
						
							| 
									
										
										
										
											2020-12-26 19:13:50 +08:00
										 |  |  |  |                            FileHandlerService fileHandlerService) {
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  |             this.previewFactory = previewFactory;
 | 
					
						
							| 
									
										
										
										
											2019-04-08 17:50:13 +08:00
										 |  |  |  |             this.cacheService = cacheService;
 | 
					
						
							| 
									
										
										
										
											2020-12-26 19:13:50 +08:00
										 |  |  |  |             this.fileHandlerService = fileHandlerService;
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  |         }
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         @Override
 | 
					
						
							|  |  |  |  |         public void run() {
 | 
					
						
							|  |  |  |  |             while (true) {
 | 
					
						
							| 
									
										
										
										
											2020-05-14 10:11:15 +08:00
										 |  |  |  |                 String url = null;
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  |                 try {
 | 
					
						
							| 
									
										
										
										
											2020-05-14 10:11:15 +08:00
										 |  |  |  |                     url = cacheService.takeQueueTask();
 | 
					
						
							| 
									
										
										
										
											2019-06-17 14:21:16 +08:00
										 |  |  |  |                     if(url != null){
 | 
					
						
							| 
									
										
										
										
											2020-12-26 19:13:50 +08:00
										 |  |  |  |                         FileAttribute fileAttribute = fileHandlerService.getFileAttribute(url,null);
 | 
					
						
							| 
									
										
										
										
											2020-05-14 10:11:15 +08:00
										 |  |  |  |                         FileType fileType = fileAttribute.getType();
 | 
					
						
							|  |  |  |  |                         logger.info("正在处理预览转换任务,url:{},预览类型:{}", url, fileType);
 | 
					
						
							| 
									
										
										
										
											2021-02-08 18:02:49 +08:00
										 |  |  |  |                         if(fileType.equals(FileType.COMPRESS) || fileType.equals(FileType.OFFICE) || fileType.equals(FileType.CAD)) {
 | 
					
						
							| 
									
										
										
										
											2020-05-14 10:11:15 +08:00
										 |  |  |  |                             FilePreview filePreview = previewFactory.get(fileAttribute);
 | 
					
						
							| 
									
										
										
										
											2019-06-17 14:21:16 +08:00
										 |  |  |  |                             filePreview.filePreviewHandle(url, new ExtendedModelMap(), fileAttribute);
 | 
					
						
							| 
									
										
										
										
											2020-05-14 10:11:15 +08:00
										 |  |  |  |                         } else {
 | 
					
						
							|  |  |  |  |                             logger.info("预览类型无需处理,url:{},预览类型:{}", url, fileType);
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  |                         }
 | 
					
						
							|  |  |  |  |                     }
 | 
					
						
							|  |  |  |  |                 } catch (Exception e) {
 | 
					
						
							|  |  |  |  |                     try {
 | 
					
						
							| 
									
										
										
										
											2020-12-27 14:06:06 +08:00
										 |  |  |  |                         TimeUnit.SECONDS.sleep(10);
 | 
					
						
							| 
									
										
										
										
											2020-05-14 10:11:15 +08:00
										 |  |  |  |                     } catch (Exception ex){
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  |                         ex.printStackTrace();
 | 
					
						
							|  |  |  |  |                     }
 | 
					
						
							| 
									
										
										
										
											2020-05-14 10:11:15 +08:00
										 |  |  |  |                     logger.info("处理预览转换任务异常,url:{}", url, e);
 | 
					
						
							| 
									
										
										
										
											2018-01-19 14:51:18 +08:00
										 |  |  |  |                 }
 | 
					
						
							|  |  |  |  |             }
 | 
					
						
							|  |  |  |  |         }
 | 
					
						
							|  |  |  |  |     }
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | }
 |