跳至頁尾內容
使用 IRONPDF

如何在不使用庫的情況下用 C# 將 HTML 轉換為 PDF

在 C# 中將 HTML 轉換為 PDF 時,開發人員可能會考慮使用原生.NET功能,而無需依賴外部程式庫。 雖然這種方法在某些情況下是可行的,但它本身也存在一些優點和挑戰。 本文將探討這個過程、優缺點,並討論為什麼像IronPDF這樣的函式庫可能是更好的選擇。

工作原理

使用內建的 .NET 工具,您可以透過渲染 HTML 內容並使用 WebBrowser 控制項和PrintDocument類別列印它來實現 HTML 到 PDF 的轉換。 以下是一個簡化的工作流程:

  1. 將 HTML 內容寫入臨時檔案。
  2. 將 HTML 載入到 WebBrowser 控制項中進行渲染。
  3. 使用 PrintDocument 類別建立輸出渲染內容的列印作業。

雖然這種方法避免了對外部的依賴,但它涉及使用底層組件和手動定義列印邏輯。

如果你想在不使用任何外部函式庫的情況下,用 C# 將 HTML 轉換為 PDF,你可以使用 .NET 內建功能,如 System.IO 和 System.Drawing.Printing 來渲染 HTML,然後建立 PDF。 以下是一個幫助您入門的基本範例:

如何在不使用庫的情況下用 C# 將 HTML 轉換為 PDF

如何在不使用庫的情況下使用 C# 將 HTML 轉換為 PDF:圖 1

using System;
using System.IO;
using System.Windows.Forms; // You need to add a reference to System.Windows.Forms
using System.Drawing.Printing;

class Program
{
    [STAThread] // Required for using WebBrowser control
    static void Main()
    {
        // HTML content to be converted
        string htmlContent = "<html><body><h1>Hello, World!</h1></body></html>";

        // Write HTML content to a temporary file
        string tempFilePath = Path.Combine(Path.GetTempPath(), "temp.html");
        File.WriteAllText(tempFilePath, htmlContent);

        // Initialize a WebBrowser to render HTML
        WebBrowser webBrowser = new WebBrowser();
        webBrowser.DocumentCompleted += (sender, e) => 
        {
            // Create a PrintDocument for the printing task
            PrintDocument printDoc = new PrintDocument();
            printDoc.PrintPage += (s, args) =>
            {
                // Render the HTML content onto the Graphics object of PrintPageEventArgs
                args.Graphics.DrawString(htmlContent, new Font("Arial", 12), Brushes.Black, new PointF(100, 100));
            };

            // Use a standard print controller for silent printing
            printDoc.PrintController = new StandardPrintController(); 

            // Trigger the printing process
            printDoc.Print(); 

            // Exit the application once printing is complete
            Application.ExitThread(); 
        };

        // Load the HTML file into the WebBrowser control
        webBrowser.Url = new Uri(tempFilePath);

        // Run the application, which processes events like HTML rendering
        Application.Run();
    }
}
using System;
using System.IO;
using System.Windows.Forms; // You need to add a reference to System.Windows.Forms
using System.Drawing.Printing;

class Program
{
    [STAThread] // Required for using WebBrowser control
    static void Main()
    {
        // HTML content to be converted
        string htmlContent = "<html><body><h1>Hello, World!</h1></body></html>";

        // Write HTML content to a temporary file
        string tempFilePath = Path.Combine(Path.GetTempPath(), "temp.html");
        File.WriteAllText(tempFilePath, htmlContent);

        // Initialize a WebBrowser to render HTML
        WebBrowser webBrowser = new WebBrowser();
        webBrowser.DocumentCompleted += (sender, e) => 
        {
            // Create a PrintDocument for the printing task
            PrintDocument printDoc = new PrintDocument();
            printDoc.PrintPage += (s, args) =>
            {
                // Render the HTML content onto the Graphics object of PrintPageEventArgs
                args.Graphics.DrawString(htmlContent, new Font("Arial", 12), Brushes.Black, new PointF(100, 100));
            };

            // Use a standard print controller for silent printing
            printDoc.PrintController = new StandardPrintController(); 

            // Trigger the printing process
            printDoc.Print(); 

            // Exit the application once printing is complete
            Application.ExitThread(); 
        };

        // Load the HTML file into the WebBrowser control
        webBrowser.Url = new Uri(tempFilePath);

        // Run the application, which processes events like HTML rendering
        Application.Run();
    }
}
$vbLabelText   $csharpLabel

程式碼解釋

  1. WebBrowser 控制項用於渲染 HTML。
  2. PrintDocument 類別用於定義列印行為。
  3. 此範例不會直接建立 PDF; 您需要對其進行擴展,以整合原始 PDF 建立邏輯,例如手動繪製文字和形狀或處理流程。

