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 + -
显示快捷键?