Sto tentando di eseguire il porting su JXTA per l'esecuzione su App Engine. Dato che il fornitore "BC" di BouncyCastle non è ancora supportato su App Engine, devo effettuare il porting del codice JXTA esistente per generare un X509Certificate usando le classi in white list. La mia conoscenza di Crypto è minima e non sono sicuro che ciò che sto cercando di realizzare sia persino possibile. Ecco il codice originale dal PSEUtils.java dal progetto JXTA:Generazione di X509Certificate utilizzando bouncycastle X509v3CertificateBuilder
C'è una classe di supporto che contiene la java.security.cert.X509Certificate:
public static class IssuerInfo {
public X509Certificate cert; // subject Cert
public PrivateKey subjectPkey; // subject private key
public X509Certificate issuer; // issuer Cert
public PrivateKey issuerPkey; // issuer private key
}
Nel metodo :
public static IssuerInfo genCert(X500Principal subject, KeyPair keypair, IssuerInfo issuerinfo)
sto passando nel soggetto come:
012.351.new X500Principal("CN="+useCN)
coppia di chiavi come (da codice originale):
KeyPairGenerator g = KeyPairGenerator.getInstance("RSA");
g.initialize(1024, UTILS.srng);
KeyPair keypair = g.generateKeyPair();
e la JXTA codificato IssuerInfo.
Ora, poiché non riesco a caricare i pacchetti bouncycastle.jce, ho dovuto rimuovere il codice X509Principal e X509V3CertificateGenerator che JXTA utilizza e provare a sostituirlo con un'implementazione conforme alle restrizioni GAE. Ecco cosa ho attualmente per il metodo genCert utilizzando org.bouncycastle.X509.X509v3CertificateBuilder.
SubjectPublicKeyInfo subPubKeyInfo = SubjectPublicKeyInfo.getInstance(keypair.getPublic().getEncoded());
X509v3CertificateBuilder v3CertGen = new X509v3CertificateBuilder(
new X500Name(issuer.getName()),
BigInteger.ONE,
today, until,
new X500Name(subject.getName()),
subPubKeyInfo);
Il problema è che non posso ottenere keypair.getPublic().getEncoded()
a lavorare con il metodo SubjectPublicKeyInfo.getInstance()
. Genera java.lang.IllegalArgumentException: oggetto sconosciuto in fabbrica: [B
chiave pubblica sembra essere popolato al momento dell'ispezione:
Sun RSA public key, 1024 bits
modulus: 117521430893506212334140912845641570591161279468597426442875306202350445904550279678434051874985419676760802566018092318362676224355315431299979507080364677679613392086245588766565617009250512996843008784370448997729071786062596049780632058501646041736216482596596901215941577208285499619376322050871534546271
public exponent: 65537
ho trovato il seguente Link SO che dimostra questo codice di lavoro:
il mio tentativo di convertire genCert è al di sotto, ma per qualche ragione, non posso andare oltre la creazione SubjectPublicKeyInfo dalla chiave pubblica codificata?
Qualsiasi aiuto è molto apprezzato.
public static IssuerInfo genCert(X500Principal subject, KeyPair keypair, IssuerInfo issuerinfo) {
IssuerInfo info = new IssuerInfo();
try {
// set up issuer
PrivateKey signer;
X500Principal issuer;
if (null == issuerinfo) { // self-signed root cert
signer = keypair.getPrivate();
issuer = new X500Principal(subject.getEncoded());
} else { // issuer signed service sert
signer = issuerinfo.subjectPkey;
X500Principal issuer_subject = issuerinfo.cert.getSubjectX500Principal();
issuer = new X500Principal(issuer_subject.getEncoded());
}
// set validity 10 years from today
Date today = new Date();
Calendar cal = Calendar.getInstance();
cal.setTime(today);
cal.add(Calendar.YEAR, 10);
Date until = cal.getTime();
SubjectPublicKeyInfo subPubKeyInfo = SubjectPublicKeyInfo.getInstance(keypair.getPublic().getEncoded());
//**Can't get here so i'm not sure if the rest of this works?**
AlgorithmIdentifier sigAlgId = new DefaultSignatureAlgorithmIdentifierFinder().find("SHA1withRSA");
AlgorithmIdentifier digAlgId = new DefaultDigestAlgorithmIdentifierFinder().find(sigAlgId);
RSAPrivateCrtKeyParameters cps = (RSAPrivateCrtKeyParameters) keypair.getPrivate();
ContentSigner sigGen = new BcRSAContentSignerBuilder(sigAlgId, digAlgId).build(cps);
X509CertificateHolder certHolder = v3CertGen.build(sigGen);
CertificateFactory cf = CertificateFactory.getInstance("X.509");
// Read user Certificate
InputStream is1 = new ByteArrayInputStream(certHolder.getEncoded());
X509Certificate eeCert = (X509Certificate) cf.generateCertificate(is1);
is1.close();
La prego di aggiornare questa classe come molti di questi metodi/classi sono ora deprecati in BC? – Reddy
BC ora è supportato in App Engine quindi non è necessario. –
@ChukDiesel Che ne dici di quelli che non utilizzano App Engine? Per favore? – Phil