5

現在、MVC4 で RazorPDF を使用して PDF を組み立てて表示していますが、ビューを返すと同時に PDF ファイルをファイル システムに保存したいと考えています。

コントローラー アクションの次のコード行は、ビューを呼び出しています。

return new PdfResult(claims, "PDF");
4

2 に答える 2

4

RazorPDF render メソッドのコードベースを変更することで、最終的に pdf をディレクトリ システムに書き込むことができました。Rendor メソッドは、応答ストリームに関連付けられている PdfWriter オブジェクトを作成します。

        // Associate output with response stream
        var pdfWriter = PdfWriter.GetInstance(document, viewContext.HttpContext.Response.OutputStream);
        pdfWriter.CloseStream = false;

解決策は、以下に示すように、FileStream オブジェクトに関連付けられた別の PdfWriter オブジェクトを作成することでした。

        // Create the pdf file in the directory system
        var fileStream = new FileStream(myPdfFilePath, FileMode.Create);
        var pdfWriter2 = PdfWriter.GetInstance(document, fileStream);

次に、オブジェクトを閉じました。

        fileStream.Close();

        pdfWriter.Close();
        pdfWriter2.Close();

基本的に、RazorPDF の PdfResult クラスと PdfView クラスを自分のプロジェクトに組み込み、コードを大幅に変更する必要がありました。その理由は、pdf をユーザーに送信する電子メール クラスへの呼び出しも組み込む必要があったためです。

完全な Render メソッドを以下に示します。

    public void Render(ViewContext viewContext, TextWriter writer)
    {
        // generate view into string
        var sb = new System.Text.StringBuilder();
        TextWriter tw = new System.IO.StringWriter(sb);
        myResult.View.Render(viewContext, tw);
        var resultCache = sb.ToString();

        // detect itext (or html) format of response
        XmlParser parser;
        using (var reader = GetXmlReader(resultCache))
        {
            while (reader.Read() && reader.NodeType != XmlNodeType.Element)
            {
                // no-op
            }

            if (reader.NodeType == XmlNodeType.Element && reader.Name == "itext")
                parser = new XmlParser();
            else
                parser = new HtmlParser();
        }

        // Create a document processing context
        var document = new Document();
        document.Open();

        // Associate output with response stream
        var pdfWriter = PdfWriter.GetInstance(document, viewContext.HttpContext.Response.OutputStream);
        pdfWriter.CloseStream = false;

        // Create the pdf file in the directory system
        var fileStream = new FileStream(myPdfFilePath, FileMode.Create);
        var pdfWriter2 = PdfWriter.GetInstance(document, fileStream);

        // this is as close as we can get to being "success" before writing output
        // so set the content type now
        viewContext.HttpContext.Response.ContentType = "application/pdf";

        // parse memory through document into output
        using (var reader = GetXmlReader(resultCache))
        {
            parser.Go(document, reader);
        }

        fileStream.Close();

        // Send an email to the claimant
        Thread.Sleep(100);
        if (File.Exists(myPdfFilePath))
        {
            var subject = "PDF Documents";

            var body = Config.GetContent(ContentParams.CLAIM_DOCUMENT_EMAIL_BODY_TEXT);

            bool success;
            string errorMessage;

            Email.Send(myEmailAddress, subject, body, out success, out errorMessage, myPdfFilePath);
        }

        pdfWriter.Close();
        pdfWriter2.Close();

    }

この機能が何らかの方法で現在の RazorPDF プロジェクトに組み込まれるとよいでしょう。

于 2013-08-30T17:45:58.417 に答える