我尝试使用 wsdl2java 生成 Java 类。
Wsdl 位于使用 X509 证书保护的远程服务器中,这样,当我尝试在浏览器中访问它而没有信任存储中的证书时,它会返回错误(当然,当我将证书导入到certmgr.msc
, wsdl 显示得很好)。
不幸的是,当我尝试运行 wsdl2java 时,我得到:
> org.apache.cxf.wsdl11.WSDLRuntimeException: Fail to create wsdl definition file:/resources/wsdl/my.xml: WSDLException (at /wsdl:definitions/wsdl:types/xsd:schema): faultCode=PARSER_ERROR: Problem parsing 'https://SERVER_HOST/my?xsd=../xsd/XX.xsd'.: javax.net.ssl.SSLHandshakeException: Received fatal alert: handshake_failure
我在 JKS 商店中导入了我的证书。
我如何建议 wsdl2java 使用来自 JKS 的证书来连接到服务器?
我建议您按以下步骤跳过此问题:
将该 wsdl 手动下载到您的本地计算机。
将在该 wsdl 文件中引用的 xsd 文件手动下载到本地计算机。
修改该 wsdl 以将 xsd 位置更改为您的本地位置。
您现在可以生成 java 代码了。
如果你真的想做。请参考这里:
"%JAVA_HOME%\bin\java" -Djavax.net.ssl.trustStore="{keystorefile}" -Djavax.net.ssl.trustStorePassword="{password}" -Djavax.net.ssl.keyStoreType="jks" -Dorg.jboss.security.ignoreHttpsHost="true" -Xmx128M -Djava.endorsed.dirs="%CXF_HOME%\lib\endorsed" -cp "%CXF_JAR%;%TOOLS_JAR%;%CLASSPATH%" -Djava.util.logging.config.file="%CXF_HOME%\etc\logging.properties" org.apache.cxf.tools.wadlto.WADLToJava %*
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句