使用 WSDL2Java 时出现认证错误 class
Certification error when using the WSDL2Java class
我是 Web 服务的新手,在执行以下命令行时出现错误:
java -mx1024m -Djava.ext.dirs=workspace/extdirs/remap:/home/amira/workspace/extdirs/axis2 org.apache.axis2.wsdl.WSDL2Java -o . -p fr.srd.impressions.pologne.XXXX -S . -s -d xmlbeans --noBuildXML -ep org,org.w3,org.xmlsoap -uri schema/XXXXXPackageXmlServices.wsdl -xsdconfig schema/XXXXXPackageXmlServices.xsdconfig
这是我收到的错误消息:
Retrieving document at 'schema/XXXXPackageXmlServices.wsdl'.
Retrieving schema at 'https://XXXXservicesdemo.XXXX.com.pl/XXXXPackageXmlServicesService/XXXXPackageXmlServices?xsd=1', relative to 'file:/home/amira/workspace/srd/impressions/etiquettes/pologne/XXXX/schema/XXXXPackageXmlServices.wsdl'.
Exception in thread "main" org.apache.axis2.wsdl.codegen.CodeGenerationException: Error parsing WSDL
at org.apache.axis2.wsdl.codegen.CodeGenerationEngine.<init>(CodeGenerationEngine.java:178)
at org.apache.axis2.wsdl.WSDL2Code.main(WSDL2Code.java:35)
at org.apache.axis2.wsdl.WSDL2Java.main(WSDL2Java.java:24)
Caused by: javax.wsdl.WSDLException: WSDLException (at /definitions/types/xsd:schema): faultCode=OTHER_ERROR: An error occurred trying to resolve schema referenced at 'https://XXXXservicesdemo.XXXX.com.pl/XXXXPackageXmlServicesService/XXXXPackageXmlServices?xsd=1', relative to 'file:/home/amira/workspace/srd/impressions/etiquettes/pologne/XXXX/schema/XXXXPackageXmlServices.wsdl'.: javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: No name matching dpdservicesdemo.XXXX.com.pl found
at com.ibm.wsdl.xml.WSDLReaderImpl.parseSchema(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.parseSchema(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.parseTypes(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.parseDefinitions(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at org.apache.axis2.wsdl.codegen.CodeGenerationEngine.readInTheWSDLFile(CodeGenerationEngine.java:320)
at org.apache.axis2.wsdl.codegen.CodeGenerationEngine.<init>(CodeGenerationEngine.java:133)
... 2 more
Caused by: javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: No name matching dpdservicesdemo.XXXX.com.pl found
at sun.security.ssl.Alerts.getSSLException(Alerts.java:192)
at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1836)
at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:276)
at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:270)
at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1337)
at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:154)
at sun.security.ssl.Handshaker.processLoop(Handshaker.java:868)
at sun.security.ssl.Handshaker.process_record(Handshaker.java:804)
at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:966)
at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1262)
at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1289)
at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1273)
at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:523)
at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185)
at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1296)
at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:254)
at java.net.URL.openStream(URL.java:1035)
at com.ibm.wsdl.util.StringUtils.getContentAsInputStream(Unknown Source)
... 13 more
Caused by: java.security.cert.CertificateException: No name matching dpdservicesdemo.XXXX.com.pl found
at sun.security.util.HostnameChecker.matchDNS(HostnameChecker.java:208)
at sun.security.util.HostnameChecker.match(HostnameChecker.java:93)
at sun.security.ssl.X509TrustManagerImpl.checkIdentity(X509TrustManagerImpl.java:347)
amira@amira:~/workspace/srd/impressions/etiquettes/pologne/XXXX$ java -mx1024m -Djava.ext.dirs=/home/amira/workspace/extdirs/common:/home/amira/workspace/extdirs/vaadin:/home/amira/workspace/extdirs/remap:/home/amira/workspace/extdirs/axis2 org.apache.axis2.wsdl.WSDL2Java -o . -p fr.srd.impressions.pologne.XXXX -S . -s -d xmlbeans --noBuildXML -ep org,org.w3,org.xmlsoap -uri schema/XXXXXPackageXmlServices.wsdl -xsdconfig schema/XXXXXPackageXmlServices.xsdcon
使用下面的代码绕过证书检查
TrustManager[] trustAllCerts = { new X509TrustManager() {
public X509Certificate[] getAcceptedIssuers() {
return null;
}
public void checkClientTrusted(X509Certificate[] certs, String authType) {
}
public void checkServerTrusted(X509Certificate[] certs, String authType) {
}
} };
SSLContext sc = SSLContext.getInstance("SSL");
HostnameVerifier hv = new HostnameVerifier() {
public boolean verify(String arg0, SSLSession arg1) {
return true;
}
};
sc.init(null, trustAllCerts, new SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
HttpsURLConnection.setDefaultHostnameVerifier(hv);
我是 Web 服务的新手,在执行以下命令行时出现错误:
java -mx1024m -Djava.ext.dirs=workspace/extdirs/remap:/home/amira/workspace/extdirs/axis2 org.apache.axis2.wsdl.WSDL2Java -o . -p fr.srd.impressions.pologne.XXXX -S . -s -d xmlbeans --noBuildXML -ep org,org.w3,org.xmlsoap -uri schema/XXXXXPackageXmlServices.wsdl -xsdconfig schema/XXXXXPackageXmlServices.xsdconfig
这是我收到的错误消息:
Retrieving document at 'schema/XXXXPackageXmlServices.wsdl'.
Retrieving schema at 'https://XXXXservicesdemo.XXXX.com.pl/XXXXPackageXmlServicesService/XXXXPackageXmlServices?xsd=1', relative to 'file:/home/amira/workspace/srd/impressions/etiquettes/pologne/XXXX/schema/XXXXPackageXmlServices.wsdl'.
Exception in thread "main" org.apache.axis2.wsdl.codegen.CodeGenerationException: Error parsing WSDL
at org.apache.axis2.wsdl.codegen.CodeGenerationEngine.<init>(CodeGenerationEngine.java:178)
at org.apache.axis2.wsdl.WSDL2Code.main(WSDL2Code.java:35)
at org.apache.axis2.wsdl.WSDL2Java.main(WSDL2Java.java:24)
Caused by: javax.wsdl.WSDLException: WSDLException (at /definitions/types/xsd:schema): faultCode=OTHER_ERROR: An error occurred trying to resolve schema referenced at 'https://XXXXservicesdemo.XXXX.com.pl/XXXXPackageXmlServicesService/XXXXPackageXmlServices?xsd=1', relative to 'file:/home/amira/workspace/srd/impressions/etiquettes/pologne/XXXX/schema/XXXXPackageXmlServices.wsdl'.: javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: No name matching dpdservicesdemo.XXXX.com.pl found
at com.ibm.wsdl.xml.WSDLReaderImpl.parseSchema(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.parseSchema(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.parseTypes(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.parseDefinitions(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at com.ibm.wsdl.xml.WSDLReaderImpl.readWSDL(Unknown Source)
at org.apache.axis2.wsdl.codegen.CodeGenerationEngine.readInTheWSDLFile(CodeGenerationEngine.java:320)
at org.apache.axis2.wsdl.codegen.CodeGenerationEngine.<init>(CodeGenerationEngine.java:133)
... 2 more
Caused by: javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: No name matching dpdservicesdemo.XXXX.com.pl found
at sun.security.ssl.Alerts.getSSLException(Alerts.java:192)
at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1836)
at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:276)
at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:270)
at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1337)
at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:154)
at sun.security.ssl.Handshaker.processLoop(Handshaker.java:868)
at sun.security.ssl.Handshaker.process_record(Handshaker.java:804)
at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:966)
at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1262)
at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1289)
at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1273)
at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:523)
at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185)
at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1296)
at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:254)
at java.net.URL.openStream(URL.java:1035)
at com.ibm.wsdl.util.StringUtils.getContentAsInputStream(Unknown Source)
... 13 more
Caused by: java.security.cert.CertificateException: No name matching dpdservicesdemo.XXXX.com.pl found
at sun.security.util.HostnameChecker.matchDNS(HostnameChecker.java:208)
at sun.security.util.HostnameChecker.match(HostnameChecker.java:93)
at sun.security.ssl.X509TrustManagerImpl.checkIdentity(X509TrustManagerImpl.java:347)
amira@amira:~/workspace/srd/impressions/etiquettes/pologne/XXXX$ java -mx1024m -Djava.ext.dirs=/home/amira/workspace/extdirs/common:/home/amira/workspace/extdirs/vaadin:/home/amira/workspace/extdirs/remap:/home/amira/workspace/extdirs/axis2 org.apache.axis2.wsdl.WSDL2Java -o . -p fr.srd.impressions.pologne.XXXX -S . -s -d xmlbeans --noBuildXML -ep org,org.w3,org.xmlsoap -uri schema/XXXXXPackageXmlServices.wsdl -xsdconfig schema/XXXXXPackageXmlServices.xsdcon
使用下面的代码绕过证书检查
TrustManager[] trustAllCerts = { new X509TrustManager() {
public X509Certificate[] getAcceptedIssuers() {
return null;
}
public void checkClientTrusted(X509Certificate[] certs, String authType) {
}
public void checkServerTrusted(X509Certificate[] certs, String authType) {
}
} };
SSLContext sc = SSLContext.getInstance("SSL");
HostnameVerifier hv = new HostnameVerifier() {
public boolean verify(String arg0, SSLSession arg1) {
return true;
}
};
sc.init(null, trustAllCerts, new SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
HttpsURLConnection.setDefaultHostnameVerifier(hv);