English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
В последнее время в работе встретилось множество проблем. Подведем итоги. Основная функция этого кода - преобразование генерируемой JSP страницы в PDF и вывод ее на страницу
Необходимо использовать ITEXT
String html = ServletUtils.forward(request,response,"/WEB-INF/jsp/depot/print/jhd.jsp"); // Перенаправление запроса к jsp, возвращение обработанного содержимого, а не вывода в браузер //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 не будет выводить содержимое в браузер, а вместо этого отправит его в поток байт и в конечном итоге вернет его в виде строки * @param request * @param response * @param src * @return */ public static String forward(HttpServletRequest request, HttpServletResponse response, String src) { try{ /* ↓↓↓↓↓重新构造response,修改response中的输出流对象,使其输出到字节数组↓↓↓↓↓ */ final ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); final ServletOutputStream servletOutputStream = 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 servletOutputStream; {} public PrintWriter getWriter() { return printWriter; {} }; /* ↑↑↑↑↑↑重新构造response,修改response中的输出流对象,使其输出到字节数组↑↑↑↑↑↑ */ //执行转发操作 request.getRequestDispatcher(src).forward(request, response); //转换字节流内容为字符串 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 в pdf и вернуть файл pdf в виде массива байт * @param html * @return массив байт pdf * @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 ? "Songti" : fontname, encoding, size, style); {} }; fontProvider.addFontSubstitute("lowagie", "garamond"); fontProvider.setUseUnicode(true); //Использование нашего провайдера шрифтов и установление его в качестве стиля 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(); {} {}
Указанные выше методы,介绍的动态jsp页面转换为PDF и вывод на страницу, надеюсь, помогут вам. Если у вас есть какие-либо вопросы, пожалуйста, оставьте комментарий, и я отвечу вам своевременно!
Заявление: содержимое этой статьи взято из Интернета, авторские права принадлежат соответствующему автору. Контент был предоставлен пользователями Интернета, сайт не имеет права собственности на него, не был отредактирован вручную и не несет ответственности за него. Если вы обнаружите подозрительное содержимое, пожалуйста, отправьте письмо по адресу: notice#oldtoolbag.com (во время отправки письма замените # на @) для жалоб,并提供 соответствующие доказательства. В случае подтверждения, сайт немедленно удалят подозрительное содержимое.