iTextSharp无法将HTML转换为PDF。这不是它的设计目的。它旨在从头开始创建PDF文件,而不是在各种格式之间转换为PDF。如果您想将HTML转换为PDF,您可以使用基于iText的{{3}}库。我有flying-saucer关于如何使用blogged在.NET中完成此操作。
所以你的控制器动作可能看起来像是:
[HttpPost]
public FileStreamResult GeneratePDF(string id)
{
ReportClass report = reportingAgent.GetReportById(id);
return PdfResult(report.Html);
}
其中PdfResult可以是自定义操作结果,采用原始HTML并将PDF输出到响应流中:
public class PdfResult : ActionResult
{
private readonly string _html;
public PdfResult(string html)
{
_html = html;
}
public override void ExecuteResult(ControllerContext context)
{
var response = context.HttpContext.Response;
response.ContentType = "application/pdf";
var builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
using (var bais = new ByteArrayInputStream(Encoding.UTF8.GetBytes(_html)))
using (var bao = new ByteArrayOutputStream())
{
var doc = builder.parse(bais);
var renderer = new ITextRenderer();
renderer.setDocument(doc, null);
renderer.layout();
renderer.createPDF(bao);
var buffer = bao.toByteArray();
response.OutputStream.Write(buffer, 0, buffer.Length);
}
}
}