製品比較 PDFsharpでPDFをデジタル署名する VS IronPDF(コード例) カーティス・チャウ 更新日:7月 28, 2025 IronPDF をダウンロード NuGet ダウンロード DLL ダウンロード Windows 版 無料トライアル LLM向けのコピー LLM向けのコピー LLM 用の Markdown としてページをコピーする ChatGPTで開く このページについてChatGPTに質問する ジェミニで開く このページについてGeminiに問い合わせる ジェミニで開く このページについてGeminiに問い合わせる 困惑の中で開く このページについてPerplexityに問い合わせる 共有する Facebook で共有 Xでシェア(Twitter) LinkedIn で共有 URLをコピー 記事をメールで送る デジタル署名は、電子文書の真偽性と整合性を確認する数学的な手法です。 これは、いくつかの管轄区域で文書に電子署名を施すための電子的な署名として機能し、高いセキュリティと法的有効性を確保します。 デジタル署名は、署名者のみに知られている秘密鍵を使用して作成されます。 この秘密鍵は、署名時に文書にリンクされたユニークなデジタル署名を確立します。 署名には、署名者の名前、メールアドレス、およびその他の個人情報が含まれています。 デジタル署名された文書の真偽を確認するために、受取人は署名者の公開鍵へのアクセスが必要です。 署名の正当性は、公開鍵を使用して復号化することによって検証されます。 このチュートリアルでは、PDFsharpとIronPDFを使用してPDF文書にデジタル署名を追加する方法を比較します。 デジタル署名は文書の真正性を確認するために不可欠であり、PDFファイルはこのような操作において人気のある形式です。 PDFsharpはPDFの作成と操作のための有名なオープンソースライブラリであり、IronPDFは同様の機能と追加の高度な機能を提供する強力な.NET PDFライブラリです。 このガイドでは、PDF文書に秘密鍵で署名し、署名を検証する方法を扱い、両方のライブラリの例も示します。 なぜデジタル署名が重要なのか? デジタル署名は文書の統合性を確保し、堅牢なセキュリティを提供します。 通常、契約書、合意書、およびその他の法的文書に使用されます。 主な利点: 従来の署名よりも安全で改ざんされにくい。 電子的に検証され、手動の検証努力を削減。 ドキュメントを世界中でリモートで署名可能。 従来の署名よりも高い保証を提供。 PDFsharpの概要 PDFsharpは、主にPDF文書の作成と操作のために設計されたオープンソースのC#ライブラリです。 これは、簡単なPDFファイルの生成、既存の文書の編集、グラフィックの描画など、基本的なPDFタスクに広く使用されています。 ただし、デジタル署名のような高度な機能に対するネイティブサポートが限られており、開発者はしばしばBouncyCastleのようなサードパーティライブラリに依存してこれらの機能を統合する必要があります。 PDFsharpはMITライセンスの下でオープンソースであり、コストと柔軟性が重視されるプロジェクトに最適です。 主な機能 オープンソースでMITライセンスの下で無料。 基本的なPDFの作成と操作。 外部ライブラリ(例:BouncyCastle)を使用してデジタル署名を拡張可能。 HTMLからPDFへの変換や複雑なフォーム処理などの高度なPDF機能の即時サポートが欠如しています。 IronPDFの概要 IronPDFは、PDFの生成、編集、および操作のためのシンプルで強力なAPIを提供する堅牢な.NET PDFライブラリです。 その注目すべき機能の1つは、開発者が文書の真正性を確認するためにデジタル署名を簡単に実装できることです。 デジタル署名に加えて、IronPDFはHTMLからPDFへの変換、透かし、およびフォーム処理などの高度な機能をサポートしています。 商用プロジェクトで迅速な実装と強力な機能を優先する開発者に特に価値があります。 主な機能 商用ライセンスでは有料サポートと無料のトライアルが利用可能。 使いやすいAPIで、デジタル署名や文書操作のための最新機能を提供。 HTMLからPDF形式への変換、フォーム処理、およびPDF注釈(添付注釈など)に対する組み込みサポートを含む。 タイムスタンプ、視覚署名画像、および暗号化などの高度な機能とのシームレスな統合。 PDFsharpを使ってプログラムでデジタル署名を追加する PDFsharpは、C#でのPDF作成と操作のために設計されたオープンソースライブラリです。 ただし、署名を追加するサポートを提供している一方で、PDF文書の安全で正確なデジタル署名を保証するためにBouncyCastleのようなサードパーティツールを統合する必要があります。 PDFsharpでデジタル署名を追加する手順 NuGetを介してPDFsharpとBouncyCastleをインストールする。 X509Certificate2を使用してデジタル証明書を作成する。 BouncyCastleでPDFに署名する。 サンプルコード using System; using System.IO; using System.Security.Cryptography.X509Certificates; using PdfSharp.Drawing; using PdfSharp.Pdf; using BouncyCastleSigner; // Hypothetical namespace for illustration // Ensure that you have the appropriate namespaces added class Program { static void Main(string[] args) { // Create a font for the appearance of the signature var font = new XFont("Verdana", 10.0, XFontStyle.Regular); // Create a new PDF document var document = new PdfDocument(); var pdfPage = document.AddPage(); // Prepare graphics for drawing on the PDF page var xGraphics = XGraphics.FromPdfPage(pdfPage); var layoutRectangle = new XRect(0.0, 0.0, pdfPage.Width.Point, pdfPage.Height.Point); // Add some text to the page xGraphics.DrawString("Signed sample document", font, XBrushes.Black, layoutRectangle, XStringFormats.TopCenter); // Define digital signature appearance options var options = new DigitalSignatureOptions { ContactInfo = "John Doe", Location = "Seattle", Reason = "License Agreement", Rectangle = new XRect(36.0, 700.0, 400.0, 50.0), AppearanceHandler = new SignatureAppearanceHandler() }; // Sign the document using BouncyCastle signer var pdfSignatureHandler = DigitalSignatureHandler.ForDocument(document, new PdfSharp.Snippets.Pdf.BouncyCastleSigner(GetCertificate(), PdfMessageDigestType.SHA256), options); // Save the signed document document.Save("PdfSharpSignature.pdf"); } static (X509Certificate2, X509Certificate2Collection) GetCertificate() { // Locate the certificate file and read its data var certFolder = "C:\\Users\\kyess\\AppData\\Roaming\\Adobe\\Acrobat\\DC\\Security"; var pfxFile = Path.Combine(certFolder, "IronSoftware.pfx"); var rawData = File.ReadAllBytes(pfxFile); // Load the certificate using its password (example password) var certificatePassword = "Passw0rd"; var certificate = new X509Certificate2(rawData, certificatePassword, X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.Exportable); // Create and return the certificate collection var collection = new X509Certificate2Collection(); collection.Import(rawData, certificatePassword, X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.Exportable); return (certificate, collection); } } using System; using System.IO; using System.Security.Cryptography.X509Certificates; using PdfSharp.Drawing; using PdfSharp.Pdf; using BouncyCastleSigner; // Hypothetical namespace for illustration // Ensure that you have the appropriate namespaces added class Program { static void Main(string[] args) { // Create a font for the appearance of the signature var font = new XFont("Verdana", 10.0, XFontStyle.Regular); // Create a new PDF document var document = new PdfDocument(); var pdfPage = document.AddPage(); // Prepare graphics for drawing on the PDF page var xGraphics = XGraphics.FromPdfPage(pdfPage); var layoutRectangle = new XRect(0.0, 0.0, pdfPage.Width.Point, pdfPage.Height.Point); // Add some text to the page xGraphics.DrawString("Signed sample document", font, XBrushes.Black, layoutRectangle, XStringFormats.TopCenter); // Define digital signature appearance options var options = new DigitalSignatureOptions { ContactInfo = "John Doe", Location = "Seattle", Reason = "License Agreement", Rectangle = new XRect(36.0, 700.0, 400.0, 50.0), AppearanceHandler = new SignatureAppearanceHandler() }; // Sign the document using BouncyCastle signer var pdfSignatureHandler = DigitalSignatureHandler.ForDocument(document, new PdfSharp.Snippets.Pdf.BouncyCastleSigner(GetCertificate(), PdfMessageDigestType.SHA256), options); // Save the signed document document.Save("PdfSharpSignature.pdf"); } static (X509Certificate2, X509Certificate2Collection) GetCertificate() { // Locate the certificate file and read its data var certFolder = "C:\\Users\\kyess\\AppData\\Roaming\\Adobe\\Acrobat\\DC\\Security"; var pfxFile = Path.Combine(certFolder, "IronSoftware.pfx"); var rawData = File.ReadAllBytes(pfxFile); // Load the certificate using its password (example password) var certificatePassword = "Passw0rd"; var certificate = new X509Certificate2(rawData, certificatePassword, X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.Exportable); // Create and return the certificate collection var collection = new X509Certificate2Collection(); collection.Import(rawData, certificatePassword, X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.Exportable); return (certificate, collection); } } Imports System Imports System.IO Imports System.Security.Cryptography.X509Certificates Imports PdfSharp.Drawing Imports PdfSharp.Pdf Imports BouncyCastleSigner ' Hypothetical namespace for illustration ' Ensure that you have the appropriate namespaces added Friend Class Program Shared Sub Main(ByVal args() As String) ' Create a font for the appearance of the signature Dim font = New XFont("Verdana", 10.0, XFontStyle.Regular) ' Create a new PDF document Dim document = New PdfDocument() Dim pdfPage = document.AddPage() ' Prepare graphics for drawing on the PDF page Dim xGraphics = XGraphics.FromPdfPage(pdfPage) Dim layoutRectangle = New XRect(0.0, 0.0, pdfPage.Width.Point, pdfPage.Height.Point) ' Add some text to the page xGraphics.DrawString("Signed sample document", font, XBrushes.Black, layoutRectangle, XStringFormats.TopCenter) ' Define digital signature appearance options Dim options = New DigitalSignatureOptions With { .ContactInfo = "John Doe", .Location = "Seattle", .Reason = "License Agreement", .Rectangle = New XRect(36.0, 700.0, 400.0, 50.0), .AppearanceHandler = New SignatureAppearanceHandler() } ' Sign the document using BouncyCastle signer Dim pdfSignatureHandler = DigitalSignatureHandler.ForDocument(document, New PdfSharp.Snippets.Pdf.BouncyCastleSigner(GetCertificate(), PdfMessageDigestType.SHA256), options) ' Save the signed document document.Save("PdfSharpSignature.pdf") End Sub Private Shared Function GetCertificate() As (X509Certificate2, X509Certificate2Collection) ' Locate the certificate file and read its data Dim certFolder = "C:\Users\kyess\AppData\Roaming\Adobe\Acrobat\DC\Security" Dim pfxFile = Path.Combine(certFolder, "IronSoftware.pfx") Dim rawData = File.ReadAllBytes(pfxFile) ' Load the certificate using its password (example password) Dim certificatePassword = "Passw0rd" Dim certificate = New X509Certificate2(rawData, certificatePassword, X509KeyStorageFlags.MachineKeySet Or X509KeyStorageFlags.PersistKeySet Or X509KeyStorageFlags.Exportable) ' Create and return the certificate collection Dim collection = New X509Certificate2Collection() collection.Import(rawData, certificatePassword, X509KeyStorageFlags.MachineKeySet Or X509KeyStorageFlags.PersistKeySet Or X509KeyStorageFlags.Exportable) Return (certificate, collection) End Function End Class $vbLabelText $csharpLabel 出力 ここに示されているように、デジタル署名フィールドを作成し、新しい文書に証明書を適用することができましたが、そのプロセスは広範で手動的であり、実装する際にIronPDFのようなライブラリと比較して効率的ではありません。 IronPDFを使ってデジタル署名を追加する IronPDFは開発者にデジタル署名されたPDF文書のための簡潔な方法を提供します。 using IronPdf; using System.Security.Cryptography.X509Certificates; public class Program { static void Main(string[] args) { // Load the certificate with its password var sig = new PdfSignature("IronSoftware.pfx", "your-password"); // Configure additional signature details sig.TimestampHashAlgorithm = TimestampHashAlgorithms.SHA256; sig.TimestampUrl = "http://timestamp.digicert.com"; sig.SignatureImage = new PdfSignatureImage("IronPdf.png", 0, new Rectangle(150, 100, 200, 200)); // Sign and save the PDF document sig.SignPdfFile("output.pdf"); } } using IronPdf; using System.Security.Cryptography.X509Certificates; public class Program { static void Main(string[] args) { // Load the certificate with its password var sig = new PdfSignature("IronSoftware.pfx", "your-password"); // Configure additional signature details sig.TimestampHashAlgorithm = TimestampHashAlgorithms.SHA256; sig.TimestampUrl = "http://timestamp.digicert.com"; sig.SignatureImage = new PdfSignatureImage("IronPdf.png", 0, new Rectangle(150, 100, 200, 200)); // Sign and save the PDF document sig.SignPdfFile("output.pdf"); } } Imports IronPdf Imports System.Security.Cryptography.X509Certificates Public Class Program Shared Sub Main(ByVal args() As String) ' Load the certificate with its password Dim sig = New PdfSignature("IronSoftware.pfx", "your-password") ' Configure additional signature details sig.TimestampHashAlgorithm = TimestampHashAlgorithms.SHA256 sig.TimestampUrl = "http://timestamp.digicert.com" sig.SignatureImage = New PdfSignatureImage("IronPdf.png", 0, New Rectangle(150, 100, 200, 200)) ' Sign and save the PDF document sig.SignPdfFile("output.pdf") End Sub End Class $vbLabelText $csharpLabel 出力 このコードは、IronPDFのPdfSignatureクラスを使用してPDF文書に署名する方法を示しています。 プログラムはまず、.pfx証明書ファイルの場所とそのパスワードを指定してPdfSignatureオブジェクトを作成します。 その後、ハッシュアルゴリズム(SHA256)、タイムスタンプURL、および署名用のカスタム画像(IronPdf.png)などの追加署名プロパティを設定します。 最後に、SignPdfFileメソッドを呼び出して、PDF文書にデジタル署名を適用し、output.pdfとして保存します。 このプロセスは、タイムスタンプとビジュアルイメージとともにデジタル署名を埋め込むことによってPDFの整合性と真正性を保証します。 PDFSharp: MITライセンスのもとでオープンソース。 デジタル署名のような高度な機能のために外部ライブラリ(例: BouncyCastle)を必要とします。 IronPDF: 商用ライセンス(開発者と展開インスタンスに基づく価格設定)。 無料トライアル利用可能 開発用途に無料 結論: C#でのデジタル署名に関するIronPDF対PDFsharp デジタル署名をPDFに追加するための IronPDF と PDFsharp を比較したとき、プロジェクトのニーズに応じて両ライブラリは異なる利点を提供します。 IronPDFは、PDFにデジタル署名を適用するためのシンプルで使いやすいAPIを求める独立したフリーランスソフトウェア開発者や企業で働く開発者に最適であり、最新の機能を備えています。 デジタル署名の適用、HTMLからのPDF変換、およびその他のPDF機能とのシームレスな統合により、使いやすさと迅速な実装を優先する商業プロジェクトに最適です。 有料サポートと明確な商用ライセンス構造により、IronPDFは使いやすく、信頼性の高いソリューションを必要とする企業に適しています。 PDFsharpは、基本的なPDF作成と操作において優れていますが、IronPDFが提供する高度な機能やデジタル署名に対する直接的なサポートが欠如しています。 PDFsharpはオープンソースで無料で使用できる一方、IronPDFと比較してデジタル署名を扱うAPIは直感的ではなく、開発者はこれらの機能を処理するために追加のソリューションやサードパーティライブラリを採用する必要があるかもしれません。 要約すると、IronPDF はデジタル署名および関連するPDFタスクのためのシンプルで迅速なソリューションを求める開発者に最適な選択肢であり、特に商業環境で。 PDFsharpは基本的なPDFタスクにはより適していますが、デジタル署名のための使いやすさや機能セットが不足しているため、より単純なプロジェクトまたは追加のカスタマイズニーズのあるプロジェクトに適しています。 PDFsharpおよびBouncyCastleは、それぞれの所有者の登録商標です。 このサイトはPDFsharpまたはBouncyCastleとは提携、承認、またはスポンサーされていません。 すべての製品名、ロゴ、およびブランドは各所有者の所有物です。 比較は情報提供のみを目的としており、執筆時点で公開されている情報を反映しています。 よくある質問 デジタル署名はどのようにして PDF ドキュメントの信頼性と整合性を保証しますか? デジタル署名は、PDFドキュメントが署名された後に変更されていないことを確認する暗号技術を使用します。署名者の身元を確認し、ドキュメントの内容が変更されないように保証することで、セキュリティと法的な有効性を提供します。 PDFsharp を使用してデジタル署名を追加する際に、開発者が直面する可能性のある課題は何ですか? PDFsharp を使用してデジタル署名を追加する場合、通常、開発者は BouncyCastle などのサードパーティライブラリを統合する必要があります。この要件は、開発者がデジタル証明書を作成し、PDF に署名するために追加の依存関係を管理する必要があるため、実装プロセスを複雑にする可能性があります。 開発者がデジタル署名のためにオープンソースのライブラリより商用のPDFライブラリを選択する理由は何ですか? 商用用PDFライブラリは、高度な機能、Digital Signature のための組み込みサポート、およびユーザーフレンドリーなAPIを提供します。これらの属性により、特に時間と効率が重要な商用プロジェクトでは、迅速で信頼性の高いソリューションを求める開発者にとってより適しています。 .NET アプリケーションで HTML を PDF に変換する方法を教えてください。 .NETアプリケーションでは、IronPDF のようなライブラリを使用して HTML をPDFに変換できます。このライブラリは、HTML 文字列やファイルを直接 PDF ドキュメントに変換する RenderHtmlAsPdf などのメソッドを提供しており、さまざまなスタイリングやスクリプトのオプションをサポートしています。 商用プロジェクトでPDFを扱う場合にIronPDFを使用する利点は何ですか? IronPDF は、Digital Signature、HTML-to-PDF Conversion、フォーム処理を含むPDFを扱うための包括的な機能群を提供します。堅牢なサポートと使いやすいAPIにより、高度な機能性と迅速な展開を優先する商用プロジェクトに最適です。 .NETライブラリを使用してPDFのデジタル署名にタイムスタンプを追加できますか? はい、IronPDF のようなライブラリを使用すれば、署名設定でタイムスタンプサーバーのURLを指定することで、PDFのデジタル署名にタイムスタンプを追加できます。この機能は、署名されたドキュメントの信頼性と法令遵守を強化します。 デジタル署名の実装に最適なPDFライブラリを選ぶ際に考慮すべき要素は何ですか? デジタル署名のためのPDFライブラリを選ぶ際には、使いやすさ、高度な機能のサポート、サードパーティツールとの統合能力、商用ライブラリのようにより包括的であることの多い専用の顧客サポートの有無を考慮します。 カーティス・チャウ 今すぐエンジニアリングチームとチャット テクニカルライター Curtis Chauは、カールトン大学でコンピュータサイエンスの学士号を取得し、Node.js、TypeScript、JavaScript、およびReactに精通したフロントエンド開発を専門としています。直感的で美しいユーザーインターフェースを作成することに情熱を持ち、Curtisは現代のフレームワークを用いた開発や、構造の良い視覚的に魅力的なマニュアルの作成を楽しんでいます。開発以外にも、CurtisはIoT(Internet of Things)への強い関心を持ち、ハードウェアとソフトウェアの統合方法を模索しています。余暇には、ゲームをしたりDiscordボットを作成したりして、技術に対する愛情と創造性を組み合わせています。 関連する記事 公開日 12月 18, 2025 .NET Core開発で最大の価値を提供するASP PDFライブラリは? ASP.NET Core アプリケーションに最適な PDF ライブラリを発見しよう。IronPDF の Chrome エンジンを Aspose および Syncfusion の代替案と比較します。 詳しく読む 公開日 12月 3, 2025 IronPDF vs iTextSharp PDFドキュメントのヘッダーとフッター付きHTML to PDF PDFにヘッダーとフッターを追加するためのiTextSharpとIronPDFを比較します。コード例、ページ番号、HTMLヘッダーの実装。 詳しく読む 公開日 12月 3, 2025 iTextSharp HTML to PDFの "Document Has No Pages "エラーをIronPDFで解決 iTextSharp HTML to PDFでは、解析に失敗したときにページエラーが発生しません。XMLWorkerが同じ問題を抱えている理由を知り、HTML変換のためのIronPDFの信頼できるソリューションを発見してください。 詳しく読む IronPDF vs PDFsharp PDF-to-Image Conversion(コード例)PDFsharpでPDFからテキストを...
公開日 12月 18, 2025 .NET Core開発で最大の価値を提供するASP PDFライブラリは? ASP.NET Core アプリケーションに最適な PDF ライブラリを発見しよう。IronPDF の Chrome エンジンを Aspose および Syncfusion の代替案と比較します。 詳しく読む
公開日 12月 3, 2025 IronPDF vs iTextSharp PDFドキュメントのヘッダーとフッター付きHTML to PDF PDFにヘッダーとフッターを追加するためのiTextSharpとIronPDFを比較します。コード例、ページ番号、HTMLヘッダーの実装。 詳しく読む
公開日 12月 3, 2025 iTextSharp HTML to PDFの "Document Has No Pages "エラーをIronPDFで解決 iTextSharp HTML to PDFでは、解析に失敗したときにページエラーが発生しません。XMLWorkerが同じ問題を抱えている理由を知り、HTML変換のためのIronPDFの信頼できるソリューションを発見してください。 詳しく読む