Добавление атрибутов в запрос сертификата, java + bouncycastle 1.48
В настоящее время я работаю над созданием запросов сертификатов атрибутов, используя bouncycastle 1.48. Поскольку в API произошли некоторые изменения (и я новичок в этом вопросе), я не могу добавить атрибуты к созданному запросу. Мой текущий код
KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA");
keyGen.initialize(512);
KeyPair rsaKey = keyGen.generateKeyPair();
PrivateKey privateKey = rsaKey.getPrivate();
PublicKey publicKey = rsaKey.getPublic();
System.out.println(privateKey.getEncoded());
System.out.println(publicKey.getEncoded());
ContentSigner sigGen = new JcaContentSignerBuilder("SHA1withRSA").build(privateKey);
AlgorithmIdentifier rsaEncryption = new AlgorithmIdentifier(PKCSObjectIdentifiers.rsaEncryption, null);
SubjectPublicKeyInfo publicKeyInfo = new SubjectPublicKeyInfo(rsaEncryption, publicKey.getEncoded());
Date startDate = new Date(System.currentTimeMillis() - 24 * 60 * 60 * 1000);
Date endDate = new Date(System.currentTimeMillis() + 365 * 24 * 60 * 60 * 1000);
X500NameBuilder nameBuilder = new X500NameBuilder();
nameBuilder.addRDN(BCStyle.CN, "test request");
nameBuilder.addRDN(BCStyle.C, "UK");
nameBuilder.addRDN(BCStyle.E,"qwerasd@gmail.com");
nameBuilder.addRDN(BCStyle.GENDER,"M");
X500Name name = nameBuilder.build();
PKCS10CertificationRequestBuilder genReq = new PKCS10CertificationRequestBuilder(name,publicKeyInfo);
PKCS10CertificationRequest request = genReq.build(sigGen);
PEMWriter pemWriter = new PEMWriter(new FileWriter(new File("C:\\certs\\request.txt")));
pemWriter.writeObject(request);
pemWriter.flush();
Мой вопрос - как должен выглядеть правильный синтаксис для метода addAttribute? заранее спасибо
1 ответ
Это зависит от того, что вы хотите добавить. Главное помнить, что атрибуты в запросе сертификата и расширения в сертификате - это не одно и то же. Обычно люди пытаются добавить одно или несколько расширений, но в этом случае вам нужно использовать соответствующий атрибут PKCS#9 для обозначения этого, а не OID, связанный с расширением.
Скажем, например, что вы хотите запросить конкретное расширение KeyUsage от CA, у вас будет что-то вроде:
ExtensionsGenerator extGen = new ExtensionsGenerator();
extGen.addExtension(Extension.keyUsage, true, new KeyUsage(KeyUsage.keyCertSign | KeyUsage.cRLSign));
genReq.addAttribute(PKCSObjectIdentifiers.pkcs_9_at_extensionRequest, extGen.generate());
CA должен предполагать, что блок extensionRequest будет содержать нужные вам расширения.