我使用ksoap库来调用webservice。在某些情况下,服务可以正确运行,但在某些情况下,它会给出未验证的主机名,下面是我调用webservice的代码。
HttpTransportSE httpTransport = new HttpTransportSE(URL, MessageConstant.TIMEOUT_TIME);
httpTransport.debug = true; // this is optional, use it if you don't want to use a packet sniffer to check what the sent message was (httpTransport.requestDump)
httpTransport.call(SOAP_ACTION, envelope); // send request这是我的原木猫
java.io.IOException: Hostname 'XXX.XX.XXX.XXX' was not verified
at libcore.net.http.HttpConnection.verifySecureSocketHostname(HttpConnection.java:223)
at libcore.net.http.HttpsURLConnectionImpl$HttpsEngine.connect(HttpsURLConnectionImpl.java:446)
at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:289)
at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:239)
at libcore.net.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:80)
at libcore.net.http.HttpsURLConnectionImpl.connect(HttpsURLConnectionImpl.java:165)
at org.ksoap2.transport.ServiceConnectionSE.connect(ServiceConnectionSE.java:76)
at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:152)
at org.ksoap2.transport.HttpTransportSE.call(HttpTransportSE.java:95)发布于 2013-10-05 03:27:14
此链接有几个可能的原因;没有一个响应被标记为“已接受”:
你还应该看看这里:
发生这种情况的一个原因是服务器配置错误。服务器配置了一个证书,该证书没有与您尝试访问的服务器匹配的主题或主题备用名称字段。可以将一个证书用于多个不同的服务器。
例如,查看带有openssl s_client -connect google.com:443 | openssl x509 -text的google.com证书,您可以看到一个主题支持*.google.com,但也支持*.youtube.com、*.android.com和其他主题的替代名称。仅当证书未将您要连接的服务器名称列为可接受时,才会出现该错误。
发布于 2016-04-12 15:55:02
验证您的主机为
HttpsURLConnection.setDefaultHostnameVerifier(new HostVerifier());
public class HostVerifier implements HostnameVerifier {
@Override
public boolean verify(String hostname, SSLSession session) {
Log.i(TAG, "HOST NAME " + hostname);
if (hostname.contentEquals("XXX.XX.XXX.XXX")) {
Log.i(TAG, "Approving certificate for host " + hostname);
return true;
}
return false;
}
}https://stackoverflow.com/questions/19157710
复制相似问题