本文实例讲述了java实现pdf文件截图的方法。分享给大家供大家参考,具体如下:
最近做的一个网站中,有个需求是上传pdf文件,显示pdf的封页,点击封页之后进行在线阅读,这里使用的是PDFRender对pdf进行截图。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
public static boolean createScreenShoot(String source, String target) { File file = new File(source); if (!file.exists()) { System.err.println( "路径[" + source + "]对应的pdf文件不存在!" ); return false ; } try { RandomAccessFile raf = new RandomAccessFile(file, "r" ); FileChannel channel = raf.getChannel(); ByteBuffer buf = channel.map(FileChannel.MapMode.READ_ONLY, 0 , channel.size()); PDFFile pdffile = new PDFFile(buf); int num = pdffile.getNumPages(); for ( int i = 1 ; i < num; i++){ PDFPage page = pdffile.getPage( 1 ); // get the width and height for the doc at the default zoom Rectangle rect = new Rectangle( 0 , 0 , ( int ) page.getBBox() .getWidth(), ( int ) page.getBBox().getHeight()); // generate the image Image img = page.getImage(rect.width, rect.height, // width & rect, // clip rect null , // null for the ImageObserver true , // fill background with white true // block until drawing is done ); BufferedImage tag = new BufferedImage(rect.width, rect.height, BufferedImage.TYPE_INT_RGB); tag.getGraphics().drawImage(img, 0 , 0 , rect.width, rect.height, null ); FileOutputStream out = new FileOutputStream(target+i+ "jpg" ); JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); encoder.encode(tag); // JPEG编码 out.close(); } return true ; } catch (Exception e){ e.printStackTrace(); return true ; } |
另外如果需要在线显示pdf的话,需要设置响应头
1
|
response.setContentType( "application/pdf" ); |
附:pdfRender.jar点击此处本站下载。
希望本文所述对大家java程序设计有所帮助。
原文链接:http://blog.csdn.net/yangnianbing110/article/details/32702437