Sign PDF Documents with an X.509 Certificate on a Hardware Device
TX Text Control can be used to retrieve certificates from a hardware device (such as the Windows certificate store, smart cards and PIV cards, USB tokens). This article shows how to use an X.509 certificate stored on a Windows machine in the Windows certificate store.

TX Text Control can digitally sign Adobe PDF and PDF/A documents with X.509 certificates. An X.509 certificate is a digital certificate that implements the widely accepted X.509 Public Key Infrastructure (PKI) standard that verifies that a specific public key belongs to a user, computer, or service identity contained in the certificate. The certificate can be assigned in the Save
Document Signing Methods
There are two approaches to signing PDF documents with TX Text Control:
- Sign the whole document with a digital certificate
- Sign individual signature fields with a digital certificate(s)
In both approaches, signatures can be created with PFX, DER Cer, or Base64 CER certificate files, loaded from raw data, or selected from the local certificate store.
Windows Certificate Store
The following method opens a dialog box that allows the user to select the desired certificate from the local Windows certificate store. The selected certificate is returned and can be used to sign the document or the signature fields in a PDF document.
The X509Certificate2UI class provides a user interface for selecting and viewing X.509 certificates. The following code uses the SelectFromCollection method to open a certificate selection dialog. All registered certificates, including smart cards, are listed in the dialog.
static X509Certificate2 RetrieveCertificate() {
// get and open certificate store for current user
X509Store store = new X509Store(StoreLocation.CurrentUser);
store.Open(OpenFlags.ReadOnly | OpenFlags.OpenExistingOnly);
// retrieve the certificate using the integrated Windows UI
X509Certificate2Collection selectedCertificates =
X509Certificate2UI.SelectFromCollection(
store.Certificates,
"Choose your certificate",
"Please select a certificate that is used to sign the PDF.",
X509SelectionFlag.SingleSelection);
// return the first selected certificate with a private key
foreach (var certificate in selectedCertificates) {
if (certificate.HasPrivateKey)
return certificate;
}
return null;
}
Signing the PDF
The CreateEncryptedPDF method takes the selected certificate and a document in the internal TX Text Control format and creates a PDF document signed with the given certificate.
public byte[] CreateEncryptedPDF(byte[] document, X509Certificate2 certificate) {
byte[] bPDF;
using (TXTextControl.ServerTextControl tx = new TXTextControl.ServerTextControl()) {
tx.Create();
tx.Load(document, TXTextControl.BinaryStreamType.InternalUnicodeFormat);
// apply the first selected certificate
TXTextControl.SaveSettings saveSettings = new TXTextControl.SaveSettings() {
DigitalSignature = new TXTextControl.DigitalSignature(certificate, null)
};
// save the document as PDF
tx.Save(out bPDF, TXTextControl.BinaryStreamType.AdobePDFA, saveSettings);
}
return bPDF;
}
The following code shows how to call this method with the certificate returned from the certificate store.
CreateEncryptedPDF(document, RetrieveCertificate());
The dialog box for selecting the certificate from the local Windows certificate store is shown in the following screenshot.

ASP.NET
Integrate document processing into your applications to create documents such as PDFs and MS Word documents, including client-side document editing, viewing, and electronic signatures.
- Angular
- Blazor
- React
- JavaScript
- ASP.NET MVC, ASP.NET Core, and WebForms
Related Posts
One More Stop on Our Conference Circus: code.talks 2026
Text Control is joining code.talks 2026 in Hamburg for the first time, a community-driven developer conference known for its strong technical focus and unique movie theater setting. We are excited…
ASP.NETASP.NET CoreDocument Processing
Build Your Own MCP-Powered Document Processing Backend with TX Text Control
This article explains how to create a document processing backend based on MCP using TX Text Control. It reveals structured tools that AI agents can identify and use. It showcases a clean…
TXTextControl.Markdown.Core 34.1.0-beta: Work with Full Documents,…
In this article, we will explore the new features and improvements in TXTextControl.Markdown.Core 34.1.0-beta, including working with full documents, selection, and SubTextParts. We will also…
ASP.NETASP.NET CoreDocument Editor
5 Layout Patterns for Integrating the TX Text Control Document Editor in…
When integrating a document editor into an ASP.NET Core application, the technical setup is only one part of the work. Just as important is the question of how the editor fits into the user…
ASP.NETASP.NET CoreTable Extraction
Extracting Structured Table Data from DOCX Word Documents in C# .NET with…
In this article, we build a domain-aware table extraction system using TX Text Control in C# .NET. The system automatically detects the table's domain, understands column semantics, and produces…
