當前位置: 首頁>>代碼示例>>Java>>正文


Java X509Certificate.getSerialNumber方法代碼示例

本文整理匯總了Java中java.security.cert.X509Certificate.getSerialNumber方法的典型用法代碼示例。如果您正苦於以下問題:Java X509Certificate.getSerialNumber方法的具體用法?Java X509Certificate.getSerialNumber怎麽用?Java X509Certificate.getSerialNumber使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.security.cert.X509Certificate的用法示例。


在下文中一共展示了X509Certificate.getSerialNumber方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: main

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {

        byte[] data = "Hello".getBytes();
        X500Name n = new X500Name("cn=Me");

        CertAndKeyGen cakg = new CertAndKeyGen("RSA", "SHA256withRSA");
        cakg.generate(1024);
        X509Certificate cert = cakg.getSelfCertificate(n, 1000);

        MessageDigest md = MessageDigest.getInstance("SHA-256");
        PKCS9Attributes authed = new PKCS9Attributes(new PKCS9Attribute[]{
            new PKCS9Attribute(PKCS9Attribute.CONTENT_TYPE_OID, ContentInfo.DATA_OID),
            new PKCS9Attribute(PKCS9Attribute.MESSAGE_DIGEST_OID, md.digest(data)),
        });

        Signature s = Signature.getInstance("SHA256withRSA");
        s.initSign(cakg.getPrivateKey());
        s.update(authed.getDerEncoding());
        byte[] sig = s.sign();

        SignerInfo signerInfo = new SignerInfo(
                n,
                cert.getSerialNumber(),
                AlgorithmId.get("SHA-256"),
                authed,
                AlgorithmId.get("SHA256withRSA"),
                sig,
                null
                );

        PKCS7 pkcs7 = new PKCS7(
                new AlgorithmId[] {signerInfo.getDigestAlgorithmId()},
                new ContentInfo(data),
                new X509Certificate[] {cert},
                new SignerInfo[] {signerInfo});

        if (pkcs7.verify(signerInfo, data) == null) {
            throw new Exception("Not verified");
        }
    }
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:41,代碼來源:NonStandardNames.java

示例2: getCertificate

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/**
 * Returns the X.509 certificate listed in this PKCS7 block
 * which has a matching serial number and Issuer name, or
 * null if one is not found.
 *
 * @param serial the serial number of the certificate to retrieve.
 * @param issuerName the Distinguished Name of the Issuer.
 */
