📄 multicertstoretest.java
字号:
package org.bouncycastle.jce.provider.test;import org.bouncycastle.jce.MultiCertStoreParameters;import org.bouncycastle.jce.provider.BouncyCastleProvider;import org.bouncycastle.util.test.SimpleTest;import java.io.ByteArrayInputStream;import java.security.Security;import java.security.cert.CertStore;import java.security.cert.CertificateFactory;import java.security.cert.CollectionCertStoreParameters;import java.security.cert.X509CRL;import java.security.cert.X509CertSelector;import java.security.cert.X509Certificate;import java.util.ArrayList;import java.util.Collection;import java.util.List;public class MultiCertStoreTest extends SimpleTest{ public void performTest() throws Exception { basicTest(); } private void basicTest() throws Exception { CertificateFactory cf = CertificateFactory.getInstance("X.509", "BC"); X509Certificate rootCert = (X509Certificate)cf .generateCertificate(new ByteArrayInputStream( CertPathTest.rootCertBin)); X509Certificate interCert = (X509Certificate)cf .generateCertificate(new ByteArrayInputStream( CertPathTest.interCertBin)); X509Certificate finalCert = (X509Certificate)cf .generateCertificate(new ByteArrayInputStream( CertPathTest.finalCertBin)); X509CRL rootCrl = (X509CRL)cf.generateCRL(new ByteArrayInputStream( CertPathTest.rootCrlBin)); X509CRL interCrl = (X509CRL)cf .generateCRL(new ByteArrayInputStream( CertPathTest.interCrlBin)); // Testing CollectionCertStore generation from List List list = new ArrayList(); list.add(rootCert); list.add(interCert); list.add(finalCert); list.add(rootCrl); list.add(interCrl); CollectionCertStoreParameters ccsp = new CollectionCertStoreParameters(list); CertStore store1 = CertStore.getInstance("Collection", ccsp, "BC"); CertStore store2 = CertStore.getInstance("Collection", ccsp, "BC"); List storeList = new ArrayList(); storeList.add(store1); storeList.add(store2); CertStore store = CertStore.getInstance("Multi", new MultiCertStoreParameters(storeList)); // Searching for rootCert by subjectDN X509CertSelector targetConstraints = new X509CertSelector(); targetConstraints.setSubject(rootCert.getSubjectX500Principal().getName()); Collection certs = store.getCertificates(targetConstraints); if (certs.size() != 2 || !certs.contains(rootCert)) { fail("2 rootCerts not found by subjectDN"); } store = CertStore.getInstance("Multi", new MultiCertStoreParameters(storeList, false)); certs = store.getCertificates(targetConstraints); if (certs.size() != 1 || !certs.contains(rootCert)) { fail("1 rootCert not found by subjectDN"); } } public String getName() { return "MultiCertStore"; } public static void main(String[] args) { Security.addProvider(new BouncyCastleProvider()); runTest(new MultiCertStoreTest()); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -