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