`

利用itext操作pdf从数据库导出大量数据--创建PDF相关(二)

阅读更多
【原始需求】
通过SQL及JDBC模式导出各类业务数据,以PDF文件格式存放,要求该文件只能查看和打印(不能编辑和篡改),文件要有公司相关标志和水印功能。

【需求分析】
1、 通过SQL及JDBC模式导出业务数据,业务数据以表格内容格式存放于PDF文件
2、 PDF文件注明版权
3、 PDF页面中增加水印,公司文字或图片

【设计分析】
1、 生成PDF文件
2、 PDF文件注明版权
3、 PDF增加文字和图片水印
4、 PDF表格列数可能很多,比如1-50列信息,导出时需判断A4纸格式或其他格式宽度。
5、 PDF表格行数量可能超大,比如10万以上,甚至100万以上。
6、 增加水印信息后,文件大小增量应比较小,比如小于5%。

【功能开发】
1、 生成PDF文件
2、 支持中文字体
3、 PDF文件内容为表格,表格有表头
4、 PDF文件内容支持中文,表格内容上下居中,左右居中或左对齐/右对齐
5、 PDF列信息多寡不同,PDF采用页面宽度也能根据列信息按比例调整
6、 PDF行信息超大时写入模式,不能引起内存溢出等问题,有一定的并发性支撑能力。
7、 PDF文件增加作者相关版权信息
8、 PDF页头增加版权相关信息
9、 PDF文件修改权限限制,实现文档只可读取的权限
10、 PDF文件增加文字或图片水印功能,要求文字或图片在整个页面清晰可见。增加的水印信息不能使PDF文件大小增长超过5%。
11、 对PDF文件进行加密

【开发总结】
1、 大数据量写入的内存溢出问题采用文件流模式解决
2、 图片水印需要采用单例图片对象来处理,避免增加图片水印后PDF文件大小猛增
3、 PDF文件生成时,特别是当表格数据比较大时,CPU和JVM内存资源消耗都比较高,这样系统并发性较低。个人笔记本电脑单PDF文件导出时,CPU资源使用率在30%左右,JVM内存资源达到堆大小的极限,因为垃圾回收的缘故避免了内存溢出(已按流式数据处理方式)。
4、 水印的位置需要根据PDF页面大小和水印本身的信息位置范围来确定

利用itext操作pdf从数据库导出大量数据--功能汇总(一)

利用itext操作pdf从数据库导出大量数据--创建PDF相关(二)

利用itext操作pdf从数据库导出大量数据--创建PDF表格(三)

利用itext操作pdf从数据库导出大量数据--添加水印(四)

package com.fruitking.testpdf.util;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;

import com.lowagie.text.Document;
import com.lowagie.text.DocumentException;
import com.lowagie.text.Font;
import com.lowagie.text.Paragraph;
import com.lowagie.text.pdf.BaseFont;
import com.lowagie.text.pdf.PdfWriter;

public class PDFCreate1File {
	
	
	/**
	 * 创建一份PDF文档
	 * @param fullFilePath
	 */
	public boolean createPDFFile(String fullFilePath){
        Document pdfDocument = new Document();
        try {
            //构建一个PDF文档输出流程
        	OutputStream pdfFileOutputStream = new FileOutputStream(new File(fullFilePath));
        	PdfWriter.getInstance(pdfDocument,pdfFileOutputStream);
        	//设置中文字体和字体样式
            BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);  
            Font f2 = new Font(bfChinese, 2, Font.NORMAL);
            Font f6 = new Font(bfChinese, 6, Font.NORMAL);
            Font f10 = new Font(bfChinese, 10, Font.NORMAL);
            Font f12 = new Font(bfChinese, 12, Font.BOLD);
            //打开PDF文件流
        	pdfDocument.open();
            //设置PDF文件正文内容
            pdfDocument.add(new Paragraph("中国程序员周报", f12)); 
            //换行
            pdfDocument.add(new Paragraph(" ",f6)); 
            //换行
            pdfDocument.add(new Paragraph("中国程序员工作时间调查报告", f10)); 
            //换行
            pdfDocument.add(new Paragraph(" ", f2));
            return true;
        }catch(FileNotFoundException de) {
            de.printStackTrace();
            System.err.println("pdf file: " + de.getMessage());
            return false;
        }catch(DocumentException de) {
            de.printStackTrace();
            System.err.println("document: " + de.getMessage());
            return false;
        }catch(IOException de) {
            de.printStackTrace();
            System.err.println("pdf font: " + de.getMessage());
            return false;
        }finally{
            //关闭PDF文档流,OutputStream文件输出流也将在PDF文档流关闭方法内部关闭
        	if(pdfDocument!=null){
        		pdfDocument.close();
        	}
        }        
    }
	
	/**
	 * 创建一份PDF文档,且标注作者等信息
	 * @param fullFilePath
	 */
	public boolean createPDFFileWithCreatorInfo(String fullFilePath){
        Document pdfDocument = new Document();
        try {
            //构建一个PDF文档输出流程
        	OutputStream pdfFileOutputStream = new FileOutputStream(new File(fullFilePath));
        	PdfWriter pdfWriter = PdfWriter.getInstance(pdfDocument,pdfFileOutputStream);
        	//PDF版本(默认1.4)
        	pdfWriter.setPdfVersion(PdfWriter.PDF_VERSION_1_4);
            //文档属性
            pdfDocument.addTitle("水果大王信息技术有限公司数据安全产品");
            pdfDocument.addAuthor("杭州水果大王信息技术有限公司");
            pdfDocument.addSubject("文件导出的信息安全管控");
            pdfDocument.addKeywords("文件导出,信息安全");//文档关键字信息
            pdfDocument.addCreator("水果大王文件取数系统");//应用程序名称
        	//设置中文字体和字体样式
            BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);  
            Font f2 = new Font(bfChinese, 2, Font.NORMAL);
            Font f6 = new Font(bfChinese, 6, Font.NORMAL);
            Font f10 = new Font(bfChinese, 10, Font.NORMAL);
            Font f12 = new Font(bfChinese, 12, Font.BOLD);
            //打开PDF文件流
        	pdfDocument.open();
            //设置PDF文件正文内容
            pdfDocument.add(new Paragraph("中国程序员周报", f12)); 
            //换行
            pdfDocument.add(new Paragraph(" ",f6)); 
            //换行
            pdfDocument.add(new Paragraph("中国程序员工作时间调查报告", f10)); 
            //换行
            pdfDocument.add(new Paragraph(" ", f2));
            return true;
        }catch(FileNotFoundException de) {
            de.printStackTrace();
            System.err.println("pdf file: " + de.getMessage());
            return false;
        }catch(DocumentException de) {
            de.printStackTrace();
            System.err.println("document: " + de.getMessage());
            return false;
        }catch(IOException de) {
            de.printStackTrace();
            System.err.println("pdf font: " + de.getMessage());
            return false;
        }finally{
            //关闭PDF文档流,OutputStream文件输出流也将在PDF文档流关闭方法内部关闭
        	if(pdfDocument!=null){
        		pdfDocument.close();
        	}
        }        
    }
	
	/**
	 * 创建一份PDF文档,并把该文档设置成只读权限
	 * @param fullFilePath
	 */
	public boolean createReadOnlyPDFFile(String fullFilePath){
        Document pdfDocument = new Document();
        try {
            //构建一个PDF文档输出流程
        	OutputStream pdfFileOutputStream = new FileOutputStream(new File(fullFilePath));
        	PdfWriter pdfWriter = PdfWriter.getInstance(pdfDocument,pdfFileOutputStream);
        	pdfWriter.setEncryption(null, null,PdfWriter.ALLOW_PRINTING, PdfWriter.STANDARD_ENCRYPTION_128);
        	//设置中文字体和字体样式
            BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);  
            Font f2 = new Font(bfChinese, 2, Font.NORMAL);
            Font f6 = new Font(bfChinese, 6, Font.NORMAL);
            Font f10 = new Font(bfChinese, 10, Font.NORMAL);
            Font f12 = new Font(bfChinese, 12, Font.BOLD);
            //打开PDF文件流
        	pdfDocument.open();
            //设置PDF文件正文内容
            pdfDocument.add(new Paragraph("中国程序员周报", f12)); 
            //换行
            pdfDocument.add(new Paragraph(" ",f6)); 
            //换行
            pdfDocument.add(new Paragraph("中国程序员工作时间调查报告", f10)); 
            //换行
            pdfDocument.add(new Paragraph(" ", f2));
            return true;
        }catch(FileNotFoundException de) {
            de.printStackTrace();
            System.err.println("pdf file: " + de.getMessage());
            return false;
        }catch(DocumentException de) {
            de.printStackTrace();
            System.err.println("document: " + de.getMessage());
            return false;
        }catch(IOException de) {
            de.printStackTrace();
            System.err.println("pdf font: " + de.getMessage());
            return false;
        }finally{
            //关闭PDF文档流,OutputStream文件输出流也将在PDF文档流关闭方法内部关闭
        	if(pdfDocument!=null){
        		pdfDocument.close();
        	}
        }        
    }
	
	/**
	 * 创建一份PDF文档,并把该文档设置成只读权限,且标注文档作者信息
	 * @param fullFilePath
	 */
	public boolean createReadOnlyPDFFileWithCreatorInfo(String fullFilePath){
        Document pdfDocument = new Document();
        try {
            //构建一个PDF文档输出流程
        	OutputStream pdfFileOutputStream = new FileOutputStream(new File(fullFilePath));
        	PdfWriter pdfWriter = PdfWriter.getInstance(pdfDocument,pdfFileOutputStream);
        	//PDF版本(默认1.4)
        	pdfWriter.setPdfVersion(PdfWriter.PDF_VERSION_1_4);
            //文档属性
            pdfDocument.addTitle("水果大王信息技术有限公司数据安全产品");
            pdfDocument.addAuthor("杭州水果大王信息技术有限公司");
            pdfDocument.addSubject("文件导出的信息安全管控");
            pdfDocument.addKeywords("文件导出,信息安全");//文档关键字信息
            pdfDocument.addCreator("水果大王文件取数系统");//应用程序名称
        	pdfWriter.setEncryption(null, null,PdfWriter.ALLOW_PRINTING, PdfWriter.STANDARD_ENCRYPTION_128);
        	//设置中文字体和字体样式
            BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);  
            Font f2 = new Font(bfChinese, 2, Font.NORMAL);
            Font f6 = new Font(bfChinese, 6, Font.NORMAL);
            Font f10 = new Font(bfChinese, 10, Font.NORMAL);
            Font f12 = new Font(bfChinese, 12, Font.BOLD);
            //打开PDF文件流
        	pdfDocument.open();
            //设置PDF文件正文内容
            pdfDocument.add(new Paragraph("中国程序员周报", f12)); 
            //换行
            pdfDocument.add(new Paragraph(" ",f6)); 
            //换行
            pdfDocument.add(new Paragraph("中国程序员工作时间调查报告", f10)); 
            //换行
            pdfDocument.add(new Paragraph(" ", f2));
            return true;
        }catch(FileNotFoundException de) {
            de.printStackTrace();
            System.err.println("pdf file: " + de.getMessage());
            return false;
        }catch(DocumentException de) {
            de.printStackTrace();
            System.err.println("document: " + de.getMessage());
            return false;
        }catch(IOException de) {
            de.printStackTrace();
            System.err.println("pdf font: " + de.getMessage());
            return false;
        }finally{
            //关闭PDF文档流,OutputStream文件输出流也将在PDF文档流关闭方法内部关闭
        	if(pdfDocument!=null){
        		pdfDocument.close();
        	}
        }        
    }
	
	/**
	 * 创建一份PDF文档,并把该文档设置成只读权限,且标注文档作者信息,并需要作者指定密码才能打开的文件
	 * @param fullFilePath
	 */
	public boolean createReadOnlyPDFFileWithCreatorPassword(String fullFilePath,String openPassword,String creatorPassword){
        Document pdfDocument = new Document();
        try {
            //构建一个PDF文档输出流程
        	OutputStream pdfFileOutputStream = new FileOutputStream(new File(fullFilePath));
        	PdfWriter pdfWriter = PdfWriter.getInstance(pdfDocument,pdfFileOutputStream);
        	//PDF版本(默认1.4)
        	pdfWriter.setPdfVersion(PdfWriter.PDF_VERSION_1_4);
            //文档属性
            pdfDocument.addTitle("水果大王信息技术有限公司数据安全产品");
            pdfDocument.addAuthor("杭州水果大王信息技术有限公司");
            pdfDocument.addSubject("文件导出的信息安全管控");
            pdfDocument.addKeywords("文件导出,信息安全");//文档关键字信息
            pdfDocument.addCreator("水果大王文件取数系统");//应用程序名称
        	pdfWriter.setEncryption(openPassword.getBytes(), creatorPassword.getBytes(),PdfWriter.ALLOW_PRINTING, PdfWriter.STANDARD_ENCRYPTION_128);
        	//设置中文字体和字体样式
            BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);  
            Font f2 = new Font(bfChinese, 2, Font.NORMAL);
            Font f6 = new Font(bfChinese, 6, Font.NORMAL);
            Font f10 = new Font(bfChinese, 10, Font.NORMAL);
            Font f12 = new Font(bfChinese, 12, Font.BOLD);
            //打开PDF文件流
        	pdfDocument.open();
            //设置PDF文件正文内容
            pdfDocument.add(new Paragraph("中国程序员周报", f12)); 
            //换行
            pdfDocument.add(new Paragraph(" ",f6)); 
            //换行
            pdfDocument.add(new Paragraph("中国程序员工作时间调查报告", f10)); 
            //换行
            pdfDocument.add(new Paragraph(" ", f2));
            return true;
        }catch(FileNotFoundException de) {
            de.printStackTrace();
            System.err.println("pdf file: " + de.getMessage());
            return false;
        }catch(DocumentException de) {
            de.printStackTrace();
            System.err.println("document: " + de.getMessage());
            return false;
        }catch(IOException de) {
            de.printStackTrace();
            System.err.println("pdf font: " + de.getMessage());
            return false;
        }finally{
            //关闭PDF文档流,OutputStream文件输出流也将在PDF文档流关闭方法内部关闭
        	if(pdfDocument!=null){
        		pdfDocument.close();
        	}
        }        
    }

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		PDFCreate1File pdfCreate1File = new PDFCreate1File();
		long startTime1 = System.currentTimeMillis();
		boolean result1 = pdfCreate1File.createPDFFile("D:/temp/pdftest/11helloword你好.pdf");
		long endTime1 = System.currentTimeMillis();
		System.out.println("pdf文档创建结果:" + result1+"。总计花费时间:"+((endTime1-startTime1)/1000)+"秒");
		System.out.println("--------------------------------------------------------------------------");
		long startTime2 = System.currentTimeMillis();
		boolean result2 = pdfCreate1File.createPDFFileWithCreatorInfo("D:/temp/pdftest/12数据安全管控产品白皮书.pdf");
		long endTime2 = System.currentTimeMillis();
		System.out.println("数据安全管控产品白皮书的pdf文档创建结果:" + result2+"。总计花费时间:"+((endTime2-startTime2)/1000)+"秒");
		System.out.println("--------------------------------------------------------------------------");
		long startTime3 = System.currentTimeMillis();
		boolean result3 = pdfCreate1File.createReadOnlyPDFFile("D:/temp/pdftest/13只读权限PDF文档.pdf");
		long endTime3 = System.currentTimeMillis();
		System.out.println("只读权限的pdf文档创建结果:" + result3+"。总计花费时间:"+((endTime3-startTime3)/1000)+"秒");
		System.out.println("--------------------------------------------------------------------------");
		long startTime4 = System.currentTimeMillis();
		boolean result4 = pdfCreate1File.createReadOnlyPDFFileWithCreatorInfo("D:/temp/pdftest/14只读权限并标注作者信息文档.pdf");
		long endTime4 = System.currentTimeMillis();
		System.out.println("只读权限并标注作者信息的pdf文档创建结果:" + result4+"。总计花费时间:"+((endTime4-startTime4)/1000)+"秒");
		System.out.println("--------------------------------------------------------------------------");
		long startTime5 = System.currentTimeMillis();
		boolean result5 = pdfCreate1File.createReadOnlyPDFFileWithCreatorPassword("D:/temp/pdftest/15只读权限并标注作者信息加密文档.pdf","123456","xuguo123");
		long endTime5 = System.currentTimeMillis();
		System.out.println("只读权限并标注作者信息的加密pdf文档创建结果:" + result5+"。总计花费时间:"+((endTime5-startTime5)/1000)+"秒");
	}
}
5
4
分享到:
评论

相关推荐

    利用itext操作pdf从数据库导出大量数据--汇总(一)

    这篇博客"利用iText操作PDF从数据库导出大量数据--汇总(一)"显然讨论了如何利用iText将数据库中的数据高效地导出到PDF文件中,这对于报告生成、数据分析或者报表制作等场景非常有用。 首先,我们需要了解iText的...

    利用itext操作pdf从数据库导出大量数据--功能汇总(一)

    标题 "利用itext操作pdf从数据库导出大量数据--功能汇总(一)" 提到的是一个关于使用iText库在Java环境中操作PDF文档,并从数据库中导出大量数据的实践教程。iText是一个流行的开源Java库,专门用于创建、修改和...

    利用itext操作pdf从数据库导出大量数据

    通过实践和调试,你可以掌握利用iText从数据库导出大量数据到PDF文档的技能,这在报表生成、数据导出等方面非常实用。 总之,iText是一个强大且灵活的工具,它使得在Java应用中处理PDF文档变得简单。结合数据库技术...

    java iText 实现从数据库中导出数据到已有的PDF模板

    Java中的iText库是一个强大的...总的来说,Java结合iText实现从数据库导出数据到PDF模板涉及了数据库操作、Java I/O、PDF处理和数据映射等多个技术点。理解并掌握这些技能,对于开发高效、灵活的数据导出功能至关重要。

    Struts2+IText动态导出PDF示例源码

    在这个"Struts2+IText动态导出PDF示例源码"项目中,开发者利用这两者结合,实现了在Web应用中动态生成PDF文件的功能。这在报表生成、合同制作、证书打印等场景中非常实用。 首先,Struts2作为控制器层框架,负责...

    itext生成pdf文件-表格

    在实际应用中,通常会从数据库或其他数据源动态生成表格内容。这可能涉及到遍历数据集,然后对每个数据项调用`addCell()`方法。此外,还可以使用`PdfPCell`的构造函数接收一个`Paragraph`对象,这样可以在单元格中...

    JAVA ITEXT 导出试卷

    开发者可能通过创建一个`PaperWriter`类,封装了试卷生成的逻辑,包括读取试题数据(可能是从数据库、CSV文件或XML文件中获取),然后使用iText将这些数据转换为PDF格式。`PaperWriter`可能包含了一系列方法,如`...

    springboot使用itext生成pdf并保存到本地

    本教程将探讨如何利用iText库在Spring Boot应用中从HTML页面生成PDF,并进行一系列的定制化操作,如添加页眉、页码、水印、目录以及二维码。 首先,iText是一个强大的Java库,专门用于创建和编辑PDF文档。它提供了...

    iText输出pdf表格

    iText是一款广泛使用的Java库,专门用于创建和编辑PDF文档。在处理PDF文档时,输出表格是一项常见的任务,尤其在报告、发票或数据分析等场景中。`iText`提供了强大的功能来实现这一需求,让我们深入了解一下如何使用...

    导出PDF (iText实现) PdfDownloadDS

    标题中的“导出PDF (iText实现) PdfDownloadDS”指的是使用iText库来生成PDF文档的示例或服务,可能是一个数据下载系统,其中“DS”可能代表“Download Service”。iText是一个流行的Java库,它允许开发人员创建、...

    itext-5.5.6

    7. **XML支持**:iText能够将XML数据直接转化为PDF,这对于需要从XML数据源生成报表的应用来说非常方便。 在实际应用中,开发者可以通过Maven或Gradle等构建工具将iText 5.5.6库引入项目。使用时,只需按照官方提供...

    利用iText在JSP中生成PDF报表.rar源码都有 和列子

    在JSP(JavaServer Pages)环境中,开发者经常使用iText来动态生成PDF报表,这在数据导出、报告生成或者电子发票等场景中非常常见。这个压缩包“利用iText在JSP中生成PDF报表.rar”提供了一个实例,帮助我们理解如何...

    itext PDF报表

    - 企业内部系统,如CRM或ERP,经常使用iText来导出用户界面的数据为PDF格式,便于打印和分享。 7. **学习资源** - iText官方文档提供了详细的API参考和示例代码,是学习iText的好起点。 - 书籍《iText in Action...

    PB数据窗口导出PDF并且合并到一个PDF文件中

    标题 "PB数据窗口导出PDF并且合并到一个PDF文件中" 涉及的主要知识点是使用PowerBuilder(PB)这个编程工具,对数据窗口对象进行操作,并将结果以PDF格式导出,最后实现多个PDF文件的合并。在这个过程中,我们不仅...

    Datawindow 导出到PDF文件

    它可以动态地从数据库中获取数据,支持多种数据源,如SQL Server、Oracle等,并提供了丰富的样式和格式设置选项,使用户可以创建复杂的报表和界面。 2. **PDF导出的功能**: 将Datawindow导出为PDF格式,主要是...

    java导出PDF文件的例子

    除了基本的文本输出,还可以直接从数据库导出数据到PDF。这通常涉及到查询数据库,将结果集转换成表格或其他格式,然后添加到PDF中。例如,可以使用JDBC连接数据库,获取数据,再通过` PdfPTable`对象显示数据。 ...

    itext导出pdf

    在标题中提到的"itext插件导出pdf文档"实际上是指使用IText库来编写程序,将数据或者内容输出为PDF格式的文件。 **IText的使用场景** 1. **报告生成**:IText非常适合用来生成动态报告,例如业务分析报告、财务...

    java导出pdf、加表格、加水印

    在Java开发中,导出PDF、添加表格以及加水印是常见的需求,这些功能可以用于创建报告、发票、证书等文档。PDF(Portable Document Format)是一种广泛应用的文档格式,能够跨平台保持一致的布局和样式。下面将详细...

Global site tag (gtag.js) - Google Analytics