Преобразование HTML в PDF - ошибка «Не удается загрузить ресурс XML» - PullRequest
7 голосов
/ 23 февраля 2012

Я пытаюсь конвертировать строгий XHTML в PDF, используя летающую тарелку и iText.Я проверил XHTML и пути ввода и вывода файла являются точными.Я не имею ни малейшего понятия, почему это вызывает исключение в строке renderer.setDocument ("file: / c: /example/First.html").

Мой класс:

package flyingsaucerpdf;
    import java.io.*;
    import org.xhtmlrenderer.pdf.ITextRenderer;
    import com.lowagie.text.DocumentException;

    public class FirstDoc {
     public static void main(String[] args) throws IOException, DocumentException
         {
                 String outputFile = "results/firstdoc.pdf";
                 OutputStream os = new FileOutputStream(outputFile);
                 ITextRenderer renderer = new ITextRenderer();
             try
             {
                 renderer.setDocument("file:/c:/example/First.html");
             }
             catch( Exception e )
             {
                 System.out.println("Me not create file. Error:"+e.getMessage());
             }
             renderer.layout();
             renderer.createPDF(os);

             os.close();
         }

    }

Мое исключение:

ОШИБКА: '' Я не создаю файл.Ошибка: не удается загрузить ресурс XML (с использованием преобразователя TRaX).java.lang.NullPointerException

Исключение в "основном" потокеITextRenderer.java:152) at flyingsaucerpdf.FirstDoc.main (FirstDoc.java:31)

Мой XHTML:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Insert title here</title>
<style type="text/css"> b { color: green; } </style>
</head>
<body>
<p>
<b>Greetings Earthlings!</b>
We've come for your Java.
</p>
</body>
</html>

Любая помощь?

1 Ответ

2 голосов
/ 22 мая 2012

Ваша виртуальная машина в сети? Возможно, что средство визуализации / анализатор пытается загрузить связанные ресурсы, такие как

http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd

, которые необходимы для обеспечения правильности предоставленного вами xml (xhtml).

В сервлете я делаю следующее, что, кажется, работает (некоторые онлайн-ресурсы доступны в моей файловой системе, потому что у сервера нет подключения к Интернету):

final DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
builder.setEntityResolver(new EntityResolver() {
  @Override
  public InputSource resolveEntity(String publicId, String systemId)
      throws SAXException, IOException {
    if (systemId.contains("xhtml1-transitional.dtd")) {
      return new InputSource(new FileReader(realPath + "/WEB-INF/dtd/xhtml1-transitional.dtd"));
    } else if (systemId.contains("xhtml-lat1.ent")) {
      return new InputSource(new FileReader(realPath + "/WEB-INF/dtd/xhtml-lat1.ent"));
    } else if (systemId.contains("xhtml-symbol.ent")) {
      return new InputSource(new FileReader(realPath + "/WEB-INF/dtd/xhtml-symbol.ent"));
    } else if (systemId.contains("xhtml-special.ent")) {
      return new InputSource(new FileReader(realPath + "/WEB-INF/dtd/xhtml-special.ent"));
    } else {
      return null;
    }
  }
});
final ByteArrayInputStream inputStream = new ByteArrayInputStream(html.getBytes("UTF-8"));
final Document doc = builder.parse(inputStream);
inputStream.close();
final ITextRenderer renderer = new ITextRenderer(26f * 4f / 3f, 26);
renderer.setDocument(doc, request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort());
renderer.layout();

Это в основном устанавливает DocumentBuilder, а затем анализирует мой документ (который имеет формат String и представлен переменной html )

...