java8生成数字证书

使用java8生成数字证书

import sun.security.x509.*;
import java.io.FileOutputStream;
import java.io.IOException;
import java.math.BigInteger;
import java.security.*;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.util.Date;

public class GenerateDigitalCertificate {
    public static void main(String[] args) throws Exception {
        // 创建KeyPairGenerator对象
        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
        keyPairGenerator.initialize(2048); // 设置密钥长度
        
        // 生成密钥对
        KeyPair keyPair = keyPairGenerator.generateKeyPair();
        
        // 创建X509证书
        X509Certificate cert = createCertificate(keyPair);
        
        // 创建KeyStore对象
        KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
        keyStore.load(null, null);
        
        // 将证书存储到KeyStore中
        keyStore.setKeyEntry("alias", keyPair.getPrivate(), "password".toCharArray(), new X509Certificate[]{cert});
        
        // 保存KeyStore到文件
        keyStore.store(new FileOutputStream("certificate.p12"), "password".toCharArray());
        
        System.out.println("数字证书生成成功!");
    }
    
    private static X509Certificate createCertificate(KeyPair keyPair) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, SignatureException {
        // 创建X509证书生成器
        X509Certificate cert = null;
        try {
            X509CertInfo info = new X509CertInfo();
            Date from = new Date();
            Date to = new Date(from.getTime() + 365 * 24 * 60 * 60 * 1000L);
            CertificateValidity interval = new CertificateValidity(from, to);
            BigInteger sn = new BigInteger(64, new SecureRandom());
            X500Name owner = new X500Name("CN=Test Certificate");
            AlgorithmId algorithm = new AlgorithmId(AlgorithmId.sha256WithRSAEncryption_oid);
            info.set(X509CertInfo.VALIDITY, interval);
            info.set(X509CertInfo.SERIAL_NUMBER, new CertificateSerialNumber(sn));
            info.set(X509CertInfo.SUBJECT, owner);
            info.set(X509CertInfo.ISSUER, owner);
            info.set(X509CertInfo.KEY, new CertificateX509Key(keyPair.getPublic()));
            info.set(X509CertInfo.VERSION, new CertificateVersion(CertificateVersion.V3));
            info.set(X509CertInfo.ALGORITHM_ID, new CertificateAlgorithmId(algorithm));
            cert = new X509CertImpl(info);
            ((X509CertImpl) cert).sign(keyPair.getPrivate(), "SHA256withRSA");
        } catch (Exception e) {
            e.printStackTrace();
        }
        return cert;
    }
}

在Java 8中,我们需要使用X509CertInfoX509CertImplCertificateValidityCertificateSerialNumberX500NameAlgorithmIdCertificateX509KeyCertificateVersionCertificateAlgorithmId等类来生成数字证书。

注意 别名alias和密码password 可以自定义,在后面配置tomcat的时候用的着

tomcat配置证书

步骤:

  1. certificate.p12证书文件复制到Tomcat服务器上的某个目录,例如/path/to/certificate.p12

  2. 打开Tomcat的配置文件server.xml,通常位于<Tomcat安装目录>/conf目录下。

  3. 找到以下配置块:

    <Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"
                maxThreads="150" scheme="https" secure="true"
                clientAuth="false" sslProtocol="TLS" />
    
  4. 在该配置块中添加以下配置项:

    <Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"
                maxThreads="150" scheme="https" secure="true"
                clientAuth="false" sslProtocol="TLS"
                keystoreFile="/path/to/certificate.p12"
                keystoreType="PKCS12"
                keystorePass="password" />
    

    其中,keystoreFile指定证书文件的路径,keystoreType指定证书文件的类型(PKCS12格式),keystorePass指定证书文件的密码。

  5. 保存server.xml文件并重新启动Tomcat。

现在,Tomcat将使用配置的证书来启用HTTPS连接。请确保将keystorePass设置为certificate.p12证书的密码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值