Instalando certificado digital no windows com C#

Este post objetiva mostrar como realizar a instalação de um certificado digital na base de certificados pessoais do usuário através de um aplicativo C#.

Quando executado o aplicativo o certificado será instalado na base de certificados pessoais do usuário executor do aplicativo.

Segue o código:

using System;
using System.Security.Cryptography;
using System.Security.Cryptography.X509Certificates;
using System.IO;

namespace InstallCertificate
{
 class Program
 {
 public static void Main(string[] args)
 {
 try {
 InstallCertificate(args[0], args[1]);

 } catch (Exception ex) {
 Console.WriteLine( ex.Message);
 }

 Console.Write("");
 Console.Write("Press any key to continue . . . ");
 Console.ReadKey(true);
 }

 private static void InstallCertificate(string certificatePath, string certificatePassword)
 {
 try
 {
 var serviceRuntimeUserCertificateStore = new X509Store(StoreName.My);
 serviceRuntimeUserCertificateStore.Open(OpenFlags.ReadWrite);

 X509Certificate2 cert;

 try
 {
 cert = new X509Certificate2(certificatePath, certificatePassword);
 }
 catch(Exception ex)
 {
 Console.WriteLine("Failed to load certificate " + certificatePath + ": " + ex.Message);
 throw new Exception("Certificate appeared to load successfully but also seems to be null.", ex);
 }

 serviceRuntimeUserCertificateStore.Add(cert);
 serviceRuntimeUserCertificateStore.Close();
 Console.WriteLine("Installation OK!");
 }
 catch(Exception ex)
 {
 Console.WriteLine("Failed to install {0}. Check the certificate index entry and verify the certificate file exists.\n {1}", certificatePath, ex.Message);
 }
 }

 }
}
Helvio Junior

Helvio Junior

Gerente de Infraestrutura de TI e Telecomunicações em Fael, uma empresa do grupo Apollo Global
Especialista em redes e segurança de sistemas pela PUC-PR, consultor de redes e segurança da informação. CEO e CTO da SafeTrend, com um produto de single sign-on e gestão de identidades e acessos. Especialista em Segurança da Informação, Controle de Acesso, ambientes e ferramentas de segurança, telefonia VoIP com Asterisk, administração de redes em ambientes híbridos e realização de penetration test (pentest).
Helvio Junior
3 respostas
  1. Eduardo Oliveira
    Eduardo Oliveira says:

    Helvio,

    O seu código me ajudou muito quando estávamos testando localmente, em uma máquina com Windows 10, mas ao enviar o código para um servidor com o Windows Server 2012, infelizmente não funcionou.
    Você tem alguma ideia do que seja, se é preciso alguma configuração específica para o Server ou alguma alteração no código?
    Obrigado!

    Responder

Deixe uma resposta

Want to join the discussion?
Feel free to contribute!

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios são marcados com *