• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Java Certificate类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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



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

示例1: getCertFingerPrint

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
/**
 * @return sha-256 string based on cert in keystore
 */
public static String getCertFingerPrint(String storePath, String alias,String pass) {
    try {
        Certificate cert = DTLSUtils.loadCert(storePath,
                alias,
                pass);

        byte[] der = cert.getCertificateAt(0).getEncoded();
        MessageDigest md = MessageDigest.getInstance("SHA-256");
        byte[] dat = md.digest(der);

        String fingerprint = createFingerprintString(dat);
        logger.info("Local cert signature is {} ",fingerprint);
        return fingerprint;
    } catch (Exception e) {
        logger.error("Failed to create cert fingerprint from {}",storePath ,e);
        throw new IllegalStateException("Loading certificate failed");
    }
}
 
开发者ID:IIlllII,项目名称:bitbreeds-webrtc,代码行数:22,代码来源:CertUtil.java


示例2: main

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static void main(String[] args) throws IOException, CertificateException, NoSuchProviderException {
	Security.addProvider(new BouncyCastleProvider());
	final X509Certificate clientCertX509 = CertificateClientManagement.loadCertificate("secure/cert/test.crt");
	final Certificate clientCert = new Certificate(new org.bouncycastle.asn1.x509.Certificate[] {org.bouncycastle.asn1.x509.Certificate.getInstance(clientCertX509.getEncoded())});
	final KeyPair clientKeyPair = CertificateClientManagement.loadKey("secure/cert/test.key", clientCertX509.getPublicKey());
	Socket socket = new Socket("localhost", 4444);
	TlsClientProtocol tlsClientProtocol = new CustomTlsClientProtocol(socket.getInputStream(), socket.getOutputStream());
	tlsClientProtocol.connect(new CustomTlsClient(clientKeyPair, clientCert));
	System.out.println("auth finished");

	while (true);
}
 
开发者ID:oberien,项目名称:Oberien,代码行数:13,代码来源:TlsClientTest.java


示例3: fingerprint

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
static String fingerprint(org.bouncycastle.asn1.x509.Certificate c)
    throws IOException
{
    byte[] der = c.getEncoded();
    byte[] sha1 = sha256DigestOf(der);
    byte[] hexBytes = Hex.encode(sha1);
    String hex = new String(hexBytes, "ASCII").toUpperCase();

    StringBuffer fp = new StringBuffer();
    int i = 0;
    fp.append(hex.substring(i, i + 2));
    while ((i += 2) < hex.length())
    {
        fp.append(':');
        fp.append(hex.substring(i, i + 2));
    }
    return fp.toString();
}
 
开发者ID:credentials,项目名称:irma_future_id,代码行数:19,代码来源:TlsTestUtils.java


示例4: createServerTransport

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
static DTLSTransport createServerTransport(final RTCCertificate rtcCertificate,
                                           final DatagramTransport transport) throws IOException {

    final DefaultTlsServer defaultTlsServer = new DefaultTlsServer() {

        private final AsymmetricKeyParameter privateKeyAsymKeyParam = PrivateKeyFactory.createKey(rtcCertificate.getKeyPair()
                                                                                                                .getPrivate()
                                                                                                                .getEncoded());
        private final Certificate cCert = new Certificate(new org.bouncycastle.asn1.x509.Certificate[]{rtcCertificate.getCertificate().toASN1Structure()});

        @Override
        protected ProtocolVersion getMaximumVersion() {
            return ProtocolVersion.DTLSv10;
        }

        @Override
        protected ProtocolVersion getMinimumVersion() {
            return ProtocolVersion.DTLSv10;
        }

        @Override
        protected TlsSignerCredentials getRSASignerCredentials() throws IOException {
            return new DefaultTlsSignerCredentials(this.context,
                                                   this.cCert,
                                                   this.privateKeyAsymKeyParam);
        }
    };

    return new DTLSServerProtocol(SECURE_RANDOM).accept(defaultTlsServer,
                                                        transport);
}
 
开发者ID:Zubnix,项目名称:rtcdcjava,代码行数:32,代码来源:DTLSTransportFactory.java


示例5: createClientTransport

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
static DTLSTransport createClientTransport(final DatagramTransport transport) throws IOException {

        final DefaultTlsClient defaultTlsClient = new DefaultTlsClient() {

            @Override
            public ProtocolVersion getClientVersion() {
                return ProtocolVersion.DTLSv10;
            }

            @Override
            public ProtocolVersion getMinimumVersion() {
                return ProtocolVersion.DTLSv10;
            }

            @Override
            public TlsAuthentication getAuthentication() throws IOException {

                return new ServerOnlyTlsAuthentication() {
                    @Override
                    public void notifyServerCertificate(final Certificate serverCertificate) throws IOException {
                        //TODO Check if certificate is signed by a trusted party.
                    }
                };
            }
        };

        return new DTLSClientProtocol(SECURE_RANDOM).connect(defaultTlsClient,
                                                             transport);
    }
 
开发者ID:Zubnix,项目名称:rtcdcjava,代码行数:30,代码来源:DTLSTransportFactory.java


