13

这是我调查的第二天没有结果。至少现在,我可以问一些非常具体的问题。

我正在尝试使用iText编写一个有效的 HTML 代码,该代码在 PDF 文件中包含一些非拉丁字符,更具体地说,使用来自Flying Saucer的ITextRenderer

我的简短示例/代码首先使用此值初始化字符串变量 doc:

String doc = "<?xml version=\"1.0\" encoding=\"UTF-8\"?><html xmlns=\"http://www.w3.org/1999/xhtml\" lang=\"en\">"
            + "<body>Some greek characters: Καλημέρα Some greek characters"
            + "</body></html>";

这是我用于调试目的的代码。我将此字符串保存到 HTML 文件,然后通过浏览器打开它,以仔细检查 HTML 内容是否有效,并且我仍然可以读取希腊字符:

//write for debugging purposes in an html file
File newTextFile = new File("C:/work/test.html");
FileWriter fw = new FileWriter(newTextFile);
fw.write(doc);
fw.close();

下一步是尝试将此值写入 PDF 文件。这是我的代码:

ITextRenderer renderer = new ITextRenderer();
    //add some fonts - if paths are not right, an exception will be thrown
    renderer.getFontResolver().addFont("c:/work/fonts/TIMES.TTF", BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
    renderer.getFontResolver().addFont("c:/work/fonts/TIMESBD.TTF", BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
    renderer.getFontResolver().addFont("c:/work/fonts/TIMESBI.TTF", BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
    renderer.getFontResolver().addFont("c:/work/fonts/TIMESI.TTF", BaseFont.IDENTITY_H, BaseFont.EMBEDDED);


    final DocumentBuilderFactory documentBuilderFactory = DocumentBuilderFactory
            .newInstance();
    documentBuilderFactory.setValidating(false);
    DocumentBuilder builder = documentBuilderFactory.newDocumentBuilder();
    builder.setEntityResolver(FSEntityResolver.instance());
    org.w3c.dom.Document document = builder.parse(new ByteArrayInputStream(
            doc.toString().getBytes("UTF-8")));

    renderer.setDocument(document, null);
    renderer.layout();
    renderer.createPDF(os);

我的代码的最终结果是:

在 HTML 文件中我得到:一些希腊字符:Καλημέρα 一些希腊字符(预期)

在 PDF 文件中,我得到:一些希腊字符:一些希腊字符意外- 希腊字符被忽略!!)

依赖项:

  • java版本“1.6.0_27”

  • itext-2.0.8.jar

  • de.huxhorn.lilith.3rdparty.flyingsaucer.core-renderer-8Pre2.jar

我也尝试过更多的字体,但我想我的问题与使用错误的字体无关。任何帮助都非常受欢迎。

谢谢

4

3 回答 3

11

我来自捷克共和国,对我们的国家标志也有同样的问题!经过一番搜索,我设法用这个解决方案解决了它。

特别是(您已经拥有):

renderer
    .getFontResolver()
    .addFont(fonts.get(i).getFile().getPath(), 
             BaseFont.IDENTITY_H, 
             BaseFont.NOT_EMBEDDED);

然后是 CSS 中的重要部分:

* {
  font-family: Verdana;
/*  font-family: Times New Roman; - alternative. Without ""! */
}

在我看来,没有那个 css,你的字体就不会被使用。当我从 CSS 中删除这些行时,编码再次被破坏。

希望这会有所帮助!

于 2012-07-09T16:20:17.657 回答
9

在您的 HTML 中添加如下内容:

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv='Content-Type' content='text/html; charset=UTF-8'/>
        <style type='text/css'> 
            * { font-family: 'Arial Unicode MS'; }
        </style>
    </head>
    <body>
        <span>Some text with šđčćž characters</span>
    </body>
</html>

然后在java代码中将FontResolver添加到ITextRenderer:

ITextRenderer renderer = new ITextRenderer();
renderer.getFontResolver().addFont("fonts/ARIALUNI.TTF", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);

非常适合克罗地亚语角色

用于生成 PDF 的 jar 是:

core-renderer.jar
iText-2.0.8.jar
于 2013-12-02T10:01:55.917 回答
0

iText从包含utf-8内容的 html 内容中读取标题信息。在带有编码的 html 代码中
添加meta标签,然后运行以生成 PDF 并检查结果。 content-typeutf-8 charsetiText

<?xml version="1.0" encoding="UTF-8"?>
<html xmlns="http://www.w3.org/1999/xhtml" lang="en">
 <head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 </head>
 <body>
  Some greek characters: Καλημέρα Some greek characters
 </body>
</html>

更新
如果上述方法不起作用,请参阅http://www.manning.com/lowagie2/iText2E_MEAP_CH02.pdfENCODING VERSUS THE DEFAULT CHARSET USED BY THE JVM上发布的文档

于 2012-04-20T19:29:50.453 回答