這種方法有其局限性,對於大型或樣式複雜的 HTML 文件來說可能會變得複雜。 如果你的使用情境允許,使用像 IronPDF 這樣的函式庫通常會更有效率、更豐富。

使用 .NET 內建功能的優缺點

優點

-無外部依賴:避免使用外部程式庫可以降低專案中管理第三方依賴的複雜性。 -免費:由於此方法僅使用原生 .NET 元件,因此無需支付許可費或額外費用。 -精細控制:您可以完全控制內容的渲染和列印方式,從而實現自訂處理。

缺點

-功能有限:內建的 .NET 工具缺乏準確渲染複雜 HTML、CSS 或 JavaScript 的功能。 可能不支援高階佈局、響應式設計或動態內容。 -實現耗時:您需要編寫自訂程式碼來處理渲染、分頁和 PDF 創建,這可能會導致更高的開發成本。 -可擴展性差:對於大規模或高效能應用,這種方法可能效率低下,容易出現瓶頸。 -不支援原生 PDF:工作流程不會直接建立 PDF; 您需要實作自訂邏輯,才能從列印輸出產生 PDF 檔案。

IronPDF簡介

如何在不使用庫的情況下使用 C# 將 HTML 轉換為 PDF:圖 2

IronPDF是一個 .NET 程式庫,它允許開發人員輕鬆地將 HTML 轉換為 PDF。 它支援多種功能,包括 CSS、JavaScript,甚至嵌入式圖片。 使用IronPDF ,您可以建立與 HTML 網頁外觀完全相同的 PDF 文件,確保格式之間的無縫過渡。 該程式庫對於需要動態生成 PDF 文件的 Web 應用程式尤其有用。

IronPDF允許開發人員將 PDF 功能無縫整合到 .NET 應用程式中,而無需手動管理 PDF 文件結構。 IronPDF利用基於 Chrome 的渲染引擎將 HTML 頁面(包括複雜的 CSS、JavaScript 和圖像)轉換為結構良好的 PDF 文件。 它可用於產生報告、發票、電子書或任何需要以 PDF 格式呈現的文件。

IronPDF 功能多樣,不僅可以渲染 PDF,還提供各種 PDF 操作選項,例如編輯、表單處理、加密等等。

IronPDF 的主要特點

  1. HTML 轉 PDF

    • HTML 渲染: IronPDF可以將 HTML 檔案格式的文件或網頁(包括具有 CSS、圖片和 JavaScript 的 HTML)直接轉換為 PDF 文件。 它也可以使用HTML模板進行轉換。 這非常適合從動態網頁內容產生 PDF 檔案。

    -支援現代 HTML/CSS: IronPDF 可處理現代 HTML5、CSS3 和 JavaScript,確保您的 Web 內容能夠準確地渲染為 PDF,並保留佈局、字體和互動元素。

    -進階渲染:它使用 Chrome 的渲染引擎(透過 Chromium)產生精確、高品質的 PDF,使其比許多其他 HTML 轉 PDF 庫更可靠。

    -網站 URL 轉 PDF: IronPDF可以接受網站的 URL 字串作為輸入,並將其轉換為 PDF。

2.自訂頁首和頁尾

IronPDF允許開發人員為 PDF 文件添加自訂頁首和頁腳,其中可以包含動態內容,例如頁碼、文件標題或自訂文字。

  • 頁首和頁尾可以新增到單一頁面,也可以作為整個文件中的一致元素。

3.支援PDF中的JavaScript

IronPDF 允許在生成 PDF 之前在 HTML 內容中執行 JavaScript。 這樣就可以在產生的 PDF 中實現動態內容渲染,例如表單計算或互動功能。

  • 當從動態網頁建立 PDF 或產生需要客戶端邏輯的報表時,JavaScript 就非常有用。

4.編輯現有PDF文件

IronPDF提供編輯現有 PDF 檔案的功能。 您可以修改現有 PDF 檔案中的文字、圖像,並新增註釋。 此功能可用於在文件中新增浮水印、新增簽名或更新 PDF 文件內的內容。

  • 文字擷取和修改功能可讓您以程式設計方式操作 PDF 文件中的內容。

5.合併和拆分 PDF

IronPDF可讓您將多個 PDF 文件合併到一個文件中,或將一個大的 PDF 文件分割成更小的文件。 這非常適合需要將文件合併或分解成更易於管理的部分的工作流程。

6.對互動表單的支持

  • 您可以使用 IronPDF 建立、填寫和操作 PDF 表單。 它為互動式表單(如文字欄位、複選框和單選按鈕)提供全面支持,並允許您預先填入表單資料。

    IronPDF還允許從現有 PDF 中提取表單數據,從而可以輕鬆地以程式設計方式讀取和處理表單數據。