public X509Certificate getCertificate(BigInteger serial, X500Name issuerName) {
    if (certificates != null) {
        if (certIssuerNames == null)
            populateCertIssuerNames();
        for (int i = 0; i < certificates.length; i++) {
            X509Certificate cert = certificates[i];
            BigInteger thisSerial = cert.getSerialNumber();
            if (serial.equals(thisSerial)
                && issuerName.equals(certIssuerNames[i]))
            {
                return cert;
            }
        }
    }
    return null;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:25,代碼來源:PKCS7.java

示例3: signatureBlock

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/** Write a .RSA file with a digital signature. */
private static void signatureBlock(
        Signature signature,
        X509Certificate publicKey,
        OutputStream out)
        throws IOException, GeneralSecurityException {
    SignerInfo signerInfo = new SignerInfo(
            new X500Name(publicKey.getIssuerX500Principal().getName()),
            publicKey.getSerialNumber(),
            AlgorithmId.get("SHA1"),
            AlgorithmId.get("RSA"),
            signature.sign());
    
    PKCS7 pkcs7 = new PKCS7(
            new AlgorithmId[] { AlgorithmId.get("SHA1") },
            new ContentInfo(ContentInfo.DATA_OID, null),
            new X509Certificate[] { publicKey },
            new SignerInfo[] { signerInfo });
    
    System.out.print("\rGenerating signature block...");
    
    pkcs7.encodeSignedData(out);
}
 
開發者ID:KuroroLucilfer,項目名稱:PackageSigner2,代碼行數:24,代碼來源:Signer.java

示例4: checkServerTrusted

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
@Override
public void checkServerTrusted(X509Certificate[] chain, String authType)
    throws CertificateException
{
  trustManager.checkServerTrusted(chain, authType);

  for (X509Certificate certificate : chain) {
    for (Pair<String, BigInteger> blacklistedSerial : BLACKLIST) {
      if (certificate.getIssuerDN().getName().equals(blacklistedSerial.first()) &&
          certificate.getSerialNumber().equals(blacklistedSerial.second()))
      {
        throw new CertificateException("Blacklisted Serial: " + certificate.getSerialNumber());
      }
    }
  }

}
 
開發者ID:XecureIT,項目名稱:PeSanKita-lib,代碼行數:18,代碼來源:BlacklistingTrustManager.java

示例5: writeSignatureBlock

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/** Write the certificate file with a digital signature. */
private void writeSignatureBlock(Signature signature, X509Certificate publicKey,
        PrivateKey privateKey)
        throws IOException, GeneralSecurityException {
    SignerInfo signerInfo = new SignerInfo(
            new X500Name(publicKey.getIssuerX500Principal().getName()),
            publicKey.getSerialNumber(),
            AlgorithmId.get(DIGEST_ALGORITHM),
            AlgorithmId.get(privateKey.getAlgorithm()),
            signature.sign());

    PKCS7 pkcs7 = new PKCS7(
            new AlgorithmId[] { AlgorithmId.get(DIGEST_ALGORITHM) },
            new ContentInfo(ContentInfo.DATA_OID, null),
            new X509Certificate[] { publicKey },
            new SignerInfo[] { signerInfo });

    pkcs7.encodeSignedData(mOutputJar);
}
 
開發者ID:tranleduy2000,項目名稱:javaide,代碼行數:20,代碼來源:SignedJarBuilder.java

示例6: engineGetCertificateAlias

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/** {@inheritDoc} */
@Override
public String engineGetCertificateAlias(final Certificate cert) {
    if (!(cert instanceof X509Certificate)) {
        return null;
    }
    final BigInteger serial = ((X509Certificate) cert).getSerialNumber();
    final X500Principal principal = ((X509Certificate) cert).getIssuerX500Principal();
    for (final String alias : userCertAliases) {
    	final X509Certificate c = (X509Certificate) engineGetCertificate(alias);
        if (c.getSerialNumber() == serial && principal.equals(principal)) {
            return alias;
        }
    }
    return null;
}
 
開發者ID:MiFirma,項目名稱:mi-firma-android,代碼行數:17,代碼來源:CeresKeyStoreImpl.java

示例7: getID

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/**
 * build [alias + issuer + serialNumber] string from a cert
 */
private String getID(String alias, X509Certificate cert) {
    X500Principal issuer = cert.getIssuerX500Principal();
    BigInteger serialNum = cert.getSerialNumber();

    return alias +
            ALIAS_SEP +
            issuer.getName(X500Principal.CANONICAL) +
            ALIAS_SEP +
            serialNum.toString();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:14,代碼來源:P11KeyStore.java

示例8: XMLX509IssuerSerial

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/**
 * Constructor XMLX509IssuerSerial
 *
 * @param doc
 * @param x509certificate
 */
public XMLX509IssuerSerial(Document doc, X509Certificate x509certificate) {
    this(
        doc,
        x509certificate.getIssuerX500Principal().getName(),
        x509certificate.getSerialNumber()
    );
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:14,代碼來源:XMLX509IssuerSerial.java

示例9: JceKeyAgreeRecipientId

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
public JceKeyAgreeRecipientId(X509Certificate certificate)
{
    this(certificate.getIssuerX500Principal(), certificate.getSerialNumber());
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:5,代碼來源:JceKeyAgreeRecipientId.java

示例10: getSerialNumber

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
public BigInteger getSerialNumber() {
    X509Certificate cert = getCertificateList().get(0);
    return cert.getSerialNumber();
}
 
開發者ID:Hitachi-Data-Systems,項目名稱:Open-DM,代碼行數:5,代碼來源:SSLCertChain.java

示例11: getSerialNumberString

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
public String getSerialNumberString() {
    X509Certificate cert = getCertificateList().get(0);
    BigInteger sn = cert.getSerialNumber();
    return byteArrayToColonSeparatedHexString(sn.toByteArray(), ":");
}
 
開發者ID:Hitachi-Data-Systems,項目名稱:Open-DM,代碼行數:6,代碼來源:SSLCertChain.java

示例12: X509IssuerSerial

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/**
 * Construct an X509IssuerSerial from an X509Certificate.
 */
X509IssuerSerial(X509Certificate cert) {
    this(cert.getIssuerX500Principal(), cert.getSerialNumber());
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:7,代碼來源:X509CRLImpl.java

示例13: JcaX509CertificateHolderSelector

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/**
 * Construct a signer identifier based on the issuer, serial number and subject key identifier (if present) of the passed in
 * certificate.
 *
 * @param certificate certificate providing the issue and serial number and subject key identifier.
 */
public JcaX509CertificateHolderSelector(X509Certificate certificate)
{
    super(convertPrincipal(certificate.getIssuerX500Principal()), certificate.getSerialNumber(), getSubjectKeyId(certificate));
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:11,代碼來源:JcaX509CertificateHolderSelector.java

示例14: JceKeyTransRecipientId

import java.security.cert.X509Certificate; //導入方法依賴的package包/類
/**
 * Construct a recipient id based on the issuer, serial number and subject key identifier (if present) of the passed in
 * certificate.
 *
 * @param certificate certificate providing the issue and serial number and subject key identifier.
 */
public JceKeyTransRecipientId(X509Certificate certificate)
{
    super(convertPrincipal(certificate.getIssuerX500Principal()), certificate.getSerialNumber(), CMSUtils.getSubjectKeyId(certificate));
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:11,代碼來源:JceKeyTransRecipientId.java


注:本文中的java.security.cert.X509Certificate.getSerialNumber方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。