首頁 > 後端開發 > C++ > 如何在 C# 中建立自簽名憑證?

如何在 C# 中建立自簽名憑證?

Mary-Kate Olsen
發布: 2025-01-13 10:03:43
原創
611 人瀏覽過

How to Create Self-Signed Certificates in C#?

使用C#建立自簽名憑證

在C#中,可以使用System.Security.Cryptography.X509Certificates.CertificateRequest類別輕鬆產生自簽名憑證。此方法提供了一種直接且特定於平台的方法來建立適用於本機加密用途的憑證。

憑證建立過程首先實例化一個ECDsa對象,該對象代表非對稱金鑰對。然後,使用必要的憑證資訊(包括申請者名稱、金鑰演算法和雜湊演算法)建立一個CertificateRequest實例。

最後一步是透過呼叫CreateSelfSigned方法來建立自簽名憑證。此方法使用起始日期和結束日期設定證書,並產生有效的X.509證書。

為了將私鑰儲存在PFX憑證(PKCS #12)中,請使用Export(X509ContentType.Pfx, "密码")匯出憑證。這允許使用密碼保護私鑰。

此外,透過使用Export(X509ContentType.Cert)匯出證書,您可以建立一個僅包含公鑰的Base64編碼CER檔案。如果您想公開共享憑證或從其他應用程式重複使用公鑰,這將非常有用。

以下程式碼範例示範了整個過程:

<code class="language-csharp">using System;
using System.IO;
using System.Security.Cryptography;
using System.Security.Cryptography.X509Certificates;

public class CertificateUtil
{
    public static void MakeCert()
    {
        var ecdsa = ECDsa.Create(); // 生成非对称密钥对
        var req = new CertificateRequest("cn=foobar", ecdsa, HashAlgorithmName.SHA256);
        var cert = req.CreateSelfSigned(DateTimeOffset.Now, DateTimeOffset.Now.AddYears(5));

        // 创建包含私钥的PFX (PKCS #12) 文件
        File.WriteAllBytes("c:\temp\mycert.pfx", cert.Export(X509ContentType.Pfx, "P@55w0rd"));

        // 创建Base64编码的CER (仅包含公钥) 文件
        File.WriteAllText("c:\temp\mycert.cer",
            "-----BEGIN CERTIFICATE-----\r\n"
            + Convert.ToBase64String(cert.Export(X509ContentType.Cert), Base64FormattingOptions.InsertLineBreaks)
            + "\r\n-----END CERTIFICATE-----");
    }
}</code>
登入後複製

此範例產生一個自簽名證書,其私鑰儲存在PFX格式中,公鑰儲存在Base64編碼的CER格式中。這些憑證可以匯入到Windows憑證儲存區中,或用於本機應用程式中的資料加密或解密。

以上是如何在 C# 中建立自簽名憑證?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板