7.頁面操作

IronPDF提供了多種方法來操作 PDF 文件中的單一頁面,例如旋轉頁面、刪除頁面或重新排列頁面。 這有助於自訂最終文件的結構。

  • 您也可以為現有 PDF 新增頁面,或刪除不需要的頁面。

8.安全性和加密

IronPDF可讓您對 PDF 套用密碼保護和加密,確保您的文件安全無虞。 您可以設定使用者權限,例如禁止列印、複製或編輯 PDF 檔案。

  • 也可以為 PDF 檔案添加數位簽章以驗證其真實性,為敏感文件提供一層安全性。

9.水印和品牌推廣

使用 IronPDF 可以輕鬆地為 PDF 文件添加浮水印。 您可以將文字或圖片疊加為浮水印到頁面上,從而防止未經授權的複製或散佈您的文件。

  • 此功能通常用於品牌推廣,其中徽標或文字需要在文件的所有頁面上保持一致的顯示效果。

10.文字和圖像提取

[IronPDF](https://ironpdf.com)允許從 PDF 文件中提取文字和圖像,使開發人員能夠提取資料進行處理或重複使用。

- 這對於需要分析 PDF 內容、從表單中提取資訊或檢索影像以供進一步使用的場景非常有用。
  1. Unicode 和多語言支持

    IronPDF具有強大的 Unicode 支持,這意味著它可以處理國際字元和字體,使其成為生成多種語言 PDF 的理想選擇。

    • 它支援中文、阿拉伯語、俄語等多種語言,可以建立多語言 PDF 文件。

12.性能優化

[IronPDF](https://ironpdf.com)針對效能進行了最佳化,能夠處理大型 PDF 文件和大量請求。 該庫確保即使在處理大型資料集或影像時,PDF 生成也能保持快速且有效率。
  1. API 和開發者友善工具

    IronPDF配備了全面且易於使用的 API。 開發者可以透過簡單的方法呼叫快速上手,執行複雜的任務。

    • API 文件齊全,可以輕鬆地將 IronPDF 整合到任何 C# 或 .NET 應用程式中。

14.跨平台支持

[IronPDF](https://ironpdf.com)具有跨平台相容性,這意味著它可以在 Windows 和 Linux 環境下使用,讓您在不同的作業系統上產生和操作 PDF 檔案。

如何使用 IronPDF 將 HTML 轉換為 PDF

using IronPdf;

class Program
{
    static void Main()
    {
        // Specify license key
        License.LicenseKey = "Your Key";

        // Create a new ChromePdfRenderer object
        var Renderer = new ChromePdfRenderer();

        // Define the HTML string to be converted
        string htmlContent = "<html><body><h1>IronPDF: Easily Convert HTML to PDF</h1></body></html>";

        // Convert the HTML string to a PDF document
        var document = Renderer.RenderHtmlAsPdf(htmlContent);

        // Save the PDF document to a file
        document.SaveAs("html2Pdf.pdf");
    }
}
using IronPdf;

class Program
{
    static void Main()
    {
        // Specify license key
        License.LicenseKey = "Your Key";

        // Create a new ChromePdfRenderer object
        var Renderer = new ChromePdfRenderer();

        // Define the HTML string to be converted
        string htmlContent = "<html><body><h1>IronPDF: Easily Convert HTML to PDF</h1></body></html>";

        // Convert the HTML string to a PDF document
        var document = Renderer.RenderHtmlAsPdf(htmlContent);

        // Save the PDF document to a file
        document.SaveAs("html2Pdf.pdf");
    }
}
$vbLabelText   $csharpLabel

程式碼片段解釋

1. 許可證密鑰設置

程式首先設定IronPDF 許可證密鑰,這是解鎖庫的全部功能所必需的。

2. 建立渲染器

初始化 ChromePdfRenderer 實例。 此元件負責將 HTML 內容轉換為PDF 文檔,作為原始 HTML 和最終輸出之間的橋樑。

3. 定義 HTML 內容

建立一個名為htmlContent字串變量,用於儲存將要轉換為 PDF 的HTML 結構。 在這個例子中,它包含一個簡單的標題。

4. 將 HTML 轉換為 PDF

在 ChromePdfRenderer 實例上呼叫RenderHtmlAsPdf()方法,並將 HTML 字串傳遞為輸入。 此功能處理內容並將其轉換為PDF 文件

5. 儲存PDF文件

最後,使用SaveAs()方法將產生的 PDF 檔案儲存到名為"html2Pdf.pdf"的檔案中,並將其儲存在磁碟上以便將來存取。

輸出

如何在不使用庫的情況下使用 C# 將 HTML 轉換為 PDF:圖 3

授權資訊(提供試用版)

IronPDF 需要有效的許可證金鑰才能使用全部功能。 您可以從官方網站取得試用許可證。使用 IronPDF 庫之前,請如下設定許可證密鑰:

IronPdf.License.LicenseKey = "your key";
IronPdf.License.LicenseKey = "your key";
$vbLabelText   $csharpLabel

這樣可以確保圖書館不受限制地運作。

結論

雖然使用 .NET 內建功能將 HTML 轉換為 PDF 對於簡單的用例來說可能是一個可行的解決方案,但這通常需要付出大量努力,並且缺乏現代功能。 相比之下, IronPDF等庫提供了強大的功能、更快的開發速度以及對高級 HTML 渲染的支持,使其成為大多數開發人員的首選。 最終決定取決於您的專案需求、預算和開發優先順序。

常見問題解答

使用 .NET 原生功能進行 HTML 轉 PDF 轉換有哪些優點?

使用 .NET 原生功能可以避免外部依賴和額外成本,從而對渲染和列印過程進行高度控制。

開發者在不使用函式庫的情況下,用 C# 將 HTML 轉換為 PDF 時可能會面臨哪些挑戰?

挑戰包括內建方法的功能有限、處理樣式化或大型 HTML 文件的複雜性,以及在建立 PDF 時需要額外的自訂邏輯。

開發者如何在不使用第三方函式庫的情況下,使用 .NET 將 HTML 轉換為 PDF?

開發人員可以將 HTML 內容寫入臨時文件,使用 WebBrowser 控制項渲染它,並使用 PrintDocument 類別建立用於 PDF 轉換的列印作業。

.NET 函式庫有哪些特性使其成為 HTML 轉 PDF 的更佳選擇?

像 IronPDF 這樣的 .NET 庫為現代 HTML、CSS、JavaScript 和圖像提供了廣泛的支持,以及 PDF 編輯、合併、分割、表單處理和安全功能。

為什麼 IronPDF 可能比使用原生 .NET 方法更受歡迎?

IronPDF 透過 JavaScript 執行、自訂標頭以及高效處理動態和複雜的 Web 內容等功能簡化了轉換過程,提供了一個強大且可擴展的解決方案。

IronPDF 能否處理 PDF 中的互動式表單和複雜版面?

是的,IronPDF 支援互動式表單,並且能夠準確地渲染複雜的佈局,因此適合從 Web 內容建立專業品質的 PDF。

IronPDF 是否針對大量 PDF 產生進行了最佳化?

是的,IronPDF 旨在有效處理大型 PDF 文件和大量請求,使其成為大規模應用的理想選擇。

IronPDF是否提供跨平台支援?

IronPDF 與包括 Windows 和 Linux 在內的多種作業系統相容,為各種開發環境提供了靈活性。

IronPDF 如何確保 PDF 文件的安全性?

IronPDF 提供密碼保護、加密、使用者權限和數位簽章等選項,以保護 PDF 文件的安全。

要使用 IronPDF 的所有功能,需要哪些條件?

要解鎖 IronPDF 的全部功能,需要一個有效的許可證密鑰。開發者可以從官方網站取得試用許可證。

IronPDF 是否支援 .NET 10?在 .NET 10 專案中使用 IronPDF 時是否有任何特殊注意事項?

是的,IronPDF 完全相容於 .NET 10——它以原生模式支援 .NET 10(及更早版本),包括其所有現代 API,無需特殊配置或變通方法。您可以透過 NuGet 安裝它,並像在早期 .NET 版本中一樣使用基於 Chrome 的渲染、JS 執行和響應式 CSS 等功能。

使用 .NET 原生功能將 HTML 轉換為 PDF 時,以 .NET 10 為目標平台與以更早的 .NET 版本為目標平台有何不同?

面向 .NET 10 通常能帶來更好的效能、更完善的 API 和更可預測的行為——尤其是在桌面或 Windows Forms 環境中。然而,手動渲染(例如使用 WebBrowser 和 PrintDocument)的限制依然存在。與針對 .NET 10 最佳化的 IronPDF 不同,原生方法缺乏對現代 HTML/CSS/JS 的支持,需要更多自訂工作才能處理各種內容。

柯蒂斯·週
技術撰稿人

Curtis Chau擁有卡爾頓大學電腦科學學士學位,專長於前端開發,精通Node.js、TypeScript、JavaScript和React。他熱衷於打造直覺美觀的使用者介面,喜歡使用現代框架,並擅長撰寫結構清晰、視覺效果出色的使用者手冊。

除了開發工作之外,柯蒂斯對物聯網 (IoT) 也抱有濃厚的興趣,致力於探索硬體和軟體整合的創新方法。閒暇時,他喜歡玩遊戲和製作 Discord 機器人,將他對科技的熱愛與創造力結合。