1
我正在开发MVC应用程序,并且我有XMLWorker和ImageProvider的问题。我的图像不会以PDF格式显示,它会显示它收到的html。ITextSharp XMLWorker未显示图像
下面是代码:
var bytes = Encoding.UTF8.GetBytes(html);
string cssPath = HttpContext.Current.Server.MapPath("~/Content");
using (MemoryStream input = new MemoryStream(bytes))
{
MemoryStream output = new MemoryStream();
using (Document pdfDoc = new Document(PageSize.LETTER, 50, 50, 50, 50))
{
using (PdfWriter pdfWrt = PdfWriter.GetInstance(pdfDoc, output))
{
pdfWrt.CloseStream = false;
pdfWrt.PageEvent = new PdfWriterEvents("watermark");
pdfDoc.Open();
HtmlPipelineContext context = new HtmlPipelineContext(null);
context.SetTagFactory(iTextSharp.tool.xml.html.Tags.GetHtmlTagProcessorFactory());
context.SetImageProvider(new MyImageProvider());
var cssResolver = XMLWorkerHelper.GetInstance().GetDefaultCssResolver(true);
cssResolver.AddCssFile(cssPath + "\\main.css", true);
IPipeline pipeline = new CssResolverPipeline(cssResolver, new HtmlPipeline(context, new PdfWriterPipeline(pdfDoc, pdfWrt)));
var worker = new XMLWorker(pipeline, true);
var parser = new XMLParser();
parser.AddListener(worker);
using (TextReader sr = new StringReader(html))
{
parser.Parse(sr);
}
pdfDoc.Close();
byte[] test = output.GetBuffer();
File.WriteAllBytes(HttpContext.Current.Server.MapPath("~/Content/PDFs/test.pdf"), test);
}
}
}
这里是我的ImageProvider实现:
public class MyImageProvider : AbstractImageProvider
{
public override string GetImageRootPath()
{
return HttpContext.Current.Server.MapPath("~/Content/Images");
}
}
任何想法?
为了帮助您进行调试,而不是直接解析到'Document'对象,请尝试写入自定义的'IElementHandler',以便您可以遍历每个对象。请参阅[第二个和第三个代码块](http://stackoverflow.com/a/24498296/231316)了解如何执行此操作。此外,而不是'output.GetBuffer();'总是使用'output.ToArray();'。前者实际上包括未初始化(垃圾)字节,这些字节会在某些常见情况下破坏您的PDF。 – 2014-09-10 14:44:16
谢谢你的回复。我已经尝试使用自定义IElementHandler,但它没有工作。无论如何,我可能会从HTML中删除图像,并将它们创建为pdf图像 – user1797770 2014-09-11 08:03:15
我建议仅使用IElementHandler,以便您可以在for循环中放置断点并查看iTextSharp实际上在做什么。 – 2014-09-11 13:16:30