产品比较

Compdfkit与IronPDF比较

发布 2024年八月13日
分享:

PDFPDF是便携式文档格式的缩写,是Adobe创建的一种文件类型,用于确保文档共享的一致性。该格式在各种设备和操作系统上保持布局、文本和图像的一致性。PDF以其安全性、互动功能和体积小巧而著称,非常适合分发文档而不改变原始内容。

对于使用C#的开发人员,PDF库提供用于处理PDF文件的PDF解决方案。这些库能够进行文档创建、内容修改以及文本和图像的提取。它们还支持表单处理、数字签名和跨平台兼容等功能。为了实现最佳性能,这些库促进了高效的PDF处理。

在本文中,我们将比较两个C# PDF库: IronPDFComPDFKit本次比较将涵盖功能、特性、代码示例和授权。通过检查这些方面,您可以确定哪一个库最适合您的PDF相关项目。

1. ComPDFKit SDK

ComPDFKIT与IronPDF的对比:图1 - ComPDFKIT SDK主页

ComPDFKit PDF SDK 是一个强大的 C# PDF SDK,允许开发人员将全面的 PDF 功能集成到他们的应用程序中。该库支持处理 PDF 文档编程所需的广泛 PDF 功能。它被设计用于各种环境,包括网页、桌面和移动平台,使其成为开发跨平台项目的开发人员的多功能工具。示例解决方案中有多个功能。您可以选择任何您想要尝试的相关 ComPDFKit PDF SDK 功能。

1.1 ComPDFKit的关键功能

  1. PDF查看:ComPDFKit提供了一个强大的PDF查看器,使用户能够以高保真度查看PDF文档。查看器支持平滑滚动、缩放和导航,确保无缝的用户体验。

  2. 注释:该库包含了集成PDF注释的工具。用户可以突出显示文本、添加评论,并创建各种类型的注释,这对于协同工作流程至关重要。

  3. 表单处理:该库提供了对交互式表单的广泛支持。开发者可以创建、填写和提取PDF表单中的数据,非常适合需要处理表单的应用程序。

  4. PDF编辑:ComPDFKit允许广泛的PDF编辑功能,包括修改PDF文件中的文本、图像和其他内容。此功能对需要更新或自定义现有PDF文档的应用程序非常有用。

  5. 转换:该库支持将PDF文件转换为各种格式,例如Word、Excel、PowerPoint和图像,以及从这些格式转换为PDF。这种灵活性对于需要将PDF内容转换为不同用途的应用程序至关重要。

  6. 安全:ComPDFKit包含强大的安全功能,如加密和权限管理。开发者可以保护PDF文档,防止未经授权的访问,以保护敏感信息。

  7. 光学字符识别 (光学字符识别)**图书馆包括OCR功能,可以将扫描的文档转换为可编辑和可搜索的PDF。这一功能对于数字化纸质文档并使其电子化是至关重要的。

ComPDFKit提供了一整套API,使这些功能集成到各种应用程序中变得更加简便。其详尽的文档和支持使其成为希望将高级PDF功能纳入其项目的开发人员的绝佳选择。**

2. IronPDF Library

2. IronPDF库

比较Compdfkit和IronPDF:图2 - IronPDF主页

IronPDF 是一个多功能的PDF库,适用于.NET,让开发人员可以使用C#创建、编辑和管理PDF文档。它提供了全面的PDF功能。它的设计旨在通过从HTML、CSS、JavaScript和各种图像格式渲染PDF来简化PDF生成。这使得它成为开发人员希望在他们的.NET应用程序中集成强大PDF功能的理想工具。

IronPDF 的主要特性

  1. HTML 转 PDF 转换: IronPDF 擅长将 HTML、CSS 和 JavaScript 内容转换成高质量的 PDF 文档。此功能支持 从HTML字符串生成PDF, URLs、ASPX 表单和 MVC 视图,成为各种基于网络内容的灵活解决方案。

  2. PDF 编辑:该库提供广泛的编辑功能,包括添加、复制和删除页面,合并和拆分 PDF,以及操作文本和图像。开发人员还可以为 PDF 文档添加页眉、页脚、水印和数字签名。

  3. 表单处理:IronPDF 支持智能表单创建和 以编程方式填写PDF表单. 该功能对于需要动态表单生成和从用户提交的表单中提取数据的应用程序至关重要。

  4. 安全特性:IronPDF 提供了强大的安全选项,例如设置密码和权限、加密文件以及添加数字签名。这些功能确保 PDF 文件中的敏感信息不会被未经授权的访问。

  5. OCR 和数据提取:该库包括光学字符识别 (光学字符识别) 功能,允许将扫描的文件转换为可编辑和可搜索的PDF。此外,IronPDF可以从现有的PDF中提取文本、图像和其他数据,方便内容重用和分析。

  6. 图像转换:IronPDF支持将各种图像格式,包括JPG、PNG、GIF、BMP和SVG,转换为PDF文档。它还提供将PDF页面渲染为图像的功能,这对于需要PDF内容视觉预览的应用程序非常有用。

  7. 跨平台兼容性:IronPDF兼容多个.NET平台,包括.NET Core、.NET Framework和.NET Standard。它支持在Windows、Linux、macOS和Azure上部署,为在不同环境中工作的开发人员提供了多功能的选择。

  8. 性能优化:该库设计为高性能,支持多线程和异步操作。这确保了PDF处理任务即使在高工作负载应用程序中也能高效执行。

  9. 全面的文档和支持:IronPDF提供详细的文档和大量的代码示例,使开发人员可以轻松上手并实现其功能。此外,它还提供技术支持,以帮助解决开发过程中可能出现的任何问题。

