Решение HTML в PDF (обработка содержимого, верхних и нижних колонтитулов) - PullRequest
0 голосов
/ 30 сентября 2011

Я пытаюсь создать «отчет», создав PDF на основе HTML.

Сначала я просто попытался записать необработанный кодированный HTML в документ, а затем распечатать этот документ с использованием Javascript. Однако это не давало мне никакого контроля над заголовками и колонтитулами.

Я попытался использовать элементы thead и tfoot, которые довольно хорошо работали в большинстве браузеров, однако я не смог получить форматирование, которое искал.

В настоящее время - я пытаюсь работать над решением на стороне сервера, используя iTextSharp в MVC3, однако я немного растерялся относительно того, что делать дальше, так как не работал с iTextSharp.

Ввод и описание выхода:

При создании отчета будет использовано 4 элемента:

  • Содержание отчета (который в настоящее время кодируется в формате HTML, так как я не уверен, изменит ли декодирование какое-либо форматирование)
  • Заголовок отчета (будет просто именем сгенерированного PDF)
  • Заголовок отчета (будет отображаться в верхнем левом углу каждой страницы)
  • Нижний колонтитул отчета (будет отображаться в левом нижнем углу каждой страницы)

Действие контроллера:

//This will be accessed by a jQuery Post
[HttpPost]
public FileStreamResult GeneratePDF(string id)
{
      //Grab Report Item
      ReportClass report = reportingAgent.GetReportById(id);

      Document doc = new Document();

      //Do I need to decode the HTML or is it possible to use the encoded HTML?

      //Adding Headers / Footers

      //Best method of returning the PDF?
}

1 Ответ

2 голосов
/ 30 сентября 2011

iTextSharp не может конвертировать HTML в PDF. Это не то, что было задумано. Он был разработан для создания PDF-файлов с нуля, а не для преобразования различных форматов в PDF. Если вы хотите конвертировать HTML в PDF, вы можете, например, использовать библиотеку летающая тарелка , основанную на iText. Я написал в блоге о том, как это можно сделать в .NET, используя IKVM.NET байт-код компилятор (ikvmc.exe) .

Таким образом, действие вашего контроллера может выглядеть примерно так:

[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);
        }
    }
}
...