Queste sono le differenze tra la revisione selezionata e la versione attuale della pagina.
Entrambe le parti precedenti la revisione Revisione precedente Prossima revisione | Revisione precedente | ||
guide_pubbliche:certificatitls:formaticertificati [2025/04/11 06:00] riccardo.cappone@unipr.it [Formati disponibili dei vari certificati TLS] |
guide_pubbliche:certificatitls:formaticertificati [2025/05/14 06:49] (versione attuale) riccardo.cappone@unipr.it |
||
---|---|---|---|
Linea 57: | Linea 57: | ||
</code> | </code> | ||
+ | ====== Generazione chiave privata e CSR ====== | ||
+ | HARICA mette a disposizione un tool grafico via web per generare chiavi private e CSR | ||
+ | |||
+ | https://www.harica.gr/en/Tools/KeyGeneration | ||
+ | |||
+ | E' altresì possibile creare le chiavi con il comando openssl su terminale Linux. | ||
+ | |||
+ | Raccomandiamo le seguenti best practice: | ||
+ | |||
+ | 1. Utilizzare Algoritmi Forti | ||
+ | RSA: Utilizzare una dimensione della chiave di almeno 2048 bit, ma 4096 bit è raccomandato per una maggiore sicurezza. | ||
+ | Curva Ellittica (EC): Utilizzare curve come prime256v1 o secp384r1 per una forte sicurezza. | ||
+ | |||
+ | 2. Utilizzare Archiviazione Sicura delle Chiavi | ||
+ | Moduli di Sicurezza Hardware (HSM): Archiviare le chiavi in HSM per sicurezza fisica. | ||
+ | File System Locale: Assicurarsi che le chiavi siano archiviate in modo sicuro con permessi appropriati. | ||
+ | |||
+ | 3. Crittografare le Chiavi Private | ||
+ | Crittografia AES-256: Crittografare le chiavi private con algoritmi di crittografia forti. | ||
+ | |||
+ | ===== Comandi per Generare Chiavi Private Sicure ===== | ||
+ | |||
+ | |||
+ | ^ Tipo di Chiave ^ Dimensione | Comando | | ||
+ | | RSA | 2048 | openssl genpkey -algorithm RSA -out rsa_2048.key -aes256 -pkeyopt rsa_keygen_bits:2048 | | ||
+ | | RSA | 3072 | openssl genpkey -algorithm RSA -out rsa_3072.key -aes256 -pkeyopt rsa_keygen_bits:3072 | | ||
+ | | RSA | 4096 | openssl genpkey -algorithm RSA -out rsa_4096.key -aes256 -pkeyopt rsa_keygen_bits:4096 | | ||
+ | |||
+ | ^ Tipo di Chiave ^ Curva | Comando per Generare la Chiave | Comando per Crittografare la Chiave | | ||
+ | | ECDSA | prime256v1 (256 bit) | openssl ecparam -name prime256v1 -genkey -noout -out ecdsa_256.key | openssl pkcs8 -topk8 -inform PEM -outform PEM -in ecdsa_256.key -out ecdsa_256_encrypted.key -v2 aes256 | | ||
+ | | ECDSA | secp384r1 (384 bit) | openssl ecparam -name secp384r1 -genkey -noout -out ecdsa_384.key | openssl pkcs8 -topk8 -inform PEM -outform PEM -in ecdsa_384.key -out ecdsa_384_encrypted.key -v2 aes256 | | ||
+ | |||
+ | ===== Comandi per Generare la CSR a partire dalle chiavi private ===== | ||
+ | |||
+ | | Tipo di Chiave | Curva/Dimensione ^ Comando per Generare la CSR ^ | ||
+ | | RSA | 2048 bit | openssl req -new -key rsa_2048.key -out rsa_2048.csr | | ||
+ | | RSA | 3072 bit | openssl req -new -key rsa_3072.key -out rsa_3072.csr | | ||
+ | | RSA | 4096 bit | openssl req -new -key rsa_4096.key -out rsa_4096.csr | | ||
+ | | ECDSA | prime256v1 (256 bit) | openssl req -new -key ecdsa_256_encrypted.key -out ecdsa_256.csr | | ||
+ | | ECDSA | secp384r1 (384 bit) | openssl req -new -key ecdsa_384_encrypted.key -out ecdsa_384.csr | | ||
+ | |||
+ | ====== Altri comandi utili da terminale con openssl ====== | ||
+ | |||
+ | ===== Leggere da un file contenente una catena di certificati (bundle) ===== | ||
+ | |||
+ | Output breve:\\ | ||
+ | <code> | ||
+ | openssl crl2pkcs7 -nocrl -certfile <nome_file_certificati_bundle>.pem | openssl pkcs7 -print_certs -noout | ||
+ | </code> | ||
+ | Output esteso:\\ | ||
+ | <code> | ||
+ | openssl crl2pkcs7 -nocrl -certfile <nome_file_certificati_bundle>.pem | openssl pkcs7 -print_certs -text -noout | ||
+ | </code> | ||
+ | |||
+ | ===== Verificare corrispondenza chiave privata - certificato - CSR ===== | ||
+ | |||
+ | Estrarre ed effettuare l'hash della chiave pubblica a partire dalla chiave privata:\\ | ||
+ | <code> | ||
+ | openssl rsa -noout -modulus -in server.key | openssl md5 | ||
+ | </code> | ||
+ | |||
+ | Dal certificato:\\ | ||
+ | <code> | ||
+ | openssl x509 -noout -modulus -in server.crt | openssl md5 | ||
+ | </code> | ||
+ | |||
+ | Dal CSR:\\ | ||
+ | <code> | ||
+ | openssl req -noout -modulus -in server.csr | openssl md5 | ||
+ | </code> | ||
+ | |||
+ | Gli hash devono essere uguali in tutti i tre casi. | ||
+ | |||
+ | ===== Chiave privata protetta da password ===== | ||
+ | |||
+ | Durante il wizard per la creazione del CSR viene generata la chiave privata, protetta da password e dunque cifrata. Se si desidera utilizzare la chiave privata in sistemi che non prevedono la decifratura, è possibile eliminare la cifratura con il seguente comando: | ||
+ | |||
+ | <code> | ||
+ | openssl rsa -in encrypted_key.pem -out decrypted_key.pem | ||
+ | </code> |