gpt4 book ai didi

java - 如何在将 HTML 呈现为 PDF 时在 Flying-Saucer 中设置基本 url?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:22:49 24 4
gpt4 key购买 nike

我正在尝试使用 Flying-Saucer 将 HTML 页面呈现为 PDF。 HTML 在内存中创建并作为

传递给渲染器
renderer.setDocumentFromString(new String(htmlByteArray));

问题是我有 <img src="images.jpg"/>在 HTML 中,它不会在最终的 HTML 中呈现。图片位于 resources包中的文件夹。

我尝试使用以下设置基本 url,但没有成功:

ITextRenderer renderer = new ITextRenderer();renderer.getSharedContext().setBaseURL("com/org/tools/designer/resources/");System.out.println(renderer.getSharedContext().getBaseURL());renderer.setDocumentFromString(new String(htmlByteArray));renderer.layout();renderer.createPDF(os);

最佳答案

FS 中有一个非常酷的接口(interface),称为 UserAgentCallback,它允许您获取所有自己的资源。对于查看此内容的其他人,您可以相应地设置您的网址:

renderer.getSharedContext().getUserAgentCallback().setBaseURL("url_to_resources");

但是这里有一个特殊情况,您的 jar 文件中嵌入了需要特殊方式访问的资源。您可以实现自己的 UserAgentCallback 这是我为您编写的一个小例子。 (我没有对此进行测试,因此您可能需要稍微调试一下)。

此代码位扩展了 ITextUserAgent,这样您只需覆盖 getBinaryResource 方法并将其余部分留给库。如果这不奏效,您可以考虑在 UserAgentCallback 上实现完整的实现。

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;

import org.xhtmlrenderer.pdf.ITextOutputDevice;
import org.xhtmlrenderer.pdf.ITextUserAgent;

public class PackageUserAgentCallback extends ITextUserAgent {
private Class resourceClass;

public PackageUserAgentCallback(ITextOutputDevice outputDevice, Class resourceClass) {
super(outputDevice);
this.resourceClass = resourceClass;
}

@Override
public byte[] getBinaryResource(String uri) {
try {
InputStream in = resourceClass.getResourceAsStream(uri);
ByteArrayOutputStream out = new ByteArrayOutputStream();
int numRead;
byte [] buffer = new byte[256];
while((numRead = in.read(buffer)) != -1) {
out.write(buffer, 0, numRead);
}
return out.toByteArray();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}

}

然后您可以将其设置为您的UserAgentCallback,这将通过您的PackageUserAgentCallback 引导所有资源请求

ITextRenderer renderer = new ITextRenderer();
renderer.getSharedContext().setUserAgentCallback(
new PackageUserAgentCallback(renderer.getOutputDevice(), Resources.class));
System.out.println(renderer.getSharedContext().getBaseURL());
renderer.setDocumentFromString(new String(htmlByteArray));

renderer.layout();
renderer.createPDF(os);

关于java - 如何在将 HTML 呈现为 PDF 时在 Flying-Saucer 中设置基本 url?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8401298/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com