3. 创建一个新的 Visual Studio 项目

在我们深入代码示例之前,让我们创建一个新的 Visual Studio 项目。以下是设置 Visual Studio 中的 C# 控制台应用程序的分步指南。

第 1 步:安装 Visual Studio (如果尚未安装)

Visual Studio 是 C# 项目的最佳集成开发环境 (IDE)。如果您还没有下载和安装它,请从这个 链接 并安装它。

步骤2:打开Visual Studio

安装Visual Studio后,打开它。如果您使用的是Visual Studio Community,您可以选择登录或不登录继续。

第三步:创建一个新项目

  1. 点击“创建新项目”或导航到 文件 > 新建 > 项目。

Compdfkit和IronPDF之间的比较:图3 - IronPDF和DinkToPdf之间的比较:图1

  1. 在搜索栏中搜索Console应用程序,并从搜索结果中选择Console应用程序。

Compdfkit与IronPDF的比较: 图4 - IronPDF与DinkToPdf的比较: 图2 - 在创建新项目的对话框中,选择C#控制台应用并点击下一步。

  1. 选择最适合您需求的项目模板。对于基本的控制台应用程序,您可以选择“Console App”。 (.NET框架)."

  2. 提供您的项目名称和保存位置。您还可以设置解决方案名称。

  3. 选择适当的目标框架,然后点击“创建”来生成您的项目。

4. 安装 IronPDF

将 IronPDF 集成到您的项目中可以通过多种方法完成,每种方法都提供无缝的设置体验。

  1. 要使用 Visual Studio NuGet 包管理器,首先右键单击解决方案中的“Dependencies”,然后选择“Manage NuGet Packages”。在“Browse”选项卡中,搜索“IronPDF”并为您的项目安装最新版本。

Compdfkit 与 IronPDF 的比较:图 5 - 使用 NuGet 包管理器搜索 IronPDF

或者,您可以使用 NuGet 包管理器控制台。通过在 Visual Studio 中导航到 工具 > NuGet 包管理器 > 包管理器控制台来打开控制台。打开控制台后,执行以下命令:

Install-Package IronPdf
Install-Package IronPdf
'INSTANT VB TODO TASK: The following line uses invalid syntax:
'Install-Package IronPdf
VB   C#

这种方法提供了一种使用简单命令行快速安装库的方法。

对比Compdfkit与IronPDF:图6 - 使用命令行输入上述命令

  1. 对于那些更喜欢直接从 NuGet 网站下载的人,请访问 IronPDF NuGet 包页面从那里,你可以下载软件包文件。下载后,双击文件将其添加到你的项目中,然后重新加载你的解决方案以完成集成。

另一种方法是直接从最新版本下载 IronPDF官方网站. 这确保您拥有最新的软件包。请按照网站上的说明将IronPDF手动集成到您的Visual Studio项目中。

通过任何这些方法,您都可以有效地将IronPDF集成到您的.NET项目中。

5. 安装 ComPDFKit C#

有两种主要方法将ComPDFKit添加到您的项目中:使用NuGet包管理器或本地包。

5.1 使用 NuGet 包管理器

  1. 打开 NuGet 包管理器:在解决方案资源管理器中,右键点击“引用”,然后选择“管理 NuGet 包”。

  2. 搜索并安装:在 NuGet 包管理器中搜索“ComPDFKit”。选择合适的包。 (例如,ComPDFKit.NetFrameworkComPDFKit.Conversion.NetFramework) 并点击“安装”。

ComPDFKit与IronPDF的对比:图7 - 使用NuGet包管理器搜索ComPDFKit

  1. 验证安装:确保包出现在解决方案资源管理器中的“引用”下。

5.2 使用本地包

  1. 下载包:从官方的 ComPDFKit 网站获取 ComPDFKit.NetFramework.nupkg 文件。

  2. 配置 NuGet 源:在你的项目目录中创建或编辑一个 nuget.config 文件,以包含本地包的路径。
<?xml version="1.0" encoding="utf-8"?>
    <configuration>
        <packageSources>
            <add key="ComPDFKitSource" value="path\to\directoryContainingNupkg" />
        </packageSources>
    </configuration>
<?xml version="1.0" encoding="utf-8"?>
    <configuration>
        <packageSources>
            <add key="ComPDFKitSource" value="path\to\directoryContainingNupkg" />
        </packageSources>
    </configuration>
'INSTANT VB TODO TASK: The following line uses invalid syntax:
'<?xml version="1.0" encoding="utf-8"?> <configuration> <packageSources> <add key="ComPDFKitSource" value="path" + vbTab + "o\directoryContainingNupkg" /> </packageSources> </configuration>
VB   C#
  1. 安装本地包:在 Visual Studio 中重新打开您的解决方案,转到“管理 NuGet 包”,然后选择您的本地包源。从本地源安装 ComPDFKit 包。

5.3 应用许可证密钥

  1. 获得许可证:联系 ComPDFKit 团队以获取试用或完整许可证。

  2. 在代码中应用许可证
