2013-07-22 20 views
5

Mi chiedo come estrarre le chiavi da un file .p12 di Apple. Dalla mia comprensione limitata, un file .p12 è una combinazione di certificati X504 e chiavi private.Estrarre più chiavi da un file .p12 utilizzando OpenSSL ruby ​​

Vedo che ogni file .p12 in cui viene eseguito ha un certificato X504 e almeno una chiave, e in alcune situazioni due chiavi. Ciò è dovuto al fatto che ogni .p12 ha una chiave di sviluppo Apple, e alcuni hanno una chiave extra (possibilmente una chiave di autorizzazione root Apple). Sto considerando solo quei file .p12 con due chiavi valide. Il mio obiettivo qui è di distinguere tra quei file .p12 che hanno una chiave e quelli che ne hanno due.

Finora ho utilizzato OpenSSL per poter ispezionare i file X504 e le chiavi di qualsiasi .p12. Per esempio io ho questo codice che fa i controlli per tutti i file in una directory p12:

Dir.glob('*.p12').each do |p| 
    file = File.read(p) 
    p12 = OpenSSL::PKCS12.new(file, "") 

    # note that this new certificate is in an X509 format 
    cert = p12.certificate 
    puts p12.inspect() 
    puts cert.inspect() 
end 

Questa è la mia uscita:

#<OpenSSL::PKCS12:0x007fcf33018920> 
#<OpenSSL::X509::Certificate subject=/UID=FFBMT4K5/CN=iPhone Distribution: A.H. Belo Management Services, Inc./OU=FFBMT4K5/O=FFBMT4K5/C=US, issuer=/C=US/O=Apple Inc./OU=Apple Worldwide Developer Relations/CN=Apple Worldwide Developer Relations Certification Authority, serial=36597980220620, not_before=2012-01-11 16:30:22 UTC, not_after=2013-01-10 16:30:22 UTC> 

chiavi Ora il mio problema sta ottenendo. Se faccio qualcosa di simile:

puts p12.key 

ottengo una lunga serie di dati cifrati in questo modo:

-----BEGIN RSA PRIVATE KEY----- 
MIIEowIBAAKCAQEA4Pet7CZrPr4x/SKjMwy5avXmcguzQlix/vBq+qq7aKQhctKr 
d5HE7wk4jWbDGj7Rf9ckeFFMktTTbKYmnKCywCct/uJmgavFl1+t45DIQL2V1JMU 
JSXvtjDXoKFweKQgdiha5mBNL70+ivqxMzJJw19E+MhFoZ6tFOgQ5gPLcDLR5WTU 
ezxH9RbXGWbq+CMBjJ+lw8/Ako7IOm+d95ZTM6u333qp0dsn+1/I/zGeWE1gJXIl 
8mIkvrp7+BDTvXHYALADwXnXijqvd/bANfetsDQ+gxRnc06dFt114JUuptcXGwbg 
//ykDzNYhuibQD1Z65KfTB/ntQ1aE5FtHEXirwIDAQABAoIBACNCrt/0pZqP9QXY 
B/xYYjeBkz0M2GvtuvhadmoTmIwuLY/xtS5oipVsvJBtKudSMUP4VJ8HHxlkgj7l 
S+gAyAOWIH9yvN5WLgIr3PVuG/UJwhIve1jXOVs1DJcAtsAx+WSLrrOtJGv3HXZr 
FJsRpr4YkJbtzPwoArjkJsHmllxfT2zeQPMJy+RQ/qlHUqsude/ahC0I3RiW3SgB 
EKTNM1vGTEkox8bUUhHqNY3ERlihFpZC2wSkroETDY3RkSjuPkNy7uT/b66a/qjj 
qaIA0YLhNOYGdN2llJN5GJjYYVKakpiipqcHCFrV1+JtbFB2tKhqAvK6fjCZcSFF 
fW58owECgYEA/g8FvAPcejPR3O8E1ydNWChhd9UZQUeQNCET+lY3Dxwklk+u1140 
yw/u2hUoNdJLfev1HtlYruglD9jW/LGoLaPodQfcHcaCSfdJa1mmKfSieApOe15+ 
ijO3WpZK/MJUTteGVMW/B/QnxPBGtsDo6q2v2YxA7fOhzmImn5hgxlsCgYEA4q/A 
DBKe1WDZPUyG3R/Cfl5AEqEHly6VkCPFF+uYFZzep/SN/ez34r7fmcfl0RL7H9kn 
Q4WBaCMbCgG9dErORW99usoBsjys5pojstNJDZwACUg9rPnV/+uUqMyocjeN0Vrl 
2Vg0dC8HH1hLZPLkp+MAy2nNzmnnHcTKiTqsDT0CgYEApVzfzaXxvvS1t4k37Fbf 
h+8YqefhfVT4LoYNO9ccFVCrG88XrYTa9gUT4Yz91DJiAr8vl/m+OHJPlUX9gRKd 
tb9HEc2g3xyTN1OmzSHX/t0FVv7WYIR79rZ8tJC4lFZki8DK5aikk6e+rvf5/wAH 
WqDcocwhgwAeJHhMTXrgGpsCgYBGYqWx2fJBdNHfK6zQafUdAazJXACcW5WK7OBc 
vgU56Lxl0BRqnLKXUAbjm+Lq2Qbqa6W6XHDC4euaXtHxkuybOLQEVIbUTeytqXye 
IOaU+DQ2rZyg4e4liYNeKjW/SSqar6ugobefv55piCPY02ZWDrEHd/G0PsPJRXpR 
w8r6TQKBgFMoEZKywokRIbMCUHHRR3TVeizBMhbNUUmOiRhzsHZPJ2V63PNp3L1c 
0NsRo62mbekXDRH8J0C8fLG4R64Y7+rHBQo0tBpgYepPU0NCrsojF7brtYYb3VqI 
baVEPRhIy2tJylDad6M36DeOCIhvXalh8GaV/HhEr4lxykth+mGH 
-----END RSA PRIVATE KEY----- 

La mia domanda è come posso determinare se questo certificato dispone di più di una chiave, e anche come posso ispezionare le chiavi per informazioni. Se quello che sto chiedendo o la mia comprensione di questo problema è fondamentalmente errata, per favore fatemelo sapere. Questa è la prima volta che viene esposto ai certificati e qualsiasi informazione sarà di grande aiuto. Tutti i punti nella giusta direzione saranno apprezzati, grazie in anticipo.

EDIT:

Utilizzando OpenSSL posso visualizzare le due keybags avvolti di un .p12. Esempio:

openssl pkcs12 -in some_p12.p12 -info -noout 

uscita:

Enter Import Password: 
MAC Iteration 1 
MAC verified OK 
PKCS7 Encrypted data: pbeWithSHA1And40BitRC2-CBC, Iteration 2048 
Certificate bag 
Certificate bag 
PKCS7 Data 
Shrouded Keybag: pbeWithSHA1And3-KeyTripleDES-CBC, Iteration 2048 
Shrouded Keybag: pbeWithSHA1And3-KeyTripleDES-CBC, Iteration 2048 

Quindi sto cercando un paio di cose. In generale, quali sono esattamente questi portachiavi? E inoltre, come posso controllarli/determinare quanti ne ho per il file .p12 usando Ruby. Grazie.

risposta

0

A .p12 contiene solo 1 chiave privata e contiene 1 o più chiavi pubbliche. Le chiavi pubbliche sono quelle che fanno la catena della fiducia.

.p12 è un formato binario. Per convertirlo ed estrarlo in singoli certificati, cerca ad esempio here. Il link contiene tutti i comandi di openssl di cui hai bisogno.

Problemi correlati