首先引入依赖:
<dependency>
<groupId>org.apache.pdfbox</groupId>
<artifactId>pdfbox</artifactId>
<version>2.0.1</version>
</dependency>
首先先引入依赖,可能有的地方在引入jai_core这个包的时候,不能 引入,所以,需要将这个包排除.
下面是经过测试的代码:
public class PdfToImg { public static void main(String[] args) { String filePath = "E:\data\pdf\1.pdf"; List<String> imageList = pdfToImagePath(filePath); Iterator<String> iterator = imageList.iterator(); while (iterator.hasNext()) { System.out.println(iterator.next()); } System.out.println(imageList); } public static List<String> pdfToImagePath(String filePath) { List<String> list = new ArrayList<>(); String fileDirectory = filePath.substring(0, filePath.lastIndexOf("."));//获取去除后缀的文件路径 String imagePath; File file = new File(filePath); try { File f = new File(fileDirectory); if (!f.exists()) { f.mkdir(); } PDDocument doc = PDDocument.load(file); PDFRenderer renderer = new PDFRenderer(doc); int pageCount = doc.getNumberOfPages(); for (int i = 0; i < pageCount; i++) { // 方式1,第二个参数是设置缩放比(即像素) BufferedImage image = renderer.renderImageWithDPI(i, 296); // 方式2,第二个参数是设置缩放比(即像素) BufferedImage images = renderer.renderImage(i, 1.25f); //第二个参数越大生成图片分辨率越高,转换时间也就越长 imagePath = fileDirectory + "/" + i + ".jpg"; ImageIO.write(images, "PNG", new File(imagePath)); list.add(imagePath); return list; } doc.close(); //关闭文件,不然该pdf文件会一直被占用。 } catch (IOException e) { e.printStackTrace(); } return null; } }
这个在本地运行是没有问题的.但是如果放在linux服务器上运行,就需要引入一个字体.这个字体为宋体,我用的为60M左右,所以包还是挺大的,如果不齐全,可以将自己电脑上的所有字体都放在服务器的user/share/fonts这个目录下,刷新缓存,然后重新启动服务,就可以正式将完整的照片进行转换,不然,转化出来的照片中的汉字会出现乱码的情况.
上面说的两种方式进行设置可以进行预览,纯就是扯淡,只能通过具体的域名加上具体的路径才能真正的达到预览的效果.