Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/37.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 在spring和nodejs应用程序之间本地创建SSL连接_Java_Node.js_Spring_Spring Boot_Ssl - Fatal编程技术网

Java 在spring和nodejs应用程序之间本地创建SSL连接

Java 在spring和nodejs应用程序之间本地创建SSL连接,java,node.js,spring,spring-boot,ssl,Java,Node.js,Spring,Spring Boot,Ssl,我有两个应用程序,一个是用nodejs(在本例中是简单的模拟服务器)和spring应用程序(核心应用程序)编写的。我想在这两者之间创建一个SSL连接。首先,我生成一对密钥和证书,然后简单地设置一个nodejs来通过SSL工作(我使用了这个示例:)。 我已经检查过,当我在浏览器中写东西时,它给了我一个“安全”的连接(带打开的挂锁——所以没问题) 接下来,我正在使用spring应用程序进行配置。我从上一代步骤中获取了一个证书,并将其设置在keystore的.p12文件中。在spring应用程序中,我

我有两个应用程序,一个是用nodejs(在本例中是简单的模拟服务器)和spring应用程序(核心应用程序)编写的。我想在这两者之间创建一个SSL连接。首先,我生成一对密钥和证书,然后简单地设置一个nodejs来通过SSL工作(我使用了这个示例:)。 我已经检查过,当我在浏览器中写东西时,它给了我一个“安全”的连接(带打开的挂锁——所以没问题)

接下来,我正在使用spring应用程序进行配置。我从上一代步骤中获取了一个证书,并将其设置在keystore的.p12文件中。在spring应用程序中,我将节点应用程序的url更改为https

当我尝试从spring应用程序连接并从节点获取一些模拟数据时,我得到了以下stacktrace:

原因:javax.net.ssl.SSLHandshakeException:PKIX路径生成失败:sun.security.provider.certpath.SunCertPathBuilderException:找不到请求目标的有效证书路径

我在中发现了一些东西,但当我在特定目录中设置此证书,然后重新启动我的应用程序时,结果是一样的


是否有人知道此配置中可能出现的错误以及如何修复的建议

我找到了这个问题的解决办法。我不知道为什么,但当我创建了一个内部带有cert的密钥库,然后在我的spring应用程序中使用它时,它无法在全局范围内找到这个带有cert的密钥库。我正在寻找关于openJDK11的文档(因为我使用了它),并找到一个链接并检查我有openJDK11版本的文件

在我的例子中,
crypto.policy
中的行被注释了,不知道为什么。当我取消注释并设置
unlimited
时,它又给了我一个错误,但随后我找到了另一个解决方案。我发现,我需要将我的签名自证书添加到cacerts文件()。经过这两次手术后,它就成了魅力