mirror of
				https://github.com/Frooodle/Stirling-PDF.git
				synced 2025-10-25 11:17:28 +02:00 
			
		
		
		
	Bug fixes for merge and split (#80)
This commit is contained in:
		
							parent
							
								
									726fcf861c
								
							
						
					
					
						commit
						3d7fdd0f35
					
				| @ -21,6 +21,8 @@ import org.springframework.web.bind.annotation.PostMapping; | ||||
| import org.springframework.web.bind.annotation.RequestParam; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| 
 | ||||
| import stirling.software.SPDF.utils.PdfUtils; | ||||
| 
 | ||||
| @Controller | ||||
| public class MergeController { | ||||
| 
 | ||||
| @ -33,7 +35,7 @@ public class MergeController { | ||||
|     } | ||||
| 
 | ||||
|     @PostMapping("/merge-pdfs") | ||||
|     public ResponseEntity<InputStreamResource> mergePdfs(@RequestParam("fileInput") MultipartFile[] files) throws IOException { | ||||
|     public ResponseEntity<byte[]> mergePdfs(@RequestParam("fileInput") MultipartFile[] files) throws IOException { | ||||
|         // Read the input PDF files into PDDocument objects | ||||
|         List<PDDocument> documents = new ArrayList<>(); | ||||
| 
 | ||||
| @ -43,15 +45,9 @@ public class MergeController { | ||||
|         } | ||||
| 
 | ||||
|         PDDocument mergedDoc = mergeDocuments(documents); | ||||
|         ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); | ||||
|         mergedDoc.save(byteArrayOutputStream); | ||||
|         mergedDoc.close(); | ||||
| 
 | ||||
|         // Create an InputStreamResource from the merged PDF | ||||
|         InputStreamResource resource = new InputStreamResource(new ByteArrayInputStream(byteArrayOutputStream.toByteArray())); | ||||
| 
 | ||||
|         // Return the merged PDF as a response | ||||
|         return ResponseEntity.ok().contentType(MediaType.APPLICATION_PDF).body(resource); | ||||
|         return PdfUtils.pdfDocToWebResponse(mergedDoc, files[0].getOriginalFilename().replaceFirst("[.][^.]+$", "")+ "_merged.pdf"); | ||||
|     } | ||||
| 
 | ||||
|     private PDDocument mergeDocuments(List<PDDocument> documents) throws IOException { | ||||
|  | ||||
| @ -31,7 +31,8 @@ import org.springframework.web.bind.annotation.GetMapping; | ||||
| import org.springframework.web.bind.annotation.PostMapping; | ||||
| import org.springframework.web.bind.annotation.RequestParam; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| 
 | ||||
| import java.util.zip.ZipEntry; | ||||
| import java.util.zip.ZipOutputStream; | ||||
| @Controller | ||||
| public class SplitPDFController { | ||||
| 
 | ||||
| @ -105,32 +106,33 @@ public class SplitPDFController { | ||||
|         // closing the original document | ||||
|         document.close(); | ||||
| 
 | ||||
|         // create the zip file | ||||
|         Path zipFile = Files.createTempFile("split_documents", ".zip"); | ||||
|         URI uri = URI.create("jar:file:" + zipFile.toUri().getPath()); | ||||
|         Map<String, String> env = new HashMap<>(); | ||||
|         env.put("create", "true"); | ||||
|         FileSystem zipfs = FileSystems.newFileSystem(uri, env); | ||||
| 
 | ||||
|         // loop through the split documents and write them to the zip file | ||||
|         for (int i = 0; i < splitDocumentsBoas.size(); i++) { | ||||
|             String fileName = "split_document_" + (i + 1) + ".pdf"; | ||||
|             ByteArrayOutputStream baos = splitDocumentsBoas.get(i); | ||||
|             byte[] pdf = baos.toByteArray(); | ||||
|             Path pathInZipfile = zipfs.getPath(fileName); | ||||
|             try (OutputStream os = Files.newOutputStream(pathInZipfile)) { | ||||
|                 os.write(pdf); | ||||
|         try (ZipOutputStream zipOut = new ZipOutputStream(Files.newOutputStream(zipFile))) { | ||||
|             // loop through the split documents and write them to the zip file | ||||
|             for (int i = 0; i < splitDocumentsBoas.size(); i++) { | ||||
|                 String fileName = "split_document_" + (i + 1) + ".pdf"; | ||||
|                 ByteArrayOutputStream baos = splitDocumentsBoas.get(i); | ||||
|                 byte[] pdf = baos.toByteArray(); | ||||
| 
 | ||||
|                 // Add PDF file to the zip | ||||
|                 ZipEntry pdfEntry = new ZipEntry(fileName); | ||||
|                 zipOut.putNextEntry(pdfEntry); | ||||
|                 zipOut.write(pdf); | ||||
|                 zipOut.closeEntry(); | ||||
| 
 | ||||
|                 logger.info("Wrote split document {} to zip file", fileName); | ||||
|             } catch (Exception e) { | ||||
|                 logger.error("Failed writing to zip", e); | ||||
|                 throw e; | ||||
|             } | ||||
|         } catch (Exception e) { | ||||
|             logger.error("Failed writing to zip", e); | ||||
|             throw e; | ||||
|         } | ||||
|         zipfs.close(); | ||||
| 
 | ||||
|         logger.info("Successfully created zip file with split documents: {}", zipFile.toString()); | ||||
|         byte[] data = Files.readAllBytes(zipFile); | ||||
|         ByteArrayResource resource = new ByteArrayResource(data); | ||||
|         Files.delete(zipFile); | ||||
| 
 | ||||
|         // return the Resource in the response | ||||
|         return ResponseEntity.ok().header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=" + file.getOriginalFilename().replaceFirst("[.][^.]+$", "") + "_split.zip").contentType(MediaType.APPLICATION_OCTET_STREAM) | ||||
|                 .contentLength(resource.contentLength()).body(resource); | ||||
|  | ||||
| @ -16,10 +16,8 @@ | ||||
|                         <form action="merge-pdfs" method="post" enctype="multipart/form-data"> | ||||
|                             <div class="form-group"> | ||||
|                                 <label th:text="#{multiPdfDropPrompt}"></label> | ||||
|                                 <div class="custom-file"> | ||||
|                                     <input type="file" class="custom-file-input" id="fileInput" name="fileInput" accept="application/pdf" multiple required>  | ||||
|                                     <label class="custom-file-label" th:text="#{pdfPrompt}"></label> | ||||
|                                 </div> | ||||
|                                 <div th:replace="~{fragments/common :: fileSelector(name='fileInput', multiple=true, accept='application/pdf')}"></div> | ||||
| 
 | ||||
|                             </div> | ||||
|                             <div class="form-group"> | ||||
|                                 <ul id="selectedFiles" class="list-group"></ul> | ||||
| @ -61,7 +59,7 @@ | ||||
| 
 | ||||
|                         </style> | ||||
|                         <script> | ||||
|                         document.getElementById("fileInput").addEventListener("change", function() { | ||||
|                         document.getElementById("fileInput-input").addEventListener("change", function() { | ||||
|                         	  var files = this.files; | ||||
|                         	  var list = document.getElementById("selectedFiles"); | ||||
|                         	  list.innerHTML = ""; | ||||
| @ -121,7 +119,7 @@ | ||||
|                         	        } | ||||
|                         	      } | ||||
|                         	    } | ||||
|                         	    document.getElementById("fileInput").files = dataTransfer.files; | ||||
|                         	    document.getElementById("fileInput-input").files = dataTransfer.files; | ||||
|                         	  } | ||||
|                         	}); | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user