示例6: unmarshal

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
@Override
public Certificate unmarshal(String v) throws Exception {

    Certificate cert = Certificate.parse(new ByteArrayInputStream(ArrayConverter.hexStringToByteArray(v.replaceAll(
            "\\s+", ""))));
    return cert;
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:8,代码来源:CertificateAdapter.java


示例7: adjustTLSContext

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
@Override
public void adjustTLSContext(CertificateMessage message) {
    Certificate cert;
    if (tlsContext.getChooser().getSelectedProtocolVersion().isTLS13()) {
        ByteArrayOutputStream stream = new ByteArrayOutputStream();
        int certificatesLength = 0;
        try {
            for (CertificatePair pair : message.getCertificatesList()) {
                stream.write(ArrayConverter.intToBytes(pair.getCertificateLength().getValue(),
                        HandshakeByteLength.CERTIFICATE_LENGTH));
                stream.write(pair.getCertificate().getValue());
                certificatesLength += pair.getCertificateLength().getValue()
                        + HandshakeByteLength.CERTIFICATE_LENGTH;
            }
        } catch (IOException ex) {
            throw new AdjustmentException("Could not concatenate certificates bytes", ex);
        }
        cert = parseCertificate(certificatesLength, stream.toByteArray());
    } else {
        cert = parseCertificate(message.getCertificatesListLength().getValue(), message.getCertificatesListBytes()
                .getValue());
    }
    if (tlsContext.getTalkingConnectionEndType() == ConnectionEndType.CLIENT) {
        LOGGER.debug("Setting ClientCertificate in Context");
        tlsContext.setClientCertificate(cert);
    } else {
        LOGGER.debug("Setting ServerCertificate in Context");
        tlsContext.setServerCertificate(cert);
    }
    if (cert != null) {
        adjustPublicKeyParameters(cert);
    }
    if (tlsContext.getChooser().getSelectedProtocolVersion().isTLS13()) {
        adjustExtensions(message);
    }
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:37,代码来源:CertificateHandler.java


示例8: adjustPublicKeyParameters

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
private void adjustPublicKeyParameters(Certificate cert) {
    try {
        if (CertificateUtils.hasDHParameters(cert)) {
            LOGGER.debug("Adjusting DH PublicKey");
            DHPublicKeyParameters dhParameters = CertificateUtils.extractDHPublicKeyParameters(cert);
            adjustDHParameters(dhParameters);
        } else if (CertificateUtils.hasECParameters(cert)) {
            LOGGER.debug("Adjusting EC PublicKey");
            ECPublicKeyParameters ecParameters = CertificateUtils.extractECPublicKeyParameters(cert);
            adjustECParameters(ecParameters);
        } else if (CertificateUtils.hasRSAParameters(cert)) {
            LOGGER.debug("Adjusting RSA PublicKey");
            if (tlsContext.getTalkingConnectionEndType() == ConnectionEndType.CLIENT) {
                tlsContext.setClientRSAPublicKey(CertificateUtils.extractRSAPublicKey(cert));
                tlsContext.setClientRSAPrivateKey(tlsContext.getConfig().getDefaultClientRSAPrivateKey());
                tlsContext.setClientRsaModulus(CertificateUtils.extractRSAModulus(cert));
            } else {
                tlsContext.setServerRSAPublicKey(CertificateUtils.extractRSAPublicKey(cert));
                tlsContext.setServerRSAPrivateKey(tlsContext.getConfig().getDefaultServerRSAPrivateKey());
                tlsContext.setServerRsaModulus(CertificateUtils.extractRSAModulus(cert));
            }
        } else {
            LOGGER.warn("Could not adjust Certificate publicKey");
        }
    } catch (IOException E) {
        throw new AdjustmentException("Could not adjust PublicKey Information from Certificate", E);
    }
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:29,代码来源:CertificateHandler.java


示例9: parseCertificate

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
private Certificate parseCertificate(int lengthBytes, byte[] bytesToParse) {
    try {
        ByteArrayInputStream stream = new ByteArrayInputStream(ArrayConverter.concatenate(
                ArrayConverter.intToBytes(lengthBytes, HandshakeByteLength.CERTIFICATES_LENGTH), bytesToParse));
        return Certificate.parse(stream);
    } catch (IOException | IllegalArgumentException E) {
        LOGGER.warn("Could not parse Certificate bytes into Certificate object:"
                + ArrayConverter.bytesToHexString(bytesToParse, false));
        LOGGER.debug(E);
        return null;
    }
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:13,代码来源:CertificateHandler.java


示例10: fetchServerCertificate

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static Certificate fetchServerCertificate(Config config) {
    State state = new State(config);
    config.setWorkflowTraceType(WorkflowTraceType.HELLO);
    WorkflowExecutor workflowExecutor = WorkflowExecutorFactory.createWorkflowExecutor(
            WorkflowExecutorType.DEFAULT, state);
    try {
        workflowExecutor.executeWorkflow();
    } catch (WorkflowExecutionException E) {
        LOGGER.warn("Could not fetch ServerCertificate");
        LOGGER.debug(E);
    }
    return state.getTlsContext().getServerCertificate();
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:14,代码来源:CertificateFetcher.java


示例11: parsePublicKey

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
/**
 * Parses the leaf Certificate PublicKey from the CertificateStructure
 *
 * @param cert
 *            The Certificate from which the PublicKey should be extracted
 * @return The parsed PublicKey
 */
public static PublicKey parsePublicKey(Certificate cert) {
    try {
        X509CertificateObject certObj = new X509CertificateObject(cert.getCertificateAt(0));
        return certObj.getPublicKey();
    } catch (CertificateParsingException | IllegalArgumentException | ClassCastException ex) {
        LOGGER.warn("Could not extract public key from Certificate!");
        LOGGER.debug(ex);
        return null;
    }
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:18,代码来源:CertificateUtils.java


示例12: hasDHParameters

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static boolean hasDHParameters(Certificate cert) {
    if (cert.isEmpty()) {
        return false;
    }
    SubjectPublicKeyInfo keyInfo = cert.getCertificateAt(0).getSubjectPublicKeyInfo();
    return keyInfo.getAlgorithm().getAlgorithm().equals(X9ObjectIdentifiers.dhpublicnumber);
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:8,代码来源:CertificateUtils.java


示例13: hasECParameters

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static boolean hasECParameters(Certificate cert) {
    if (cert.isEmpty()) {
        return false;
    }
    SubjectPublicKeyInfo keyInfo = cert.getCertificateAt(0).getSubjectPublicKeyInfo();
    return keyInfo.getAlgorithm().getAlgorithm().equals(X9ObjectIdentifiers.id_ecPublicKey);
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:8,代码来源:CertificateUtils.java


示例14: hasRSAParameters

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static boolean hasRSAParameters(Certificate cert) {
    if (cert.isEmpty()) {
        return false;
    }
    PublicKey key = parsePublicKey(cert);
    return key != null && key instanceof RSAPublicKey;
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:8,代码来源:CertificateUtils.java


示例15: extractDHPublicKeyParameters

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static DHPublicKeyParameters extractDHPublicKeyParameters(Certificate cert) throws IOException {
    if (hasDHParameters(cert)) {
        SubjectPublicKeyInfo keyInfo = cert.getCertificateAt(0).getSubjectPublicKeyInfo();
        return (DHPublicKeyParameters) PublicKeyFactory.createKey(keyInfo);
    } else {
        throw new IOException();
    }
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:9,代码来源:CertificateUtils.java


示例16: extractECPublicKeyParameters

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static ECPublicKeyParameters extractECPublicKeyParameters(Certificate cert) throws IOException {
    if (hasECParameters(cert)) {
        SubjectPublicKeyInfo keyInfo = cert.getCertificateAt(0).getSubjectPublicKeyInfo();
        return (ECPublicKeyParameters) PublicKeyFactory.createKey(keyInfo);
    } else {
        throw new IOException();
    }
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:9,代码来源:CertificateUtils.java


示例17: extractRSAModulus

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static BigInteger extractRSAModulus(Certificate cert) throws IOException {
    if (hasRSAParameters(cert)) {
        RSAPublicKey rsaPubKey = (RSAPublicKey) parsePublicKey(cert);
        return rsaPubKey.getModulus();
    } else {
        throw new IOException();
    }
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:9,代码来源:CertificateUtils.java


示例18: extractRSAPublicKey

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static BigInteger extractRSAPublicKey(Certificate cert) throws IOException {
    if (hasRSAParameters(cert)) {
        RSAPublicKey rsaPubKey = (RSAPublicKey) parsePublicKey(cert);
        return rsaPubKey.getPublicExponent();
    } else {
        throw new IOException();
    }
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:9,代码来源:CertificateUtils.java


示例19: getTestCertificate

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static Certificate getTestCertificate() {
    try {
        ByteArrayInputStream bin = new ByteArrayInputStream(cert1);
        ASN1InputStream ain = new ASN1InputStream(bin);
        Certificate obj = Certificate.parse(ain);
        return obj;
    } catch (IOException ex) {
        ex.printStackTrace();
    }
    return null;
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:12,代码来源:TestCertificates.java


示例20: keyPairFromStore

import org.bouncycastle.crypto.tls.Certificate; //导入依赖的package包/类
public static KeyPair keyPairFromStore(KeyStore keyStore, String keyAlias, String keyPass)
        throws KeyStoreException, NoSuchAlgorithmException, UnrecoverableKeyException {
    PrivateKey privKey = (PrivateKey) keyStore.getKey(keyAlias, keyPass.toCharArray());
    java.security.cert.Certificate cert = keyStore.getCertificate(keyAlias);
    PublicKey pubKey = cert.getPublicKey();
    return new KeyPair(pubKey, privKey);
}
 
开发者ID:RUB-NDS,项目名称:TLS-Attacker,代码行数:8,代码来源:TestCertificates.java



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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java TablePermission类代码示例发布时间:2022-05-23
下一篇:
Java IndonesianStemFilter类代码示例发布时间:2022-05-23
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap