Caused by: java.io.IOException: DerInputStream.getLength(): lengthTag=111, too big.

1. 出错环境描述:

web项目升级 https ,配置证书后启动报错。

2. 出错检测

出错的原因:SSL 证书(keystore)配置不正确。修改路径为server.ssl.key-store=classpath:keystore.p12 正常可用。

2.1 检查SSL证书是否正确

keystore.p12 文件检测命令为:

keytool -list -v -keystore path/to/keystore.p12 -storetype PKCS12 -storepass 123456
  • -list:列出密钥库中的条目。
  • -v:显示详细信息。
  • -storetype :指定密钥库的类型,也就是加密算法类型。
  • -storepass : 指定密钥库的密码。

2.2 检查SSL证书是否有被处理导致文件内容错误

举个例子:
maven 配置了资源文件占位符替换,所以导致二进制文件(.p12)有问题:

<build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <!-- 对资源文件进行占位符替换 -->
                <filtering>true</filtering>
            </resource>
        </resources>
</build>             

解决办法

<resources>
    <resource>
         <directory>src/main/resources</directory>
         <filtering>true</filtering>
         <excludes>
             <exclude>**/*.p12</exclude>
         </excludes>
     </resource>
     <resource>
         <directory>src/main/resources</directory>
         <filtering>false</filtering>
         <includes>
             <include>**/*.p12</include>
         </includes>
     </resource>
 </resources>

2.3 检测项目是否有缓存,可以重新构建项目。

2.4 检查文件路径是否正确

  1. 可以先配置绝对路径去检测是否找到正确的文件并加载

举个例子,我的证书文件在 /resources-env/dev 下,

└── resources
    ├── application.properties
    ├── resources-env
    │   ├── dev
    │   │   ├── application-dev.properties
    │   │   └── keystore.p12
    │   └── prod
    └── static
        └── index.html

maven 配置如下:

 <resources>
            <resource>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
                <excludes>
                    <exclude>**/*.p12</exclude>
                </excludes>
            </resource>
            <resource>
                <directory>src/main/resources</directory>
                <filtering>false</filtering>
                <includes>
                    <include>**/*.p12</include>
                </includes>
            </resource>

            <resource>
                <directory>src/main/resources-env/${env}</directory>
                <filtering>false</filtering>
            </resource>
        </resources>

配置的地址是:server.ssl.key-store=classpath:/resources-env/dev/keystore.p12 ,会抛出另一个异常:

Caused by: java.io.FileNotFoundException: class path resource [/resources-env/dev/keystore.p12] cannot be resolved to URL because it does not exist

正确的配置应该是:server.ssl.key-store=classpath:keystore.p12

注意classpath: 表示从 src/main/resources 开始查找,因此你需要指定完整路径。

Java 中,`Caused by: java.io.IOException` 可能由多种不同的具体异常情况导致,以下是针对不同具体异常信息的解决方法: - **`org.apache.catalina.connector.ClientAbortException: java.io.IOException`**:此异常信息中给出的 “浣犵殑涓绘満涓殑杞欢涓浜嗕竴涓凡寤虹珛鐨勮繛鎺ャ” 疑似表示客户端中断了一个已建立的连接,这种情况可能是客户端主动关闭连接等原因造成。一般需要检查客户端和服务端的网络连接稳定性、客户端程序是否有异常中断的情况。不过引用中未给出明确解决办法。 - **`Caused by: java.io.IOException: Pipe closed`**:解决办法是把 `SftpUtil` 实例化放到循环里面。示例代码如下: ```java for(String string:map.keySet()){ SftpUtil sftp1 = new SftpUtil("xiecheng", "***", "192.168.2.**", 22); InputStream is = new FileInputStream(string); String path1=path+string.split("\\\\")[2]; String name=string.split("\\\\")[3]; sftp1.login(); sftp1.upload(path1,name , is); sftp1.logout(); is.close(); System.out.println(string); } ``` - **`Caused by: java.io.IOException: java.lang.reflect.InvocationTargetException`**:解决方法是在 `pom.xml` 中导入以下依赖: ```xml <dependency> <groupId>org.apache.hadoop</groupId> <artifactId>hadoop-common</artifactId> <version>2.6.0</version> </dependency> ``` - **`java.io.IOException异常:toDerInputStream拒绝标签类型45...`**:解决办法是在尝试生成 P12 密钥时,需要在钥匙串访问中同时选择私钥和证书 [^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值