Text Control與IronPDF:技術比較指南
當.NET開發人員評估PDF生成程式庫時,兩個解決方案經常在企業討論中出現:TX Text Control和IronPDF。 雖然兩者都能產生PDF輸出,但它們代表了根本不同的架構哲學。 這篇技術比較檢視了這兩個程式庫,以協助架構師和開發人員對他們的.NET應用程式做出明智的決策。
理解TX Text Control
TX Text Control是一個全面的文件編輯元件,強調DOCX編輯功能與嵌入式UI控制項。 PDF生成作為其廣泛文件處理架構中的次要功能存在。 該平台提供廣泛的文件編輯功能,使其適合需要豐富文字編輯介面的應用程式。
然而,這種全面性帶來了一些開發團隊應慎重評估的考量:
- 昂貴的授權:TX Text Control採用商業授權,每位開發者的起始費用為$3,398+,需要每年40%的強制性續訂才能維持更新訪問
- PDF作為次要功能:核心架構以字處理為優先,而PDF生成則被視為附加功能
- 已知的硬體問題:已記錄的Intel Iris Xe Graphics渲染錯誤影響第11代Intel處理器,需要註冊表解決方法
- 過多的依賴:包含可能不需要的文件編輯UI元件,對專注於PDF的工作流程而言
- 複雜的API:需要ServerTextControl上下文管理和選擇模型模式
了解IronPDF
IronPDF採取根本不同的方法,主要關注PDF生成,不層疊UI組件或DOCX編輯工具。 該程式庫以其精簡、量身訂製的設計脫穎而出,特別優化於PDF生成和操控,使其成為高效的PDF優先架構工具。
IronPDF的關鍵特點包括:
- PDF優先架構:由頭開始設計用於PDF生成,提供強大的文件創建和渲染能力
- Chromium渲染引擎:利用現代HTML5和CSS3標準,具備完整的JavaScript執行支援
- 成本效益:一次性授權模型消除持續的訂閱費用
- 穩定性證明:在各類硬體配置中記錄的可靠性,避免平臺特定的渲染問題
- 簡單整合:不需上下文管理或複雜的初始化模式
價格比較
TextControl和IronPDF之間的授權結構可能隨著時間的推移顯示出顯著的成本差異:
| 方面 | TX Text Control | IronPDF |
|---|---|---|
| 基本授權 | 每位開發者$3,398+ | $2,998 每位開發者一次性 |
| 年度續訂 | 40% 強制性 | 可選支援 |
| 團隊 4人(第1年) | ~$6,749 | ~$2,996 |
| 總共3年的成本 | 每位開發者$5,750+ | $2,998 每位開發者 |
| UI元件 | 綁定(潛在的膨脹) | 只專注於PDF |
| 伺服器運行時間 | 額外的授權 | 包括在內 |
功能比較
以下表格強調了TextControl和IronPDF之間在關鍵維度上的技術差異:
| 功能 | TX Text Control | IronPDF |
|---|---|---|
| 主要專注 | DOCX編輯 | PDF生成 |
| PDF品質 | 基本的,附加特徵 | 高,核心功能 |
| HTML到PDF | 是(次要) | 是(主要) |
| CSS支持 | 有限 | 完整的CSS3 |
| JavaScript 執行 | 有限 | 完整的ES2024 |
| URL到PDF | 複雜的設置需求 | 原生支持 |
| 標頭/頁腳 | 複雜的API | 簡單的基於HTML |
| 郵件合併 | 專有系統 | HTML範本 |
| PDF/A合規性 | 有 | 有 |
| 密碼保護 | 有 | 有 |
| 數位簽名 | 有 | 有 |
| 合併PDF | 有限 | 支持 |
| 分割PDF | 有限 | 支持 |
| 水印 | 複雜的實施 | 簡單的HTML/CSS |
| 硬體相容性 | 已知的Intel Iris問題 | 在所有裝置上穩定 |
| 上下文管理 | 必需 | 不需要 |
| 跨平臺 | 專注於Windows | 有 |
API架構差異
TextControl和IronPDF之間一個重要的區別在於他們的API設計理念和初始化模式。
TextControl方法
TextControl需要通過ServerTextControl類顯式上下文管理。 每次操作必須在調用using塊內發生:
// NuGet: Install-Package TXTextControl.Server
using TXTextControl;
using System.IO;
namespace TextControlExample
{
class Program
{
static void Main(string[] args)
{
using (ServerTextControl textControl = new ServerTextControl())
{
textControl.Create();
string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
textControl.Load(html, StreamType.HTMLFormat);
textControl.Save("output.pdf", StreamType.AdobePDF);
}
}
}
}// NuGet: Install-Package TXTextControl.Server
using TXTextControl;
using System.IO;
namespace TextControlExample
{
class Program
{
static void Main(string[] args)
{
using (ServerTextControl textControl = new ServerTextControl())
{
textControl.Create();
string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
textControl.Load(html, StreamType.HTMLFormat);
textControl.Save("output.pdf", StreamType.AdobePDF);
}
}
}
}Imports TXTextControl
Imports System.IO
Namespace TextControlExample
Class Program
Shared Sub Main(ByVal args As String())
Using textControl As New ServerTextControl()
textControl.Create()
Dim html As String = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>"
textControl.Load(html, StreamType.HTMLFormat)
textControl.Save("output.pdf", StreamType.AdobePDF)
End Using
End Sub
End Class
End Namespace此模式需要了解TextControl特定類別、流類型以及上下文生命周期。
IronPDF方法
IronPDF完全消除了上下文管理。 <a href="ChromePdfRenderer" target="_blank">https://ironpdf.com/object-reference/api/IronPdf.ChromePdfRenderer.html">ChromePdfRenderer類提供了一個無狀態API,開發者可以立即使用:
// NuGet: Install-Package IronPdf
using IronPdf;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
}
}
}// NuGet: Install-Package IronPdf
using IronPdf;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
}
}
}Imports IronPdf
Namespace IronPdfExample
Class Program
Shared Sub Main(ByVal args As String())
Dim renderer = New ChromePdfRenderer()
Dim html As String = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>"
Dim pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs("output.pdf")
End Sub
End Class
End Namespace有關HTML轉換功能的全面指南,請參見HTML到PDF教程。
API對映參考
評估從TextControl轉到IronPDF的團隊會發現此對照表對理解概念等效性很有幫助:
| TX Text Control | IronPDF |
|---|---|
ServerTextControl.Create() | new ChromePdfRenderer() |
tx.Load(html, StreamType.HTMLFormat) | renderer.RenderHtmlAsPdf(html) |
tx.Load(url, StreamType.HTMLFormat) | renderer.RenderUrlAsPdf(url) |
tx.Save(path, StreamType.AdobePDF) | pdf.SaveAs(path) |
SaveSettings.PDFAConformance | RenderingOptions.PdfAFormat |
DocumentServer.MailMerge | HTML範本 + Razor |
DocumentTarget.HeadersAndFooters | HtmlHeaderFooter |
LoadSettings | RenderingOptions |
StreamType.AdobePDF | 默認輸出 |
合併PDF文件
文件合併是一個常見要求,兩個程式庫之間的實施複雜性不同。
TextControl實施
TextControl需要按順序加載文件,並顯式追加模式標誌:
// NuGet: Install-Package TXTextControl.Server
using TXTextControl;
using System.IO;
namespace TextControlExample
{
class Program
{
static void Main(string[] args)
{
using (ServerTextControl textControl = new ServerTextControl())
{
textControl.Create();
byte[] pdf1 = File.ReadAllBytes("document1.pdf");
textControl.Load(pdf1, StreamType.AdobePDF);
byte[] pdf2 = File.ReadAllBytes("document2.pdf");
textControl.Load(pdf2, StreamType.AdobePDF, LoadAppendMode.Append);
textControl.Save("merged.pdf", StreamType.AdobePDF);
}
}
}
}// NuGet: Install-Package TXTextControl.Server
using TXTextControl;
using System.IO;
namespace TextControlExample
{
class Program
{
static void Main(string[] args)
{
using (ServerTextControl textControl = new ServerTextControl())
{
textControl.Create();
byte[] pdf1 = File.ReadAllBytes("document1.pdf");
textControl.Load(pdf1, StreamType.AdobePDF);
byte[] pdf2 = File.ReadAllBytes("document2.pdf");
textControl.Load(pdf2, StreamType.AdobePDF, LoadAppendMode.Append);
textControl.Save("merged.pdf", StreamType.AdobePDF);
}
}
}
}Imports TXTextControl
Imports System.IO
Namespace TextControlExample
Class Program
Shared Sub Main(ByVal args As String())
Using textControl As New ServerTextControl()
textControl.Create()
Dim pdf1 As Byte() = File.ReadAllBytes("document1.pdf")
textControl.Load(pdf1, StreamType.AdobePDF)
Dim pdf2 As Byte() = File.ReadAllBytes("document2.pdf")
textControl.Load(pdf2, StreamType.AdobePDF, LoadAppendMode.Append)
textControl.Save("merged.pdf", StreamType.AdobePDF)
End Using
End Sub
End Class
End NamespaceIronPDF實現
IronPDF提供了一個專用的靜態方法來合併,接受多個文件:
// NuGet: Install-Package IronPdf
using IronPdf;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var pdf1 = PdfDocument.FromFile("document1.pdf");
var pdf2 = PdfDocument.FromFile("document2.pdf");
var merged = PdfDocument.Merge(pdf1, pdf2);
merged.SaveAs("merged.pdf");
}
}
}// NuGet: Install-Package IronPdf
using IronPdf;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var pdf1 = PdfDocument.FromFile("document1.pdf");
var pdf2 = PdfDocument.FromFile("document2.pdf");
var merged = PdfDocument.Merge(pdf1, pdf2);
merged.SaveAs("merged.pdf");
}
}
}Imports IronPdf
Namespace IronPdfExample
Class Program
Shared Sub Main(ByVal args As String())
Dim pdf1 = PdfDocument.FromFile("document1.pdf")
Dim pdf2 = PdfDocument.FromFile("document2.pdf")
Dim merged = PdfDocument.Merge(pdf1, pdf2)
merged.SaveAs("merged.pdf")
End Sub
End Class
End NamespacePdfDocument.Merge方法接受任意數量的文件,並返回一個新的合併PDF,而不需上下文管理或手動處理字節陣列。
頁眉、頁腳和頁碼
添加具有動態頁碼的頁首和頁尾顯示出顯著的API複雜性差異。
TextControl實施
TextControl需要基於部分的頁首/頁尾操控,並明確類型聲明:
// NuGet: Install-Package TXTextControl.Server
using TXTextControl;
using System.IO;
namespace TextControlExample
{
class Program
{
static void Main(string[] args)
{
using (ServerTextControl textControl = new ServerTextControl())
{
textControl.Create();
string html = "<html><body><h1>Document Content</h1><p>Main body text.</p></body></html>";
textControl.Load(html, StreamType.HTMLFormat);
HeaderFooter header = new HeaderFooter(HeaderFooterType.Header);
header.Text = "Document Header";
textControl.Sections[0].HeadersAndFooters.Add(header);
HeaderFooter footer = new HeaderFooter(HeaderFooterType.Footer);
footer.Text = "Page {page} of {numpages}";
textControl.Sections[0].HeadersAndFooters.Add(footer);
textControl.Save("output.pdf", StreamType.AdobePDF);
}
}
}
}// NuGet: Install-Package TXTextControl.Server
using TXTextControl;
using System.IO;
namespace TextControlExample
{
class Program
{
static void Main(string[] args)
{
using (ServerTextControl textControl = new ServerTextControl())
{
textControl.Create();
string html = "<html><body><h1>Document Content</h1><p>Main body text.</p></body></html>";
textControl.Load(html, StreamType.HTMLFormat);
HeaderFooter header = new HeaderFooter(HeaderFooterType.Header);
header.Text = "Document Header";
textControl.Sections[0].HeadersAndFooters.Add(header);
HeaderFooter footer = new HeaderFooter(HeaderFooterType.Footer);
footer.Text = "Page {page} of {numpages}";
textControl.Sections[0].HeadersAndFooters.Add(footer);
textControl.Save("output.pdf", StreamType.AdobePDF);
}
}
}
}Imports TXTextControl
Imports System.IO
Namespace TextControlExample
Class Program
Shared Sub Main(ByVal args As String())
Using textControl As New ServerTextControl()
textControl.Create()
Dim html As String = "<html><body><h1>Document Content</h1><p>Main body text.</p></body></html>"
textControl.Load(html, StreamType.HTMLFormat)
Dim header As New HeaderFooter(HeaderFooterType.Header)
header.Text = "Document Header"
textControl.Sections(0).HeadersAndFooters.Add(header)
Dim footer As New HeaderFooter(HeaderFooterType.Footer)
footer.Text = "Page {page} of {numpages}"
textControl.Sections(0).HeadersAndFooters.Add(footer)
textControl.Save("output.pdf", StreamType.AdobePDF)
End Using
End Sub
End Class
End NamespaceIronPDF實現
IronPDF提供流線型的方法來添加基於文字的頁首和頁尾:
// NuGet: Install-Package IronPdf
using IronPdf;
using IronPdf.Rendering;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
string html = "<html><body><h1>Document Content</h1><p>Main body text.</p></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.AddTextHeader("Document Header");
pdf.AddTextFooter("Page {page} of {total-pages}");
pdf.SaveAs("output.pdf");
}
}
}// NuGet: Install-Package IronPdf
using IronPdf;
using IronPdf.Rendering;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
string html = "<html><body><h1>Document Content</h1><p>Main body text.</p></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.AddTextHeader("Document Header");
pdf.AddTextFooter("Page {page} of {total-pages}");
pdf.SaveAs("output.pdf");
}
}
}Imports IronPdf
Imports IronPdf.Rendering
Namespace IronPdfExample
Class Program
Shared Sub Main(args As String())
Dim renderer As New ChromePdfRenderer()
Dim html As String = "<html><body><h1>Document Content</h1><p>Main body text.</p></body></html>"
Dim pdf = renderer.RenderHtmlAsPdf(html)
pdf.AddTextHeader("Document Header")
pdf.AddTextFooter("Page {page} of {total-pages}")
pdf.SaveAs("output.pdf")
End Sub
End Class
End Namespace對於更複雜的頁首設計,IronPDF還支持HtmlHeaderFooter類,接受完整的HTML和CSS樣式:
renderer.RenderingOptions.HtmlHeader = new HtmlHeaderFooter
{
HtmlFragment = @"
<div style='width: 100%; text-align: center; font-size: 12pt;'>
Company Report
</div>",
MaxHeight = 30
};
renderer.RenderingOptions.HtmlFooter = new HtmlHeaderFooter
{
HtmlFragment = @"
<div style='width: 100%; text-align: right; font-size: 10pt;'>
Page {page} of {total-pages}
</div>",
MaxHeight = 25
};renderer.RenderingOptions.HtmlHeader = new HtmlHeaderFooter
{
HtmlFragment = @"
<div style='width: 100%; text-align: center; font-size: 12pt;'>
Company Report
</div>",
MaxHeight = 30
};
renderer.RenderingOptions.HtmlFooter = new HtmlHeaderFooter
{
HtmlFragment = @"
<div style='width: 100%; text-align: right; font-size: 10pt;'>
Page {page} of {total-pages}
</div>",
MaxHeight = 25
};renderer.RenderingOptions.HtmlHeader = New HtmlHeaderFooter With {
.HtmlFragment = "
<div style='width: 100%; text-align: center; font-size: 12pt;'>
Company Report
</div>",
.MaxHeight = 30
}
renderer.RenderingOptions.HtmlFooter = New HtmlHeaderFooter With {
.HtmlFragment = "
<div style='width: 100%; text-align: right; font-size: 10pt;'>
Page {page} of {total-pages}
</div>",
.MaxHeight = 25
}URL到PDF的轉換
將在線網頁轉換為PDF顯示出每個程式庫在處理網路內容方面的架構差異。
TextControl方法
TextControl需要通過其HTML格式處理程式手動載入URL,僅提供有限的CSS和JavaScript支持:
using (ServerTextControl tx = new ServerTextControl())
{
tx.Create();
LoadSettings loadSettings = new LoadSettings();
loadSettings.ApplicationFieldFormat = ApplicationFieldFormat.MSWord;
tx.Load("https://example.com/invoice", StreamType.HTMLFormat, loadSettings);
SaveSettings saveSettings = new SaveSettings();
saveSettings.PDFAConformance = PDFAConformance.PDFa1b;
tx.Save("output.pdf", StreamType.AdobePDF, saveSettings);
}using (ServerTextControl tx = new ServerTextControl())
{
tx.Create();
LoadSettings loadSettings = new LoadSettings();
loadSettings.ApplicationFieldFormat = ApplicationFieldFormat.MSWord;
tx.Load("https://example.com/invoice", StreamType.HTMLFormat, loadSettings);
SaveSettings saveSettings = new SaveSettings();
saveSettings.PDFAConformance = PDFAConformance.PDFa1b;
tx.Save("output.pdf", StreamType.AdobePDF, saveSettings);
}Imports ServerTextControlNamespace
Using tx As New ServerTextControl()
tx.Create()
Dim loadSettings As New LoadSettings()
loadSettings.ApplicationFieldFormat = ApplicationFieldFormat.MSWord
tx.Load("https://example.com/invoice", StreamType.HTMLFormat, loadSettings)
Dim saveSettings As New SaveSettings()
saveSettings.PDFAConformance = PDFAConformance.PDFa1b
tx.Save("output.pdf", StreamType.AdobePDF, saveSettings)
End UsingIronPDF方法
IronPDF通過其Chromium引擎提供原生的URL渲染,執行JavaScript並應用所有樣式:
var renderer = new ChromePdfRenderer();
// PDF/A compliance - simple property
renderer.RenderingOptions.PdfAFormat = PdfAVersions.PdfA1B;
var pdf = renderer.RenderUrlAsPdf("https://example.com/invoice");
pdf.SaveAs("output.pdf");var renderer = new ChromePdfRenderer();
// PDF/A compliance - simple property
renderer.RenderingOptions.PdfAFormat = PdfAVersions.PdfA1B;
var pdf = renderer.RenderUrlAsPdf("https://example.com/invoice");
pdf.SaveAs("output.pdf");Dim renderer = New ChromePdfRenderer()
' PDF/A compliance - simple property
renderer.RenderingOptions.PdfAFormat = PdfAVersions.PdfA1B
Dim pdf = renderer.RenderUrlAsPdf("https://example.com/invoice")
pdf.SaveAs("output.pdf")RenderUrlAsPdf方法捕獲完整的渲染頁面,包括動態生成的內容,使其對於使用React、Angular或Vue.js等框架建立的現代網頁應用程序非常理想。
頁面設置和配置
配置頁面尺寸、邊距和方向顯示了文件設置方法的不同。
TextControl實施
TextControl使用基於部分的頁面設置,測量單位為TWIPS:
using (ServerTextControl tx = new ServerTextControl())
{
tx.Create();
tx.Load(html, StreamType.HTMLFormat);
// Complex page settings through sections
foreach (Section section in tx.Sections)
{
section.Format.PageSize = PageSize.A4;
section.Format.PageMargins = new PageMargins(
1440, 1440, 1440, 1440); // TWIPS
section.Format.Landscape = true;
}
tx.Save("output.pdf", StreamType.AdobePDF);
}using (ServerTextControl tx = new ServerTextControl())
{
tx.Create();
tx.Load(html, StreamType.HTMLFormat);
// Complex page settings through sections
foreach (Section section in tx.Sections)
{
section.Format.PageSize = PageSize.A4;
section.Format.PageMargins = new PageMargins(
1440, 1440, 1440, 1440); // TWIPS
section.Format.Landscape = true;
}
tx.Save("output.pdf", StreamType.AdobePDF);
}Imports TXTextControl
Using tx As New ServerTextControl()
tx.Create()
tx.Load(html, StreamType.HTMLFormat)
' Complex page settings through sections
For Each section As Section In tx.Sections
section.Format.PageSize = PageSize.A4
section.Format.PageMargins = New PageMargins(1440, 1440, 1440, 1440) ' TWIPS
section.Format.Landscape = True
Next
tx.Save("output.pdf", StreamType.AdobePDF)
End UsingIronPDF實現
IronPDF在RenderingOptions中集中頁面設置,使用直觀的毫米為基準的測量:
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Landscape;
renderer.RenderingOptions.MarginTop = 25; // mm
renderer.RenderingOptions.MarginBottom = 25;
renderer.RenderingOptions.MarginLeft = 25;
renderer.RenderingOptions.MarginRight = 25;
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Landscape;
renderer.RenderingOptions.MarginTop = 25; // mm
renderer.RenderingOptions.MarginBottom = 25;
renderer.RenderingOptions.MarginLeft = 25;
renderer.RenderingOptions.MarginRight = 25;
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");Dim renderer = New ChromePdfRenderer()
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Landscape
renderer.RenderingOptions.MarginTop = 25 ' mm
renderer.RenderingOptions.MarginBottom = 25
renderer.RenderingOptions.MarginLeft = 25
renderer.RenderingOptions.MarginRight = 25
Dim pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs("output.pdf")密碼保護和安全性
兩個程式庫都支持PDF安全功能,但具備不同的API模式。
TextControl實施
using (ServerTextControl tx = new ServerTextControl())
{
tx.Create();
tx.Load(html, StreamType.HTMLFormat);
SaveSettings saveSettings = new SaveSettings();
saveSettings.UserPassword = "user123";
saveSettings.MasterPassword = "owner456";
tx.Save("protected.pdf", StreamType.AdobePDF, saveSettings);
}using (ServerTextControl tx = new ServerTextControl())
{
tx.Create();
tx.Load(html, StreamType.HTMLFormat);
SaveSettings saveSettings = new SaveSettings();
saveSettings.UserPassword = "user123";
saveSettings.MasterPassword = "owner456";
tx.Save("protected.pdf", StreamType.AdobePDF, saveSettings);
}Imports ServerTextControlNamespace
Using tx As New ServerTextControl()
tx.Create()
tx.Load(html, StreamType.HTMLFormat)
Dim saveSettings As New SaveSettings()
saveSettings.UserPassword = "user123"
saveSettings.MasterPassword = "owner456"
tx.Save("protected.pdf", StreamType.AdobePDF, saveSettings)
End UsingIronPDF實現
IronPDF通過SecuritySettings屬性提供細分的安全控控:
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SecuritySettings.UserPassword = "user123";
pdf.SecuritySettings.OwnerPassword = "owner456";
pdf.SecuritySettings.AllowUserCopyPasteContent = false;
pdf.SecuritySettings.AllowUserPrinting = PdfPrintSecurity.FullPrintRights;
pdf.SaveAs("protected.pdf");var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SecuritySettings.UserPassword = "user123";
pdf.SecuritySettings.OwnerPassword = "owner456";
pdf.SecuritySettings.AllowUserCopyPasteContent = false;
pdf.SecuritySettings.AllowUserPrinting = PdfPrintSecurity.FullPrintRights;
pdf.SaveAs("protected.pdf");Dim renderer As New ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf(html)
pdf.SecuritySettings.UserPassword = "user123"
pdf.SecuritySettings.OwnerPassword = "owner456"
pdf.SecuritySettings.AllowUserCopyPasteContent = False
pdf.SecuritySettings.AllowUserPrinting = PdfPrintSecurity.FullPrintRights
pdf.SaveAs("protected.pdf")當團隊考慮TextControl的替代品時
有幾個場景通常促使開發團隊評估TextControl的替代方案:
成本優化
由於TextControl授權每位開發者的起始費用為$3,398+,並需每年40%的強制性續訂,三年總擁有成本達到每位開發者$5,750+。 專注於PDF生成的團隊通常發現這種定價難以證明的合理性,而替代方案的價格點大幅更低。
硬體相容性問題
記錄的Intel Iris Xe Graphics錯誤影響第11代Intel處理器,需要TextControl部署上的註冊表解決方案。 IronPDF的基於Chromium的渲染完全消除了這些特定硬體的渲染問題。
PDF優先要求
當PDF生成是主要的使用案例,而不是文檔編輯時,TextControl的文字處理器架構引入了不必要的複雜性。 不需要DOCX編輯功能或嵌入式UI控制項的應用受益於IronPDF的專注PDF優先設計。
現代Web技術整合
TextControl有限的CSS和JavaScript支持為使用當代前端框架的應用程序帶來挑戰。 IronPDF的完整HTML5、CSS3和ES2024 JavaScript支持確保現代網頁內容的準確渲染。
簡化部署
TextControl的ServerTextControl上下文管理和UI組件依賴性增加了部署複雜性。 IronPDF作為一個獨立的NuGet包運行,沒有外部依賴或複雜的初始化模式。
範本和郵件合併替代方案
TextControl的專有郵件合併系統使用帶有合併字段的DOCX範本。 IronPDF用標準的HTML範本方法取代了這個方法:
// Use standard C# string interpolation
var data = new { CustomerName = "John Doe", InvoiceNumber = "12345", Total = "$1,500.00" };
var html = $@"
<html>
<head>
<style>
body {{ font-family: Arial; padding: 40px; }}
h1 {{ color: #333; }}
.total {{ font-size: 24px; color: green; }}
</style>
</head>
<body>
<h1>Invoice #{data.InvoiceNumber}</h1>
<p>Customer: {data.CustomerName}</p>
<p class='total'>Total: {data.Total}</p>
</body>
</html>";
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("invoice.pdf");// Use standard C# string interpolation
var data = new { CustomerName = "John Doe", InvoiceNumber = "12345", Total = "$1,500.00" };
var html = $@"
<html>
<head>
<style>
body {{ font-family: Arial; padding: 40px; }}
h1 {{ color: #333; }}
.total {{ font-size: 24px; color: green; }}
</style>
</head>
<body>
<h1>Invoice #{data.InvoiceNumber}</h1>
<p>Customer: {data.CustomerName}</p>
<p class='total'>Total: {data.Total}</p>
</body>
</html>";
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("invoice.pdf");Imports IronPdf
Dim data = New With {.CustomerName = "John Doe", .InvoiceNumber = "12345", .Total = "$1,500.00"}
Dim html = $"
<html>
<head>
<style>
body {{ font-family: Arial; padding: 40px; }}
h1 {{ color: #333; }}
.total {{ font-size: 24px; color: green; }}
</style>
</head>
<body>
<h1>Invoice #{data.InvoiceNumber}</h1>
<p>Customer: {data.CustomerName}</p>
<p class='total'>Total: {data.Total}</p>
</body>
</html>"
Dim renderer As New ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs("invoice.pdf")對於更複雜的範本設置,IronPDF與Razor引擎和其他範本框架集成。 請參閱Razor範本集成指南以獲取詳細的實施模式。
.NET兼容性和未來準備
兩個程式庫都支持當前的.NET實現。 IronPDF保持積極的開發,定期更新,確保與.NET 8、.NET 9和包括預計在2026年發布的.NET 10的兼容性。程式庫的非同步/等待支持貫穿其API,符合現代C#開發實踐,包括C# 13提供的功能和預期的C# 14的能力。
額外的PDF功能
除了生成,IronPDF還提供文件操作功能,擴展了其實用性:
結論
TX Text Control和IronPDF儘管都生成PDF輸出,卻服務於不同的主要目的。 TextControl是一個全面的文檔編輯器,具有DOCX操作和嵌入式UI控制項,適合需要豐富文本編輯介面和文件導出功能的應用程式。
IronPDF專注於從HTML和網絡內容生成PDF,為需要將HTML、URL或動態生成的內容轉換為PDF的開發者提供流線型的解決方案,而無需完整的文件編輯架構。 其基於Chromium的渲染可確保像素精準的輸出與瀏覽器顯示相匹配,而其API設計優先考慮簡單性和與標準Web開發工作流程的整合。
在它們之間的選擇取決於專案需求:全面的文件編輯和PDF導出偏向TextControl,而直接從網絡內容生成PDF則與IronPDF的優勢相符。 對於目前主要用TextControl進行PDF生成的團隊,評估IronPDF可能揭示出顯著的成本降低機會及簡化的部署,而不會犧牲PDF質量。
欲瞭解更多實施指導,請探索IronPDF文檔和教程,涵蓋具體使用案例和高級功能。
([{i:(Text Control是一個註冊商標)和它各自的所有者。 本站與Text Control沒有關聯、未經其認可或贊助。 所有產品名稱、標誌及商標均為其各自所有者的財產。 比較僅供信息參考,反映在寫作時公開的相關信息。)}]