bool LicenseVerify()
    {
        if (!CPDFSDKVerifier.LoadNativeLibrary())
            return false;
        LicenseErrorCode verifyResult = CPDFSDKVerifier.LicenseVerify("input your license here");
        return (verifyResult == LicenseErrorCode.E_LICENSE_SUCCESS);
    }
bool LicenseVerify()
    {
        if (!CPDFSDKVerifier.LoadNativeLibrary())
            return false;
        LicenseErrorCode verifyResult = CPDFSDKVerifier.LicenseVerify("input your license here");
        return (verifyResult == LicenseErrorCode.E_LICENSE_SUCCESS);
    }
Private Function LicenseVerify() As Boolean
		If Not CPDFSDKVerifier.LoadNativeLibrary() Then
			Return False
		End If
		Dim verifyResult As LicenseErrorCode = CPDFSDKVerifier.LicenseVerify("input your license here")
		Return (verifyResult = LicenseErrorCode.E_LICENSE_SUCCESS)
End Function
VB   C#

将此方法添加到您的主应用程序文件中以验证许可证。

通过按照这些步骤操作,您可以成功将 ComPDFKit 集成到您的C#项目中。

6. HTML转PDF

将HTML页面转换为PDF 是许多应用程序中的常见需求,例如从Web内容动态生成报告、发票或文档。IronPDF和ComPDFKit都为此任务提供了强大的解决方案,但它们的方法和功能有显著差异。

这个过程通常从捕获HTML内容开始,这些内容可以是静态的或动态生成的。然后处理捕获的HTML以应用任何相关的样式表。 (CSS) 和脚本 (JavaScript)确保最终的PDF与原始网页的外观和行为相符。

6.1. 使用 IronPDF 将 HTML 页面转换为 PDF

IronPDF 是一个用于在 C# 中将 HTML 转换为 PDF 的多功能库。它使用基于 Chrome 的渲染引擎,以确保高质量的输出。此过程涉及将 HTML、CSS 和 JavaScript 内容准确渲染为 PDF 格式。以下是一个如何使用 IronPDF 将 HTML 字符串转换为 PDF 文件的基本示例:

using IronPdf;
using System;
class Program
{
    static void Main()
    {
        // Define your HTML string
        string htmlString = @"
                <h1>Hello, IronPDF!</h1>
                <p>This is a simple PDF created from an HTML string.</p>";
        var renderer = new ChromePdfRenderer();
        // Convert the HTML string to a PDF document
        PdfDocument pdf = renderer.RenderHtmlAsPdf(htmlString);
        // Save the PDF document to a file
        string outputPath = "sample.pdf";
        pdf.SaveAs(outputPath);
        Console.WriteLine($"PDF created successfully and saved to {outputPath}");
    }
}
using IronPdf;
using System;
class Program
{
    static void Main()
    {
        // Define your HTML string
        string htmlString = @"
                <h1>Hello, IronPDF!</h1>
                <p>This is a simple PDF created from an HTML string.</p>";
        var renderer = new ChromePdfRenderer();
        // Convert the HTML string to a PDF document
        PdfDocument pdf = renderer.RenderHtmlAsPdf(htmlString);
        // Save the PDF document to a file
        string outputPath = "sample.pdf";
        pdf.SaveAs(outputPath);
        Console.WriteLine($"PDF created successfully and saved to {outputPath}");
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Compdfkit与IronPDF的比较:图8 - 上述代码的输出示例

同样,您可以从HTML文件创建PDF。这非常有用,因为有时HTML字符串太大,您需要添加CSS。IronPDF通过提供一种方法,直接将HTML文件及其CSS和JS文件转换为PDF文档来提供帮助。

using IronPdf;
using System;
class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        // Convert the HTML string to a PDF document
        PdfDocument pdf = renderer.RenderHtmlFileAsPdf("index.html");
        // Save the PDF document to a file
        string outputPath = "HTML File.pdf";
        pdf.SaveAs(outputPath);
        Console.WriteLine($"PDF created successfully and saved to {outputPath}");
    }
}
using IronPdf;
using System;
class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        // Convert the HTML string to a PDF document
        PdfDocument pdf = renderer.RenderHtmlFileAsPdf("index.html");
        // Save the PDF document to a file
        string outputPath = "HTML File.pdf";
        pdf.SaveAs(outputPath);
        Console.WriteLine($"PDF created successfully and saved to {outputPath}");
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

compdfkit与IronPDF比较:图9 - 使用IronPDF将HTML渲染为PDF的示例输出

IronPDF 还支持将 URL 和 HTML 文件转换为 PDF。这些功能在文档管理重要的软件中非常有用。IronPDF 提供了广泛的 PDF 创建和操作功能,使其成为开发人员的强大工具。

6.2. 使用 ComPDFKit 从 HTML 转换为 PDF

ComPDFKit 在其 C# SDK 中不直接支持 HTML 到 PDF 的转换。相反,它提供了一个专门用于此目的的 API。此 API 允许您通过向他们的服务发出 HTTP 请求来执行 HTML 到 PDF 的转换。

要使用 ComPDFKit HTML to PDF API,通常会遵循以下步骤:

  1. 发送 HTML 内容:创建一个 HTTP POST 请求,将您的 HTML 内容发送到 ComPDFKit API 端点。

  2. 接收 PDF 输出:API 处理 HTML 内容并返回生成的 PDF 文件。

