動態(tài)jsp頁面轉(zhuǎn)PDF輸出到頁面的實現(xiàn)方法
更新時間:2016年10月30日 17:19:54 作者:Iran_1112
最近遇到了很多坑,今天小編抽點時間給大家介紹下動態(tài)jsp頁面轉(zhuǎn)PDF輸出到頁面的實現(xiàn)方法,感興趣的朋友一起看看吧
最近工作中遇到不少問題??偨Y(jié)一下。這段代碼主要功能是將一個生成JSP頁面轉(zhuǎn)發(fā)成PDF輸出到頁面
需要利用ITEXT
String html = ServletUtils.forward(request,response,"/WEB-INF/jsp/depot/print/jhd.jsp"); //轉(zhuǎn)發(fā)請求到j(luò)sp,返回解析之后的內(nèi)容而不是輸出到瀏覽器 //System.out.println(html); byte[] pdf = PDFUtils.html2pdf(html); response.setContentType("application/pdf"); response.setHeader("Content-Length",String.valueOf(pdf.length)); response.setHeader("Connection","keep-alive"); response.setHeader("Accept-Ranges","none"); response.setHeader("X-Frame-Options","DENY"); OutputStream out = response.getOutputStream(); out.write(pdf); out.flush(); public class ServletUtils { /** * 此forward方法執(zhí)行完畢之后不會輸出內(nèi)容到瀏覽器,而是把輸出到字節(jié)流,最后以字符串的形式返回 * @param request * @param response * @param src * @return */ public static String forward(HttpServletRequest request, HttpServletResponse response, String src) { try{ /* ↓↓↓↓↓重新構(gòu)造response,修改response中的輸出流對象,使其輸出到字節(jié)數(shù)組↓↓↓↓↓ */ final ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); final ServletOutputStream servletOuputStream = new ServletOutputStream() { @Override public void write(int b) throws IOException { byteArrayOutputStream.write(b); } @Override public boolean isReady() { return false; } @Override public void setWriteListener(WriteListener writeListener) { } }; final PrintWriter printWriter = new PrintWriter(new OutputStreamWriter(byteArrayOutputStream, "UTF-8")); response = new HttpServletResponseWrapper(response) { public ServletOutputStream getOutputStream() { return servletOuputStream; } public PrintWriter getWriter() { return printWriter; } }; /* ↑↑↑↑↑↑重新構(gòu)造response,修改response中的輸出流對象,使其輸出到字節(jié)數(shù)組↑↑↑↑↑↑ */ //執(zhí)行forward操作 request.getRequestDispatcher(src).forward(request,response); //把字節(jié)流中的內(nèi)容太轉(zhuǎn)為字符串 return new String(byteArrayOutputStream.toByteArray(),"utf-8"); } catch (Exception e){ throw new RuntimeException(e); } } } import com.itextpdf.text.*; import com.itextpdf.text.pdf.PdfWriter; import com.itextpdf.tool.xml.Pipeline; import com.itextpdf.tool.xml.XMLWorker; import com.itextpdf.tool.xml.XMLWorkerFontProvider; import com.itextpdf.tool.xml.XMLWorkerHelper; import com.itextpdf.tool.xml.exceptions.CssResolverException; import com.itextpdf.tool.xml.html.CssAppliers; import com.itextpdf.tool.xml.html.CssAppliersImpl; import com.itextpdf.tool.xml.html.Tags; import com.itextpdf.tool.xml.parser.XMLParser; import com.itextpdf.tool.xml.pipeline.css.CSSResolver; import com.itextpdf.tool.xml.pipeline.css.CssResolverPipeline; import com.itextpdf.tool.xml.pipeline.end.PdfWriterPipeline; import com.itextpdf.tool.xml.pipeline.html.HtmlPipeline; import com.itextpdf.tool.xml.pipeline.html.HtmlPipelineContext; import java.io.*; /** * pdf工具類 */ public class PDFUtils { /** * 把html轉(zhuǎn)換成pdf,以字節(jié)數(shù)組的形式返回pdf文件 * @param html * @return pdf字節(jié)數(shù)組 * @throws IOException * @throws DocumentException * @throws CssResolverException */ public static byte[] html2pdf(String html) throws IOException, DocumentException,CssResolverException { Document document = new Document(PageSize.A4); ByteArrayOutputStream os = new ByteArrayOutputStream(); PdfWriter writer = PdfWriter.getInstance(document,os); document.open(); XMLWorkerFontProvider fontProvider = new XMLWorkerFontProvider(){ @Override public Font getFont(String fontname, String encoding, float size, int style) { return super.getFont(fontname == null ? "宋體" : fontname, encoding, size, style); } }; fontProvider.addFontSubstitute("lowagie", "garamond"); fontProvider.setUseUnicode(true); //使用我們的字體提供器,并將其設(shè)置為unicode字體樣式 CssAppliers cssAppliers = new CssAppliersImpl(fontProvider); HtmlPipelineContext htmlContext = new HtmlPipelineContext(cssAppliers); htmlContext.setTagFactory(Tags.getHtmlTagProcessorFactory()); CSSResolver cssResolver = XMLWorkerHelper.getInstance().getDefaultCssResolver(true); Pipeline<?> pipeline = new CssResolverPipeline(cssResolver,new HtmlPipeline(htmlContext, new PdfWriterPipeline(document,writer))); XMLWorker worker = new XMLWorker(pipeline, true); XMLParser p = new XMLParser(worker); p.parse(new InputStreamReader(new ByteArrayInputStream(html.getBytes("gbk")))); document.close(); return os.toByteArray(); } }
以上所述是小編給大家介紹的動態(tài)jsp頁面轉(zhuǎn)PDF輸出到頁面的實現(xiàn)方法,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!
相關(guān)文章
JSP動態(tài)網(wǎng)站開發(fā)環(huán)境配置詳細(xì)方法
Sun推出的JSP(Java Server Pages)是一種執(zhí)行于服務(wù)器端的動態(tài)網(wǎng)頁開發(fā)技術(shù),它基于Java技術(shù)。執(zhí)行JSP時需要在Web服務(wù)器上架設(shè)一個編譯JSP網(wǎng)頁的引擎。配置 JSP 環(huán)境可以有多種途徑,但主要工作就是安裝和配置Web服務(wù)器和JSP引擎。2008-09-09JSP開發(fā)中hibernate框架的常用檢索方式總結(jié)
這篇文章主要介紹了JSP開發(fā)中hibernate框架的常用檢索方式總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-04-04