gpt4 book ai didi

java - 如何在 Java Sun HttpsServer 中使用 LetsEncrypt 证书?

转载 作者:太空宇宙 更新时间:2023-11-03 14:44:08 25 4
gpt4 key购买 nike

使用大量谷歌搜索的各种结果,我设法制作了一个 Java 类来处理从 LetsEncrypt 下载证书,非常简洁。 (可用 here 如果有人感兴趣)

有了它,我在一个文件夹中得到了这个内容作为输出:

chain.crt
domain.crt
domain.csr
domain.key
user.key

我一直在使用带有自签名证书的 com.sun.net.httpserver.HttpsServer,我按照一些指南生成它给了我一个 .jks 文件,直到现在使用测试客户端一直运行良好.但是现在我需要浏览器接受证书而不给出验证错误,所以我想在此 HttpsServer 中使用从 LetsEncrypt 下载的证书,但我不知道如何去做。我在谷歌上搜索了一下,但我没有找到任何对我有用的东西,尽管我不得不承认我并不真正理解我在这里做的大部分事情,而且我什至不知道哪一个我应该尝试使用上面的 5 个文件。

我当前的代码使用现有生成的 .jks 文件设置我的 HttpsServer:(也可用 here)

  public void initHttpsServer(int port, String certificateFilePath, String sslPassword)
{
try
{
this.server = HttpsServer.create(new InetSocketAddress(port), 0);
SSLContext sslContext = SSLContext.getInstance("TLS");
char[] password = sslPassword.toCharArray();
KeyStore ks = KeyStore.getInstance("JKS");
FileInputStream fis = new FileInputStream(certificateFilePath);
ks.load(fis, password);
KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
kmf.init(ks, password);
TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");
tmf.init(ks);
sslContext.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
this.server.setHttpsConfigurator(new HttpsConfigurator(sslContext)
{
@Override
public void configure(HttpsParameters params)
{
try
{
SSLContext c = SSLContext.getDefault();
SSLEngine engine = c.createSSLEngine();
params.setNeedClientAuth(false);
params.setCipherSuites(engine.getEnabledCipherSuites());
params.setProtocols(engine.getEnabledProtocols());
SSLParameters defaultSSLParameters = c.getDefaultSSLParameters();
params.setSSLParameters(defaultSSLParameters);
}

在寻找解决方案时,我遇到了一些答案,其中包括从 cmd 运行命令以生成不同类型的文件。我需要所有这些在运行时工作,因此首选以编程方式进行的方法。

我还有一个相关的问题,当旧的 LetsEncrypt 证书过期并且我已经下载了新证书时,我是否可以更新正在运行的 HttpsServer 实例以使用新下载的证书,或者我是否必须重新启动服务器?

非常感谢任何帮助弄清楚如何完成这项工作的人。

最佳答案

旁白:将此 JKS 文件称为“certificateFile”具有误导性; JKS(或其他 keystore ,如 PKCS12)通常包含多个证书,但通常还包括私钥,而且关键是私钥。

通常较难的部分是读取 key 文件,并且由于您使用的是 acme4j,它会为您处理。由于缺乏基础设施而未经过测试,但可以执行以下操作:

KeyPair kp = KeyPairUtils.readKeyPair (new FileReader ("domain.key"));
// add error handling and close much like your getOrCreateKeyPair
CertificateFactory cf = CertificateFactory.getInstance ("X.509");
Certificate cert0 = cf.generateCertificate (new FileInputStream ("domain.crt"));
Certificate cert1 = cf.generateCertificate (new FileInputStream ("chain.crt"));
// add similar error handling and close

KeyStore ks = KeyStore.getInstance ("jks"); // type doesn't really matter since it's in memory only
ks.load (null);
ks.setKeyEntry ("anyalias", kp.getPrivate(), password, new Certificate[]{cert0,cert1});

// now create a KMF and KeyManager from this KeyStore,
// optionally a TMF and TrustManager, then SSLContext etc as in your existing code

不知道Sun HttpsServer是否可以在运行时更改KeyManager数据;如果我以后有时间,我会试着看看。但很明显你需要在改变它之前开始它是一个问题:-)

关于java - 如何在 Java Sun HttpsServer 中使用 LetsEncrypt 证书?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40568195/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com