Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/335.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/image/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 带有base64图像的HTML到PDF引发FileNotFoundException_Java_Image_Pdf_Base64_Itext - Fatal编程技术网

Java 带有base64图像的HTML到PDF引发FileNotFoundException

Java 带有base64图像的HTML到PDF引发FileNotFoundException,java,image,pdf,base64,itext,Java,Image,Pdf,Base64,Itext,我使用的是itextpdf-5.0.6.jar(Java8),当我尝试导出带有base64图像标记的html代码时,我得到了一个文件未找到异常 如果我删除图像标签,一切都很好 我发现很少有关于重写图像标记处理器的解决方案,但大多数都是旧的,与5.0.6版本不兼容 以下是我发送的HTML: "<!doctype html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n

我使用的是itextpdf-5.0.6.jar(Java8),当我尝试导出带有base64图像标记的html代码时,我得到了一个文件未找到异常

如果我删除图像标签,一切都很好

我发现很少有关于重写图像标记处理器的解决方案,但大多数都是旧的,与5.0.6版本不兼容

以下是我发送的HTML:

    "<!doctype html>\n<html lang=\"en\">\n<head>\n    
<meta charset=\"UTF-8\">\n    
<title>Test PDF</title>\n</head>\n<body>\n\n
<div class=\"pdf-header\">\n\n 
  <img src=\"\">     \n\n\n</div>\n\n<div class=\"main\">\n<div class=\"canvas\">\nHellow world</div></div></body>\n</html>"
任何帮助都将受到感谢
谢谢

请停止使用
HTMLWorker
,正如StackOverflow上多次重复的那样,
HTMLWorker
类早已被放弃,取而代之的是XML Worker。我们不会投资进一步开发
HTMLWorker
,因此使用它是一个非常糟糕的选择。请切换到XML Worker

同时升级到最新的iText版本,您使用的版本是最早的,在过去的4年中,许多错误已经修复。确保您拥有具有相同版本号的iText jar和XML Worker jar

Base64图像还不受支持,但我已经为您提供了一个非常简单的概念证明,展示了添加对此类图像的支持是多么容易。请看一看示例和生成的PDF:

要实现这一点,您需要编写
ImageProvider
接口的实现。为此,我扩展了
AbstractImageProvider
类:

class Base64ImageProvider extends AbstractImageProvider {

    @Override
    public Image retrieve(String src) {
        int pos = src.indexOf("base64,");
        try {
            if (src.startsWith("data") && pos > 0) {
                byte[] img = Base64.decode(src.substring(pos + 7));
                return Image.getInstance(img);
            }
            else {
                return Image.getInstance(src);
            }
        } catch (BadElementException ex) {
            return null;
        } catch (IOException ex) {
            return null;
        }
    }

    @Override
    public String getImageRootPath() {
        return null;
    }
}
如您所见,我检查通过
img
标记的
src
属性传递给XML Worker的内容中是否存在
“base64”
。如果该
字符串
存在,我将解码该
“base64”
之后的任何内容,并返回使用结果字节创建的
图像
对象


一旦有了这个
ImageProvider
实现,只需将它传递给XML Worker即可。

解决方案按预期工作!谢谢。布鲁诺,有没有忽略坏html的选项?我首先得到了不包含closer的元素的错误,然后是-我可以忽略这个验证吗?我使用JSoup修复HTML:我发送这个HTML:但它没有选择嵌入的css,我必须将css与HTML分开吗?我必须支持这种请求方式,因此可能需要将html字符串“剪切”为块(html/css)。XML Worker(不是
HTMLWorker
)支持css,但显然并非所有css属性都受支持,原因有二:(1)PDF与HTML非常不同,HTML中存在的一些属性对于使用iText创建的PDF永远不会起作用,(2)。我们只实现了付费的CSS属性(许多人使用iText和XML Worker而不付费)。我只是一个人,我绝不是销售人员。您应该在此处发布您的问题:
class Base64ImageProvider extends AbstractImageProvider {

    @Override
    public Image retrieve(String src) {
        int pos = src.indexOf("base64,");
        try {
            if (src.startsWith("data") && pos > 0) {
                byte[] img = Base64.decode(src.substring(pos + 7));
                return Image.getInstance(img);
            }
            else {
                return Image.getInstance(src);
            }
        } catch (BadElementException ex) {
            return null;
        } catch (IOException ex) {
            return null;
        }
    }

    @Override
    public String getImageRootPath() {
        return null;
    }
}