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 (OSCE, OSCP, CEHv9)

Cyber Security Analyst em Banco Original
OSCE, OSCP, CEHv9, Pesquisador de Falhas de Segurança e Vulnerabilidades. Profissional com mais de 20 anos de experiência na área de TI, atualmente focado na área de segurança da informação ofensiva (Red Team), bug hunting, cyber threat hunting, criação e engenharia reversa de Malware.
Carreira baseada em sólidos conhecimentos técnicos nas principais tecnologias de TI: Penetration Testing, Clould Computing, Ambiente de alta criticidade e alta disponibilidade, Windows Servers e seus serviços, Linux Servers e seus serviços, VoIP com Asterisk, Redes, Cisco, HP, ISO 27002, Hacker ético (CEHv9) e Engenharia reversa.
Helvio Junior (OSCE, OSCP, CEHv9)
3 respostas

Deixe uma resposta

Want to join the discussion?
Feel free to contribute!

Deixe uma resposta

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