当前位置: 首页>>代码示例>>Java>>正文


Java SigningCertificate类代码示例

本文整理汇总了Java中org.bouncycastle.asn1.ess.SigningCertificate的典型用法代码示例。如果您正苦于以下问题:Java SigningCertificate类的具体用法?Java SigningCertificate怎么用?Java SigningCertificate使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


SigningCertificate类属于org.bouncycastle.asn1.ess包,在下文中一共展示了SigningCertificate类的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: verifySigningCertificateV1

import org.bouncycastle.asn1.ess.SigningCertificate; //导入依赖的package包/类
private void verifySigningCertificateV1(final BigInteger signingTokenSerialNumber, final GeneralNames signingTokenIssuerName,
		final Attribute signingCertificateAttributeV1) {

	final DigestAlgorithm digestAlgorithm = DigestAlgorithm.SHA1;
	final byte[] signingTokenCertHash = signingCertificateValidity.getCertificateToken().getDigest(digestAlgorithm);
	if (LOG.isDebugEnabled()) {
		LOG.debug("Candidate Certificate Hash {} with algorithm {}", Utils.toHex(signingTokenCertHash), digestAlgorithm.getName());
	}

	final ASN1Set attrValues = signingCertificateAttributeV1.getAttrValues();
	for (int ii = 0; ii < attrValues.size(); ii++) {

		final ASN1Encodable asn1Encodable = attrValues.getObjectAt(ii);
		final SigningCertificate signingCertificate = SigningCertificate.getInstance(asn1Encodable);
		final ESSCertID[] essCertIDs = signingCertificate.getCerts();
		for (final ESSCertID essCertID : essCertIDs) {

			final byte[] certHash = essCertID.getCertHash();
			signingCertificateValidity.setDigestPresent(true);
			if (LOG.isDebugEnabled()) {
				LOG.debug("Found Certificate Hash in signingCertificateAttributeV1 {} with algorithm {}", Utils.toHex(certHash), digestAlgorithm.getName());
			}
			final IssuerSerial issuerSerial = essCertID.getIssuerSerial();
			final boolean match = verifySigningCertificateReferences(signingTokenSerialNumber, signingTokenIssuerName, signingTokenCertHash, certHash,
					issuerSerial);
			if (match) {
				return;
			}
			LOG.warn(
					"RFC 2634: The first certificate identified in the sequence of certificate identifiers MUST be the certificate used to verify the signature.");
		}
	}
}
 
开发者ID:esig,项目名称:dss,代码行数:34,代码来源:CAdESSignature.java

示例2: TimeStampToken

import org.bouncycastle.asn1.ess.SigningCertificate; //导入依赖的package包/类
public TimeStampToken(CMSSignedData signedData)
    throws TSPException, IOException
{
    this.tsToken = signedData;

    if (!this.tsToken.getSignedContentTypeOID().equals(PKCSObjectIdentifiers.id_ct_TSTInfo.getId()))
    {
        throw new TSPValidationException("ContentInfo object not for a time stamp.");
    }
    
    Collection signers = tsToken.getSignerInfos().getSigners();

    if (signers.size() != 1)
    {
        throw new IllegalArgumentException("Time-stamp token signed by "
                + signers.size()
                + " signers, but it must contain just the TSA signature.");
    }

    tsaSignerInfo = (SignerInformation)signers.iterator().next();

    try
    {
        CMSProcessable content = tsToken.getSignedContent();
        ByteArrayOutputStream bOut = new ByteArrayOutputStream();

        content.write(bOut);

        ASN1InputStream aIn = new ASN1InputStream(new ByteArrayInputStream(bOut.toByteArray()));

        this.tstInfo = new TimeStampTokenInfo(TSTInfo.getInstance(aIn.readObject()));
        
        Attribute   attr = tsaSignerInfo.getSignedAttributes().get(PKCSObjectIdentifiers.id_aa_signingCertificate);

        if (attr != null)
        {
            SigningCertificate    signCert = SigningCertificate.getInstance(attr.getAttrValues().getObjectAt(0));

            this.certID = new CertID(ESSCertID.getInstance(signCert.getCerts()[0]));
        }
        else
        {
            attr = tsaSignerInfo.getSignedAttributes().get(PKCSObjectIdentifiers.id_aa_signingCertificateV2);

            if (attr == null)
            {
                throw new TSPValidationException("no signing certificate attribute found, time stamp invalid.");
            }

            SigningCertificateV2 signCertV2 = SigningCertificateV2.getInstance(attr.getAttrValues().getObjectAt(0));

            this.certID = new CertID(ESSCertIDv2.getInstance(signCertV2.getCerts()[0]));
        }
    }
    catch (CMSException e)
    {
        throw new TSPException(e.getMessage(), e.getUnderlyingException());
    }
}
 
开发者ID:Appdome,项目名称:ipack,代码行数:60,代码来源:TimeStampToken.java

示例3: TimeStampToken

import org.bouncycastle.asn1.ess.SigningCertificate; //导入依赖的package包/类
public TimeStampToken(CMSSignedData signedData)
        throws TSPException, IOException {
    this.tsToken = signedData;

    if (!this.tsToken.getSignedContentTypeOID().equals(
            PKCSObjectIdentifiers.id_ct_TSTInfo.getId())) {
        throw new TSPValidationException(
                "ContentInfo object not for a time stamp.");
    }

    Collection signers = tsToken.getSignerInfos().getSigners();

    if (signers.size() != 1) {
        throw new IllegalArgumentException(
                "Time-stamp token signed by "
                + signers.size()
                + " signers, but it must contain just the TSA signature.");
    }

    tsaSignerInfo = (SignerInformation) signers.iterator().next();

    try {
        CMSProcessable content = tsToken.getSignedContent();
        ByteArrayOutputStream bOut = new ByteArrayOutputStream();

        content.write(bOut);

        ASN1InputStream aIn = new ASN1InputStream(
                new ByteArrayInputStream(bOut.toByteArray()));

        this.tstInfo = new TimeStampTokenInfo(TSTInfo.getInstance(aIn.readObject()));

        Attribute attr = tsaSignerInfo.getSignedAttributes().get(
                PKCSObjectIdentifiers.id_aa_signingCertificate);

        if (attr == null) {
            throw new TSPValidationException(
                    "no signing certificate attribute found, time stamp invalid.");
        }

        SigningCertificate signCert = SigningCertificate.getInstance(attr.getAttrValues().getObjectAt(0));

        this.certID = ESSCertID.getInstance(signCert.getCerts()[0]);
    } catch (CMSException e) {
        throw new TSPException(e.getMessage(), e.getUnderlyingException());
    }
}
 
开发者ID:ruhr-universitaet-bochum,项目名称:jpdfsigner,代码行数:48,代码来源:TimeStampToken.java


注:本文中的org.bouncycastle.asn1.ess.SigningCertificate类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。