【问题标题】:java.net.SocketException: Unexpected end of file from serverjava.net.SocketException:来自服务器的文件意外结束
【发布时间】:2011-06-04 08:51:58
【问题描述】:

我正在使用一个 servlet,它将字符串参数传递给另一个远程系统中的另一个 Servlet,以从该远程 servlet 获取 xml 响应。

当我尝试从本地 PC 连接到该远程 Servlet 时,这工作正常。

但是当我从另一台服务器执行相同操作时,我收到了错误 java.net.SocketException: Unexpected end of file from server

错误:

2011-06-04 11:27:24,305 INFO  [STDOUT] strURL in Inventry --> http://1**.1**.**.27:7777/GatewayServlet
/Status?Str=Inventory&PARTNUM=200A104%27%2C%27200A112%27%2C%27200A114%27%2C%27200A113%27%2C%27200A117%27%2C%27200A120%27%2C%27240A503%27%2C%27200A132%27%2C%27200A128%27%2C%27200A124
2011-06-04 11:28:06,243 ERROR [STDERR] java.net.SocketException: Unexpected end of file from server
2011-06-04 11:28:06,243 ERROR [STDERR]  at sun.net.www.http.HttpClient.parseHTTPHeader(Unknown Source)
2011-06-04 11:28:06,243 ERROR [STDERR]  at sun.net.www.http.HttpClient.parseHTTP(Unknown Source)
2011-06-04 11:28:06,243 ERROR [STDERR]  at sun.net.www.http.HttpClient.parseHTTPHeader(Unknown Source)
2011-06-04 11:28:06,243 ERROR [STDERR]  at sun.net.www.http.HttpClient.parseHTTP(Unknown Source)
2011-06-04 11:28:06,243 ERROR [STDERR]  at sun.net.www.protocol.http.HttpURLConnection.getInputStream(Unknown Source)
2011-06-04 11:28:06,243 ERROR [STDERR]  at com.cim.web.servlet.DBGatewayServiceServlet.processRequest(DBGatewayServiceServlet.java:52)
2011-06-04 11:28:06,243 ERROR [STDERR]  at com.cim.web.servlet.DBGatewayServiceServlet.doGet(DBGatewayServiceServlet.java:113)
2011-06-04 11:28:06,243 ERROR [STDERR]  at javax.servlet.http.HttpServlet.service(HttpServlet.java:690)
2011-06-04 11:28:06,243 ERROR [STDERR]  at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
2    011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:179)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:84)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:157)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:262)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
2011-06-04 11:28:06,243 ERROR [STDERR]  at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:446)
2011-06-04 11:28:06,243 ERROR [STDERR]  at java.lang.Thread.run(Unknown Source)

My Servlet(客户端)中的代码:

if(queryString.equals("Inventory")) {

   String partNum = (String)session.getAttribute("PARTNUM");
   String locId = (String)session.getAttribute("locids");

   strURL = strURL+"/InventoryStatus?queryStr=Inventory&PARTNUM="+partNum;

   URLConnection dbGatewayURL = new URL(strURL).openConnection();

   BufferedReader in = new BufferedReader(new InputStreamReader(dbGatewayURL.getInputStream()));//--This is line 52 Mentioned in Error above

   StringBuffer responseData = new StringBuffer();
   String line="";

   while((line = in.readLine()) != null) {
      responseData.append(line);
   }

   String result =responseData.toString();
   request.setAttribute("inventryStock",result);

   RequestDispatcher rd=request.getRequestDispatcher ("inventryStatus.jsp?resp=Yes");
   rd.forward(request, response);  
}

【问题讨论】:

    标签: java servlets io


    【解决方案1】:

    尝试从您的服务器远程登录到远程 servlet,并查看它是否按预期连接。如果不是,那就是连接问题。

    如果是,请尝试使用 TCP 监视器查看从您的服务器到具有 servlet 的远程服务器的 HTTP 流量。 http://ws.apache.org/commons/tcpmon/

    【讨论】:

      【解决方案2】:

      尝试在之后立即等待() URLConnection dbGatewayURL = new URL(strURL).openConnection();

      程序可能在能够建立连接之前移到下一行

      【讨论】:

      • 运气不好..进行了以下更改并得到了另一个例外:
      【解决方案3】:

      代码没有问题,但问题是远程服务器没有监听来自我的服务器的连接,因此我尝试了相同的代码,但这次在另一台远程服务器上运行良好......!有谁知道原因…………?

      【讨论】:

      • 谢谢,需要将我的服务器添加到受信任的主机。虽然它是针对基于 SOAP 的调用,但由于我的服务器不在受信任的主机中,我得到了类似的跟踪
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-12-11
      • 1970-01-01
      相关资源
      最近更新 更多