attributecertificateholder.java
来自「bouncycastle 是一个JAVA安全提供者」· Java 代码 · 共 255 行
JAVA
255 行
package org.bouncycastle.x509;import org.bouncycastle.asn1.ASN1Sequence;import org.bouncycastle.asn1.ASN1Encodable;import org.bouncycastle.asn1.DERInteger;import org.bouncycastle.asn1.DERSequence;import org.bouncycastle.asn1.x509.GeneralName;import org.bouncycastle.asn1.x509.GeneralNames;import org.bouncycastle.asn1.x509.Holder;import org.bouncycastle.asn1.x509.IssuerSerial;import org.bouncycastle.jce.PrincipalUtil;import org.bouncycastle.jce.X509Principal;import java.io.IOException;import java.math.BigInteger;import java.security.Principal;import java.security.cert.CertSelector;import java.security.cert.Certificate;import java.security.cert.CertificateParsingException;import java.security.cert.CertificateEncodingException;import java.security.cert.X509Certificate;import java.util.ArrayList;import java.util.List;import javax.security.auth.x500.X500Principal;/** * The Holder object. * <pre> * Holder ::= SEQUENCE { * baseCertificateID [0] IssuerSerial OPTIONAL, * -- the issuer and serial number of * -- the holder's Public Key Certificate * entityName [1] GeneralNames OPTIONAL, * -- the name of the claimant or role * objectDigestInfo [2] ObjectDigestInfo OPTIONAL * -- used to directly authenticate the holder, * -- for example, an executable * } * </pre> * This holder currently supports use of the baseCertificateID and the entityName. */public class AttributeCertificateHolder implements CertSelector{ Holder holder; AttributeCertificateHolder( ASN1Sequence seq) { holder = Holder.getInstance(seq); } public AttributeCertificateHolder( X509Certificate cert) throws CertificateParsingException { X509Principal name; try { name = PrincipalUtil.getIssuerX509Principal(cert); } catch (Exception e) { throw new CertificateParsingException(e.getMessage()); } holder = new Holder(new IssuerSerial(generateGeneralNames(name), new DERInteger(cert.getSerialNumber()))); } public AttributeCertificateHolder( X509Principal principal) { holder = new Holder(generateGeneralNames(principal)); } public AttributeCertificateHolder( X500Principal principal) { try { holder = new Holder(generateGeneralNames(new X509Principal(principal.getEncoded()))); } catch (IOException e) { throw new IllegalArgumentException("Can't process principal"); } } private GeneralNames generateGeneralNames(X509Principal principal) { return new GeneralNames(new DERSequence(new GeneralName(principal))); } private boolean matchesDN(X509Principal subject, GeneralNames targets) { GeneralName[] names = targets.getNames(); for (int i = 0; i != names.length; i++) { GeneralName gn = names[i]; if (gn.getTagNo() == 4) { try { if (new X509Principal(((ASN1Encodable)gn.getName()).getEncoded()).equals(subject)) { return true; } } catch (IOException e) { } } } return false; } private Object[] getNames( GeneralName[] names) { List l = new ArrayList(names.length); for (int i = 0; i != names.length; i++) { if (names[i].getTagNo() == GeneralName.directoryName) { try { l.add(new X500Principal(((ASN1Encodable)names[i].getName()).getEncoded())); } catch (IOException e) { throw new RuntimeException("badly formed Name object"); } } } return l.toArray(new Object[l.size()]); } private Principal[] getPrincipals( GeneralNames names) { Object[] p = this.getNames(names.getNames()); List l = new ArrayList(); for (int i = 0; i != p.length; i++) { if (p[i] instanceof Principal) { l.add(p[i]); } } return (Principal[])l.toArray(new Principal[l.size()]); } /** * Return any principal objects inside the attribute certificate holder entity names field. * * @return an array of Principal objects (usually X500Principal), null if no entity names field is set. */ public Principal[] getEntityNames() { if (holder.getEntityName() != null) { return getPrincipals(holder.getEntityName()); } return null; } /** * Return the principals associated with the issuer attached to this holder * * @return an array of principals, null if no BaseCertificateID is set. */ public Principal[] getIssuer() { if (holder.getBaseCertificateID() != null) { return getPrincipals(holder.getBaseCertificateID().getIssuer()); } return null; } /** * Return the serial number associated with the issuer attached to this holder. * * @return the certificate serial number, null if no BaseCertificateID is set. */ public BigInteger getSerialNumber() { if (holder.getBaseCertificateID() != null) { return holder.getBaseCertificateID().getSerial().getValue(); } return null; } /* (non-Javadoc) * @see java.security.cert.CertSelector#clone() */ public Object clone() { return new AttributeCertificateHolder((ASN1Sequence)holder.toASN1Object()); } /* (non-Javadoc) * @see java.security.cert.CertSelector#match(java.security.cert.Certificate) */ public boolean match(Certificate cert) { if (!(cert instanceof X509Certificate)) { return false; } X509Certificate x509Cert = (X509Certificate)cert; try { if (holder.getBaseCertificateID() != null) { return holder.getBaseCertificateID().getSerial().getValue().equals(x509Cert.getSerialNumber()) && matchesDN(PrincipalUtil.getIssuerX509Principal(x509Cert), holder.getBaseCertificateID().getIssuer()); } if (holder.getEntityName() != null) { if (matchesDN(PrincipalUtil.getSubjectX509Principal(x509Cert), holder.getEntityName())) { return true; } } } catch (CertificateEncodingException e) { return false; } /** * objectDigestInfo not supported */ return false; }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?