1

我正在为一个项目使用 iText。我的程序应该从浏览器内部运行,我需要它将 html 文件转换为 pdf 文件。当我从 NetBeans 运行程序时,一切正常。我签署了我的 jar 并在浏览器中运行 Applet,然后我收到此错误:

Errorjava.security.AccessControlException: access denied ("java.lang.RuntimePermission" "getenv.windir")

为了这篇文章的目的,我制作了一个简单的 JApplet 代码,它有同样的问题:

public class RunApplet extends JApplet {

    @Override
    public void init() {
        this.add(new JLabel("This is a labe"));
        File f = new File("C:/ReportGen/data.html");
        File pdf = new File("C:/ReportGen/data.pdf");

        try {
            pdf.createNewFile();
            Document pdfDocument = new Document();
            PdfWriter writer = PdfWriter.getInstance(pdfDocument, new FileOutputStream(pdf));
            pdfDocument.open();

            XMLWorkerHelper worker = XMLWorkerHelper.getInstance();

            FontFactoryImp imp = new FontFactoryImp();
            imp.getFont("Arial");
            FontFactory.setFontImp(imp);

            worker.parseXHtml(writer, pdfDocument, new FileInputStream(f));

            pdfDocument.close();
            writer.close();
            this.add(new JLabel(f.getAbsolutePath()));

        } catch (Exception ex) {
            this.add(new JTextField("Error"+ex));
        }                       
    }
}

html文件已创建并且很好,但是当我创建pdf文件时出现异常并且pdf文件实际上已创建,但已损坏并且我无法打开它。在此先感谢您的时间。

4

1 回答 1

0

首先,我在您的问题中看到了这个错误:

Errorjava.security.AccessControlException: access denied ("java.lang.RuntimePermission" "getenv.windir")

您需要签署您的小程序才能访问您的文件系统。请参阅此链接链接。

其次,我尝试了以下代码:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;

import com.itextpdf.text.Document;
import com.itextpdf.text.pdf.PdfWriter;
import com.itextpdf.tool.xml.XMLWorkerHelper;

public class main {

    public static void main(String[] args) {
        File f = new File("C:/tmp/data.htm");

        File pdf = new File("C:/tmp/data.pdf");
        Document pdfDocument = null;
        PdfWriter pdfWriter = null;
        try {

            pdfDocument = new Document();
            pdfWriter = PdfWriter.getInstance(pdfDocument, new FileOutputStream(pdf));
            pdfDocument.open();

            XMLWorkerHelper.getInstance().parseXHtml(pdfWriter, pdfDocument,
                    new FileInputStream(f));
            pdfDocument.close();

        } catch (Exception ex) {
            ex.printStackTrace();
        }

    }
}

如果文件 data.htm(原始数据)是 htmlx,则工作正常。但如果 data.htm 不是 xml,我会收到此错误:

com.itextpdf.tool.xml.exceptions.RuntimeWorkerException: Invalid nested tag head found, expected closing tag meta.
    at com.itextpdf.tool.xml.XMLWorker.endElement(XMLWorker.java:134)
    at com.itextpdf.tool.xml.parser.XMLParser.endElement(XMLParser.java:395)
    at com.itextpdf.tool.xml.parser.state.ClosingTagState.process(ClosingTagState.java:70)
    at com.itextpdf.tool.xml.parser.XMLParser.parseWithReader(XMLParser.java:235)
    at com.itextpdf.tool.xml.parser.XMLParser.parse(XMLParser.java:213)
    at com.itextpdf.tool.xml.parser.XMLParser.parse(XMLParser.java:174)
    at com.itextpdf.tool.xml.XMLWorkerHelper.parseXHtml(XMLWorkerHelper.java:220)
    at com.itextpdf.tool.xml.XMLWorkerHelper.parseXHtml(XMLWorkerHelper.java:185)
    at main.main(main.java:44)

您可以尝试使用您的数据和此示例吗?不同之处在于我的示例不是小程序,而是独立的 Java。

问候

于 2012-07-25T12:29:46.427 回答