![]() |
Como usar un Certificado desde el almacén de Windows y asignarle una password
Estamos intentando usar un certificado instalado en el almacén de windows para realizar la remisión a VeriFactu.
Para esto usamos el evento HTTPWebNode.OnNeedClientCertificate(const Sender: TObject; const ARequest: TURLRequest; const ACertificateList: TCertificateList var AnIndex: Integer); En este evento nos llega una lista de certificados válidos para el server de la AEAT y escogemos uno de ellos. Ahora bien, queremos que el proceso sea automático y en caso de que el certificado use una Passowrd nos salta la pantalla de Windows pidiendo la contraseña del certificado. Queríamos evitar esto. Se nos ocurren dos opciones: 1) Poder asignar por código la Password directamente al certificado escogido en el OnNeedCertificate pero solo podemos asignar el parámetro de salida AnIndex. 2) Sabemos que existe una forma de asignar las password de la siguiente forma: Cita:
Quizás hay alguna forma de exportar desde el Almacén de certificados de Windows hacia un Stream y así asignarlo directamente al HTTPWebNode.ClientCertificate.Stream y después la Password. ¿Alguien de aquí escoge el certificado desde el almacén o todos lo cargais desde un fichero? |
Cita:
Código:
|
Yo con el tema de certificados, lo que hago es cargarlos desde el almacen de certificados sobre una lista que luego asigno a los items de un combobox para poder seleccionar el certificado que usaré en el envio:
para cargar los certificados en un combo (cmbCertificados:TComboBox; //en el form )
y cuando se selecciona un certificado del combo se deja en una variable infoCertificado:string; el contenido del combo, el elemento seleccionado y es en el evento OnbeforePost del componente HTTPRIO donde asigno el certificado a partir de ese infocertificado. Esto plantea un problema en delphi10 y en delphi11 porque la declaracion de tipos es distinta y en delphi11 se accede directamente para asignar los datos del certificado: no asigno la password, cojo el certificado directamente del almacen; no sé si al usarlo desde alli necesito informar la password. Pero a mi me funciona ah, se necesita usar la libreria CAPICOM_TLB y tambien System.Net.HttpClient, System.Net.HttpClientComponent, Soap.Rio, Soap.SOAPHTTPClient, Soap.SOAPHTTPTrans, soap.win.certhelper puede que haya alguna de más, pero yo las tengo todas ellas puestas |
añado. he nombrado a unit DMEnvioLAF, es un tdatamodule propio donde he declarado la funcion carga certificados
|
snif!:confused:
me he olfidado una funcion importante que es la que carga infocertificado, pues no lo hace directamente, ya que los valores hexadecimales me aparecen cruzados. Para cargar infocertificado cuando el usuario elige un certificado del combo utilizo esto:
lamento la omisión |
me vais a matar, hace falta la funcion para obtener el numero de serie del certificado
ahora ya creo que esta todo. SI echarais algo en falta me lo decis. Esto me ha funcionado en Delphi Berlin y en Delphi Alexandria |
Muchísimas gracias javipes y bmfranky!!
En el caso de javipes sino te pide la contraseña ¿puede ser porque tu certificado no la requiera? nuestros certificados sí la requieren (estamos usando unos propios y otros como el DNIe) y en los dos casos nos salta la ventana de windows pidiendo la contraseña, y esto era lo que queríamos evitar cargando el certificado desde el almacén y asignandole pal password. De todas formas estamos estudiando los dos códigos, a ver si podemos tener algo en claro para nuestro caso. |
Cita:
Solo volveria a pedir la clave, al actualizar el certificado, una vez caducado. |
La franja horaria es GMT +2. Ahora son las 18:31:09. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi