1.第一種失敗的情況:
本來使用Spring的上下文容器獲取文件,將證書文件放在resource下,編譯后獲取文件會出現報錯
java.security.spec.InvalidKeySpecException: java.security.InvalidKeyException: IOException : DerInputStream.getLength(): lengthTag=111, too big. at sun.security.rsa.RSAKeyFactory.engineGeneratePrivate(RSAKeyFactory.java:217) at java.security.KeyFactory.generatePrivate(KeyFactory.java:372) at com.msok.signatured.crypto.KryptoUtil.getStoredPrivateKey(KryptoUtil.java:136) at com.msok.signatured.xml.digsig.XmlDigitalSignatureGenerator.generateXMLDigitalSignatureXML(XmlDigitalSignatureGenerator.java:254) at com.msok.signatured.xml.digsig.GetXmlDigtalSign.DigtalSignProcess(GetXmlDigtalSign.java:32) at com.msok.insure.service.impl.PayJLYHServiceImpl.checkFour(PayJLYHServiceImpl.java:104) at com.msok.insure.service.dubbo.PayPlatformFacadeImpl.payPlatForm(PayPlatformFacadeImpl.java:117) at com.alibaba.dubbo.common.bytecode.Wrapper27.invokeMethod(Wrapper27.java) at com.alibaba.dubbo.rpc.proxy.javassist.JavassistProxyFactory$1.doInvoke(JavassistProxyFactory.java:46) at com.alibaba.dubbo.rpc.proxy.AbstractProxyInvoker.invoke(AbstractProxyInvoker.java:72) at com.alibaba.dubbo.rpc.protocol.InvokerWrapper.invoke(InvokerWrapper.java:53) at com.alibaba.dubbo.rpc.filter.ExceptionFilter.invoke(ExceptionFilter.java:64) at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)
這個報錯的原因是因為, maven會替換war中的證書文件替。那證書為什么會被修改呢,是maven-resources-plugin作怪。
詳細資料有博客 https://blog.csdn.net/wolf_love666/article/details/51448596 根據博主的解決方式可以處理該異常
2.第二部失敗的情況
項目打包使用的SpringBoot打包成jar在服務器上部署,發現一直獲取不到證書文件。
獲取證書文件方式是
File pfxfile = SpringContextUtils.getApplicationContext().getResource("classpath:key" + File.separatorChar + xinyanProperties.getPfxName()).getFile();
最后查找相關資料,這種獲取文件的方式不能獲取jar里邊的文件,jar里邊文件只能通過流的方式獲取。
最后使用
InputStream stream = getClass().getClassLoader().getResourceAsStream("key" + File.separatorChar + xinyanProperties.getPfxName());
問題解決