以下是您可以在 C# 中构建此类请求的示例:

using System;
using System.Net.Http;
using System.Threading.Tasks;
public class HtmlToPdfExample
{
    public static async Task ConvertHtmlToPdfAsync()
    {
        using (var client = new HttpClient())
        {
            var content = new StringContent("<h1>Hello World</h1>");
            var response = await client.PostAsync("https://api.compdfkit.com/html-to-pdf", content);
            var pdfBytes = await response.Content.ReadAsByteArrayAsync();
            System.IO.File.WriteAllBytes("output.pdf", pdfBytes);
        }
    }
}
using System;
using System.Net.Http;
using System.Threading.Tasks;
public class HtmlToPdfExample
{
    public static async Task ConvertHtmlToPdfAsync()
    {
        using (var client = new HttpClient())
        {
            var content = new StringContent("<h1>Hello World</h1>");
            var response = await client.PostAsync("https://api.compdfkit.com/html-to-pdf", content);
            var pdfBytes = await response.Content.ReadAsByteArrayAsync();
            System.IO.File.WriteAllBytes("output.pdf", pdfBytes);
        }
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

这只是一个演示,显示我们可以在C#程序中这样使用API。在ComPDFKit的文档中没有指定用于C#的具体方法。

7. PDF上的水印

在PDF上添加水印是一个非常重要的做法,原因有很多。它有助于保护文件的完整性,确认所有权,并增加一层安全性。水印可以是文本、徽标或图片,出现在文档的背景或前景中。它们可以阻止未经授权的使用、复制和分发内容。此外,水印还可以传达重要信息,例如文件的状态。 (例如,“机密”,“草案”,“批准”) 或创作者的身份

7.1 使用 IronPDF 进行水印处理

IronPDF 提供了一种简单的方法来 以编程方式向 PDF 文档添加水印该功能集成在库中,允许开发人员使用C#代码应用水印。

using IronPdf;
using IronPdf.Editing;
License.LicenseKey = "License-Code";
string watermarkHtml = @"
<img style='width: 500px;' src=""C:\Users\Tayyab Ali\Desktop\watermark.png"">
<h1>IronPDF Watermark</h1>";
ChromePdfRenderer renderer = new ChromePdfRenderer();
PdfDocument pdf = renderer.RenderHtmlAsPdf("<h1>It's a PDF with a watermark</h1>");
// Apply watermark with 45 degrees rotation and 70% opacity
pdf.ApplyWatermark(watermarkHtml, rotation: 30, opacity: 50);
pdf.SaveAs("f://Confedential.pdf");
using IronPdf;
using IronPdf.Editing;
License.LicenseKey = "License-Code";
string watermarkHtml = @"
<img style='width: 500px;' src=""C:\Users\Tayyab Ali\Desktop\watermark.png"">
<h1>IronPDF Watermark</h1>";
ChromePdfRenderer renderer = new ChromePdfRenderer();
PdfDocument pdf = renderer.RenderHtmlAsPdf("<h1>It's a PDF with a watermark</h1>");
// Apply watermark with 45 degrees rotation and 70% opacity
pdf.ApplyWatermark(watermarkHtml, rotation: 30, opacity: 50);
pdf.SaveAs("f://Confedential.pdf");
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Compdfkit与IronPDF的对比:图10 - 上图是代码输出的示例,展示了使用IronPDF添加的水印效果

在此示例中,ChromePdfRenderer 类用于从 HTML 字符串创建 PDF。然后使用 ApplyWatermark 方法应用水印。水印包含一个图像和标题,两者都在 watermarkHtml 字符串中定义。rotation 参数设置为30度,opacity 设置为50%,确保水印可见但不会压倒主要内容。生成的 PDF 将保存到指定路径。

7.2 使用 ComPDFKit 添加水印

ComPDFKit 提供了全面的功能,可以直接在 C# 中向 PDF 文档添加水印。可以通过使用 ComPDFKit 库的方法以编程方式实现。以下是使用 ComPDFKit 添加文字水印的示例:

static private bool AddTextWatermark(CPDFDocument document)
{
    CPDFWatermark watermark = document.InitWatermark(C_Watermark_Type.WATERMARK_TYPE_TEXT);
    watermark.SetText("test");
    watermark.SetFontName("Helvetica"); 
    watermark.SetPages("0-3");
    byte[] color = { 255, 0, 0 };
    watermark.SetTextRGBColor(color);
    watermark.SetScale(2);
    watermark.SetRotation(0);
    watermark.SetOpacity(120);
    watermark.SetVertalign(C_Watermark_Vertalign.WATERMARK_VERTALIGN_CENTER);
    watermark.SetHorizalign(C_Watermark_Horizalign.WATERMARK_HORIZALIGN_CENTER);
    watermark.SetVertOffset(0);
    watermark.SetHorizOffset(0);
    watermark.SetFront(true);
    watermark.SetFullScreen(true);
    watermark.SetVerticalSpacing(10);
    watermark.SetHorizontalSpacing(10);
    watermark.CreateWatermark();
    string path = outputPath + "\\AddTextWatermarkTest.pdf";
    if (!document.WriteToFilePath(path))
    {
        return false;
    }
    Console.WriteLine("Browse the changed file in " + path);
    return true;
}
CPDFDocument document = CPDFDocument.InitWithFilePath("SamplePDF.pdf");
if (AddTextWatermark(document))
{
    Console.WriteLine("Add text watermark done.");
}
else
{
    Console.WriteLine("Add text watermark failed.");
}
static private bool AddTextWatermark(CPDFDocument document)
{
    CPDFWatermark watermark = document.InitWatermark(C_Watermark_Type.WATERMARK_TYPE_TEXT);
    watermark.SetText("test");
    watermark.SetFontName("Helvetica"); 
    watermark.SetPages("0-3");
    byte[] color = { 255, 0, 0 };
    watermark.SetTextRGBColor(color);
    watermark.SetScale(2);
    watermark.SetRotation(0);
    watermark.SetOpacity(120);
    watermark.SetVertalign(C_Watermark_Vertalign.WATERMARK_VERTALIGN_CENTER);
    watermark.SetHorizalign(C_Watermark_Horizalign.WATERMARK_HORIZALIGN_CENTER);
    watermark.SetVertOffset(0);
    watermark.SetHorizOffset(0);
    watermark.SetFront(true);
    watermark.SetFullScreen(true);
    watermark.SetVerticalSpacing(10);
    watermark.SetHorizontalSpacing(10);
    watermark.CreateWatermark();
    string path = outputPath + "\\AddTextWatermarkTest.pdf";
    if (!document.WriteToFilePath(path))
    {
        return false;
    }
    Console.WriteLine("Browse the changed file in " + path);
    return true;
}
CPDFDocument document = CPDFDocument.InitWithFilePath("SamplePDF.pdf");
if (AddTextWatermark(document))
{
    Console.WriteLine("Add text watermark done.");
}
else
{
    Console.WriteLine("Add text watermark failed.");
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

ComPDFKit与IronPDF的比较:图11 - 上面的示例是代码输出,展示了使用ComPDFKit添加的水印

在此示例中,CPDFDocument 类用于打开现有的 PDF 文档。AddTextWatermark 方法通过 InitWatermark 方法初始化文本水印。设置了水印的各种属性,例如文本内容、字体、颜色、比例、旋转、透明度、对齐方式和间距。然后,水印被创建并应用于 PDF 文档的指定页面。最后,修改后的 PDF 保存到指定路径。集成图像水印需要不同的方法。

8. PDFA

PDF/A 是专为长期数字保存电子文档而设计的PDF标准版本。确保文档符合PDF/A标准可以保证它们在未来能够可靠地查看和再现。本节探讨了如何使用两个流行的库(IronPDF和ComPDFKit)来创建符合PDF/A标准的文档。

8.1 使用 IronPDF 的 PDFA

IronPDF 简化了将标准 PDF 文档转换为符合 PDF/A 标准的文档的过程。有了 IronPDF,您可以轻松加载现有的 PDF 并将其保存为符合 PDF/A 标准的格式。

using IronPdf;
using System;
class Program
{
    static void Main()
    {
        License.LicenseKey = "License-Key";
        PdfDocument pdf = PdfDocument.FromFile("Source.pdf");
        pdf.SaveAsPdfA("pdfa-compliant.pdf", PdfAVersions.PdfA3);
    }
}
using IronPdf;
using System;
class Program
{
    static void Main()
    {
        License.LicenseKey = "License-Key";
        PdfDocument pdf = PdfDocument.FromFile("Source.pdf");
        pdf.SaveAsPdfA("pdfa-compliant.pdf", PdfAVersions.PdfA3);
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

以下是该过程的简要概述:

  1. 初始化 IronPDF:首先导入 IronPDF 库并设置您的许可证密钥。

  2. 加载 PDF:使用 PdfDocument.FromFile 加载您的源 PDF 文件。

  3. 转换与保存:通过指定所需的 PDF/A 版本来转换加载的 PDF,并保存生成的文档。

这种简单的方法使 IronPDF 成为处理 PDF/A 转换的方便选择。

8.2 使用ComPDFKit的PDFA

ComPDFKit提供了将PDF转换为PDF/A格式的强大解决方案。该过程涉及初始化PDF文档、定义输出路径和调用转换方法。

static public bool CovertToPDFA1a(CPDFDocument document)
{
    string convertToPDFA1aPath = outputPath + "\\ConvertToPDFA1aTest.pdf";
    if (!document.WritePDFAToFilePath(CPDFType.CPDFTypePDFA1a, convertToPDFA1aPath))
    {
        return false;
    }
    Console.WriteLine("Browse the changed file in " + convertToPDFA1aPath);
    return true;
}
CPDFDocument document = CPDFDocument.InitWithFilePath("CommonFivePage.pdf");
if (!Directory.Exists(outputPath))
{
    Directory.CreateDirectory(outputPath);
}
if (CovertToPDFA1a(document))
{
    Console.WriteLine("Convert to PDF/A-1a done.");
}
else
{
    Console.WriteLine("Convert to PDF/A-1a failed.");
}
static public bool CovertToPDFA1a(CPDFDocument document)
{
    string convertToPDFA1aPath = outputPath + "\\ConvertToPDFA1aTest.pdf";
    if (!document.WritePDFAToFilePath(CPDFType.CPDFTypePDFA1a, convertToPDFA1aPath))
    {
        return false;
    }
    Console.WriteLine("Browse the changed file in " + convertToPDFA1aPath);
    return true;
}
CPDFDocument document = CPDFDocument.InitWithFilePath("CommonFivePage.pdf");
if (!Directory.Exists(outputPath))
{
    Directory.CreateDirectory(outputPath);
}
if (CovertToPDFA1a(document))
{
    Console.WriteLine("Convert to PDF/A-1a done.");
}
else
{
    Console.WriteLine("Convert to PDF/A-1a failed.");
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

以下是步骤摘要:

  1. 初始化文档:使用 CPDFDocument.InitWithFilePath 加载 PDF 文档。

  2. 设置输出目录:确保输出目录存在,必要时创建。

  3. 转换为 PDF/A:使用 WritePDFAToFilePath 并指定 PDF/A 类型进行转换并保存文件。

9. 数字签名

数字签名对于验证文档的真实性和完整性至关重要。本节演示了如何使用IronPDF和ComPDFKit向PDF添加数字签名。

9.1 使用 IronPDF 的数字签名

IronPDF 提供了一种简单且有效的方法来对 PDF 文档应用数字签名。

using IronPdf;
using IronPdf.Signing;
class Program
{
    static void Main(string[] args)
    {
        var simpleSignature = new IronPdf.Signing.PdfSignature("MyCert.p12", "newpassword");
        simpleSignature.SignPdfFile("sample.pdf");
    }
}
using IronPdf;
using IronPdf.Signing;
class Program
{
    static void Main(string[] args)
    {
        var simpleSignature = new IronPdf.Signing.PdfSignature("MyCert.p12", "newpassword");
        simpleSignature.SignPdfFile("sample.pdf");
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

过程包括:

  1. Initialize IronPDF: 导入必要的 IronPDF 库。

  2. Create a Signature: 使用证书文件和密码初始化一个 PdfSignature 对象。

  3. Sign the PDF: 使用 SignPdfFile 将签名应用到 PDF 文件。

这种方法确保您的 PDF 文件被安全签署,增强其可信度和安全性。

9.2 通过ComPDFKit进行数字签名

ComPDFKit提供了一个全面的解决方案,用于创建具有广泛自定义选项的数字签名。

private static void CreateDigitalSignature(CPDFDocument document, string certificatePath, string password)
{
    Console.WriteLine("--------------------");
    Console.WriteLine("Create digital signature.");
    CPDFSignatureCertificate certificate = CPDFPKCS12CertHelper.GetCertificateWithPKCS12Path("Certificate.pfx", "ComPDFKit");
    CPDFPage page = document.PageAtIndex(0);
    CPDFSignatureWidget signatureField = page.CreateWidget(C_WIDGET_TYPE.WIDGET_SIGNATUREFIELDS) as CPDFSignatureWidget;
    signatureField.SetRect(new CRect(28, 420, 150, 370));
    signatureField.SetWidgetBorderRGBColor(new byte[] { 0, 0, 0 });
    signatureField.SetWidgetBgRGBColor(new byte[] { 150, 180, 210 });
    signatureField.UpdateAp();
    string name = GetGrantorFromDictionary(certificate.SubjectDict) + "\n";
    string date = DateTime.Now.ToString("yyyy.MM.dd HH:mm:ss");
    string reason = "I am the owner of the document.";
    string location = certificate.SubjectDict["C"];
    string DN = certificate.Subject;
    CPDFSignatureConfig signatureConfig = new CPDFSignatureConfig
    {
        Text = GetGrantorFromDictionary(certificate.SubjectDict),
        Content =
        "Name: " + name + "\n" +
        "Date: " + date + "\n" +
        "Reason: " + reason + " \n" +
        "Location: " + location + "\n" +
        "DN: " + DN + "\n",
        IsContentAlignLeft = false,
        IsDrawLogo = true,
        LogoBitmap = new Bitmap("Logo.png"),
        TextColor = new float[] { 0, 0, 0 },
        ContentColor = new float[] { 0, 0, 0 }
    };
    string filePath = outputPath + "\\" + document.FileName + "_Signed.pdf";
    signatureField.UpdataApWithSignature(signatureConfig);
    if (document.WriteSignatureToFilePath(signatureField,
        filePath,
        certificatePath, password,
        location,
        reason, CPDFSignaturePermissions.CPDFSignaturePermissionsNone))
    {
        Console.WriteLine("File saved in " + filePath);
        Console.WriteLine("Create digital signature done.");
    }
    else
    {
        Console.WriteLine("Create digital signature failed.");
    }
    Console.WriteLine("--------------------");
}
private static void CreateDigitalSignature(CPDFDocument document, string certificatePath, string password)
{
    Console.WriteLine("--------------------");
    Console.WriteLine("Create digital signature.");
    CPDFSignatureCertificate certificate = CPDFPKCS12CertHelper.GetCertificateWithPKCS12Path("Certificate.pfx", "ComPDFKit");
    CPDFPage page = document.PageAtIndex(0);
    CPDFSignatureWidget signatureField = page.CreateWidget(C_WIDGET_TYPE.WIDGET_SIGNATUREFIELDS) as CPDFSignatureWidget;
    signatureField.SetRect(new CRect(28, 420, 150, 370));
    signatureField.SetWidgetBorderRGBColor(new byte[] { 0, 0, 0 });
    signatureField.SetWidgetBgRGBColor(new byte[] { 150, 180, 210 });
    signatureField.UpdateAp();
    string name = GetGrantorFromDictionary(certificate.SubjectDict) + "\n";
    string date = DateTime.Now.ToString("yyyy.MM.dd HH:mm:ss");
    string reason = "I am the owner of the document.";
    string location = certificate.SubjectDict["C"];
    string DN = certificate.Subject;
    CPDFSignatureConfig signatureConfig = new CPDFSignatureConfig
    {
        Text = GetGrantorFromDictionary(certificate.SubjectDict),
        Content =
        "Name: " + name + "\n" +
        "Date: " + date + "\n" +
        "Reason: " + reason + " \n" +
        "Location: " + location + "\n" +
        "DN: " + DN + "\n",
        IsContentAlignLeft = false,
        IsDrawLogo = true,
        LogoBitmap = new Bitmap("Logo.png"),
        TextColor = new float[] { 0, 0, 0 },
        ContentColor = new float[] { 0, 0, 0 }
    };
    string filePath = outputPath + "\\" + document.FileName + "_Signed.pdf";
    signatureField.UpdataApWithSignature(signatureConfig);
    if (document.WriteSignatureToFilePath(signatureField,
        filePath,
        certificatePath, password,
        location,
        reason, CPDFSignaturePermissions.CPDFSignaturePermissionsNone))
    {
        Console.WriteLine("File saved in " + filePath);
        Console.WriteLine("Create digital signature done.");
    }
    else
    {
        Console.WriteLine("Create digital signature failed.");
    }
    Console.WriteLine("--------------------");
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

步骤包括:

  1. 初始化文档和证书:使用 CPDFPKCS12CertHelper 加载 PDF 文档并检索证书。

  2. 创建和配置签名字段:向 PDF 添加签名字段,设置其属性,并配置签名详情。

  3. 应用签名:使用 WriteSignatureToFilePath 应用签名并保存已签名的 PDF。

10. 提取文本

从PDF文档中提取文本 对于各种数据处理和分析任务至关重要。本节解释如何使用IronPDF和ComPDFKit从PDF中提取文本。

10.1 使用IronPDF提取文本

IronPDF 提供了一种从 PDF 文档中提取文本的简便方法。

using IronPdf;
using System.IO;
PdfDocument pdf = PdfDocument.FromFile("PDF File With Text.pdf");
string text = pdf.ExtractAllText();
File.WriteAllText("PDF Text.txt", text);
using IronPdf;
using System.IO;
PdfDocument pdf = PdfDocument.FromFile("PDF File With Text.pdf");
string text = pdf.ExtractAllText();
File.WriteAllText("PDF Text.txt", text);
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

该过程包括:

  1. 初始化 IronPDF:导入 IronPDF 库。

  2. 加载 PDF:使用 PdfDocument.FromFile 加载 PDF 文件。

  3. 提取文本:调用 ExtractAllText 从 PDF 中检索所有文本内容。

  4. 保存文本到文件:使用标准文件 I/O 操作将提取的文本写入文件。

这种方法提供了一种简单而高效的方式提取和保存 PDF 文档中的文本。

10.2 使用 ComPDFKit 提取文本

ComPDFKit 提供了一种从 PDF 文档中提取文本的灵活解决方案。

static private bool PDFToText(CPDFDocument document)
{
    string path = outputPath + "//PDFToText.txt";
    if (!document.PdfToText("1-" + document.PageCount.ToString(), path))//Page ranges are counted from 1
    {
        return false;
    }
    Console.WriteLine("Browse the generated file in " + path);
    return true;
}
static void Main(string[] args)
{
    #region Perparation work
    Console.WriteLine("Running PDFPage test sample…\r\n");
    SDKLicenseHelper.LicenseVerify();
    CPDFDocument document = CPDFDocument.InitWithFilePath("CommonFivePage.pdf");
    if (!Directory.Exists(outputPath))
    {
        Directory.CreateDirectory(outputPath);
    }
    #endregion
    if (PDFToText(document))
    {
        Console.WriteLine("PDF to text done.");
    }
    else
    {
        Console.WriteLine("PDF to text failed.");
    }
    Console.WriteLine("--------------------");
    Console.WriteLine("Done!");
    Console.WriteLine("--------------------");
    Console.ReadLine();
}
static private bool PDFToText(CPDFDocument document)
{
    string path = outputPath + "//PDFToText.txt";
    if (!document.PdfToText("1-" + document.PageCount.ToString(), path))//Page ranges are counted from 1
    {
        return false;
    }
    Console.WriteLine("Browse the generated file in " + path);
    return true;
}
static void Main(string[] args)
{
    #region Perparation work
    Console.WriteLine("Running PDFPage test sample…\r\n");
    SDKLicenseHelper.LicenseVerify();
    CPDFDocument document = CPDFDocument.InitWithFilePath("CommonFivePage.pdf");
    if (!Directory.Exists(outputPath))
    {
        Directory.CreateDirectory(outputPath);
    }
    #endregion
    if (PDFToText(document))
    {
        Console.WriteLine("PDF to text done.");
    }
    else
    {
        Console.WriteLine("PDF to text failed.");
    }
    Console.WriteLine("--------------------");
    Console.WriteLine("Done!");
    Console.WriteLine("--------------------");
    Console.ReadLine();
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

步骤如下:

  1. 初始化文档:使用 CPDFDocument.InitWithFilePath 加载 PDF 文档。

  2. 设置输出目录:确保输出目录存在,如果没有则创建它。

  3. 提取并保存文本:使用 PdfToText 从指定页面范围提取文本并保存到文件。

8. 许可

IronPDF 和 ComPDFKit 的许可模式在方法和使用条款上有所不同。了解这些差异可以帮助您为您的项目需求和预算选择合适的工具。

9.1 IronPDF 许可

Compdfkit与IronPDF比较:图12 - IronPDF许可页面

IronPDF采用商业许可模式,这意味着在商业或业务相关应用中,通常需要购买许可证。该模式提供了灵活性,包括免版税分发等选项。这使开发人员能够将库集成到他们的项目中而在运行时无需面临额外费用。

IronPDF提供永久许可证。永久许可证需要一次性支付以终身使用,额外费用用于初始期后的更新和技术支持。这种商业模式确保企业获得专门的支持、全面的文档以及专业PDF生成和操作所必需的高级功能。

9.2 ComPDFKit 许可

ComPDFKit 采用灵活的许可模式,满足不同业务需求。它提供永久和订阅许可证。永久许可证需要一次性付款,授予终身访问SDK的权限,并可选付费更新和延长支持。订阅许可证则需要定期付款。 (每月或每年) 并包括持续访问更新和支持。

在选择IronPDF和ComPDFKit时,请考虑您的项目的具体需求,例如对专门支持的需求、预算限制和部署规模。IronPDF的商业模式更适合寻求强大支持和高级功能的企业。

9.文件和支持

9.1. IronPDF 文档和支持

IronPDF 为用户提供了全面的文档和强大的支持选项。文档详尽且详细,提供了关于安装、基本使用、高级功能和故障排除的清晰指导。官方文档可在 阅读文档,包括快速启动指南、详细的API参考和大量代码示例,以帮助开发人员快速入门并有效使用IronPDF的功能。

IronPDF还通过其博客和示例部分维护一个活跃的故障排除指南和技术支持网站,用户可以在这里找到常见问题的解决方案,例如渲染延迟和部署挑战。支持网站包含一系列文章,解决常见问题和具体技术问题。

对于直接支持,IronPDF提供一个响应迅速的客户服务团队,可以联系他们解决更复杂的问题或获得个性化的帮助。这种详尽的文档和强大的支持基础设施结合在一起,使IronPDF成为开发人员希望在其应用程序中集成PDF功能的可靠选择。

9.2. ComPDFKit 文档和支持

ComPDFKit 还为其用户提供了详细的文档和支持资源。它涵盖了从基本设置到高级功能(如水印和数字签名)等各个方面的 SDK 使用方法。对于支持,ComPDFKit 通过其客户服务渠道提供技术援助。支持团队随时可以帮助解决技术问题,回答问题,并提供有关如何有效使用 SDK 的指导。

虽然 IronPDF 和 ComPDFKit 都提供了强大的文档和支持,但 IronPDF 在更详尽的故障排除指南和高度响应的支持团队方面具有优势。这使得它对可能遇到复杂技术挑战并需要可靠援助的开发人员特别有利。

10. 结论

IronPDF 和 ComPDFKit 之间的比较突出了开发人员在寻找强大的 C# PDF 生成和处理库时的优点和考虑。

ComPDFKit 是一个全面的 PDF SDK,支持以编程方式处理 PDF 文档所需的各种功能。它在 PDF 注释和广泛的编辑功能方面表现出色。其格式转换和安全选项等功能为开发人员带来了巨大的价值。

另一方面,IronPDF 以其强大且用户友好的 API 而闻名。它通过从 HTML、CSS 和 JavaScript 渲染 PDF 来简化 PDF 生成。IronPDF 在 HTML 到 PDF 转换方面表现出色,并提供与 .NET 应用程序的无缝集成。该库提供了广泛的编辑功能,包括添加页眉、页脚、水印和数字签名。

IronPDF 的安全功能确保 PDF 文档中的敏感信息得到良好保护。其对多个 .NET 平台的支持和针对高工作负载的优化性能使其成为企业级应用程序的理想选择。IronPDF 的商业许可模式确保了专门支持、全面的文档和高级功能的使用,使其特别适用于专业级项目。

与 ComPDFKit 相比,IronPDF 是开发人员寻找全面且功能丰富的 PDF 库时的一个强大选项。其先进的功能、用户友好的 API 和强大的支持基础设施使其成为企业和有多样且苛刻的 PDF 需求项目的首选解决方案。IronPDF 的广泛能力和专用支持提供了显著的优势,确保了专业应用中可靠且高效的 PDF 生成和处理。

总之,IronPDF 和 ComPDFKit 都是用于 C# PDF 处理的强大工具。然而,IronPDF 的广泛功能集、优化性能和优越的支持使其成为面向专业和企业级应用开发人员的首选。

IronPDF 提供了一个 免费试用许可证 供用户试用该库及其功能。IronPDF 许可证起价为 $749。此外,Iron Software 捆绑了九个库,其成本仅为两个库的价格,其中包括 IronXLIronOCR 以及 IronPDF。

< 前一页
CraftMyPDF与IronPDF的比较
下一步 >
Report .NET 与 IronPDF 的比较

准备开始了吗? 版本: 2024.10 刚刚发布

免费NuGet下载 总下载量: 11,108,738 查看许可证 >