我已经通过Java套接字手动开发了一个soap连接(这是一个非常简单的soap请求,Axis给出了很多构建问题)。
为了实现这一点,我基本上复制了我从Soap UI中获取的HTTP头,并编写了以下内容:
String hostname = "aaaaa";
int port = 11111;
InetAddress addr = InetAddress.getByName(hostname);
Socket sock = new Socket(addr, port);
sock.setSoTimeout(100000);
BufferedWriter wr = new BufferedWriter(new OutputStreamWriter(sock.getOutputStream(),"UTF-8"));
wr.write("POST " + "http://aaaa:11111/servicePath" + " HTTP/1.1\r\n");
wr.write("Host: aaaaa:11111\r\n");
wr.write("Accept-Encoding: gzip,deflate\r\n");
wr.write("Content-Length: " + soapXml.length() + "\r\n");
wr.write("Content-Type: text/xml; charset=\"UTF-8\"\r\n");
//wr.write("Connection: Keep-Alive\r\n");
wr.write("SOAPAction: \"/someSoapAction\"\r\n");
wr.write("User-Agent: Apache-HttpClient/4.1.1 (java 1.5)\r\n");
wr.write("\r\n");
wr.write(soapXml);
wr.flush();
请求成功,这意味着我从服务中获得了我期望的响应。 例如,当我手写“soapXml”一些无效参数时,我得到一个500错误回复XML解释问题,如果我正确设置一切我得到一个200 OK与标题后面的xml正文。
问题是在200OK的情况下,套接字在读取HTTP正文之前会挂起60秒。
它基本上读取完整的标题,然后等待60秒,然后(我认为一些协议超时)最终读取xml正文。
以下是我阅读回复的代码:
String line;
BufferedReader rd = new BufferedReader(new java.io.InputStreamReader(sock.getInputStream(),"UTF-8"));
while ((line = rd.readLine()) != null) {
i++;
LOG.debug("cycle: "+i+" -------- "+line);
//after printing the header, it hangs 60 seconds before printing the follwing XML
if ((line.length() >0) && (line.charAt(0) == '<'))
{
responseXML = line;
}
}
以下是200 OK标题示例:
HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Content-Type: text/xml;charset=utf-8
Content-Length: 1052
Date: Sun, 13 Jan 2013 08:33:45 GMT -- hanging 60 seconds here
-- blank line
<?xml version="1.0" encoding="UTF-8"?>................</SOAP-ENV:Envelope>
有人遇到过这种情况吗?请注意,这显然不是服务器问题,因为使用soap UI会立即提供答案。
谢谢
答案 0 :(得分:0)
服务器保持连接打开以保持HTTP保持活动状态,显然是60秒超时。要么更改为HTTP 1.0,要么记下返回的Content-length标头,并停止读取那么多字节。
答案 1 :(得分:0)
服务器环境变化(提供了新机器)解决了这个问题。
现在200OK的响应时间也低于1秒。
不幸的是,我没有关于环境技术堆栈的任何细节。无论如何,谢谢你的帮助。