码迷,mamicode.com
首页 > 其他好文 > 详细

Software caused connection abort: recv failed 错误介绍

时间:2015-06-08 13:07:37      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:

解决1:

Software caused connection abort: recv failed
java.net.SocketException: Software caused connection abort: recv failed
at java.net.SocketInputStream.socketRead0(Native Method)
at java.net.SocketInputStream.read(SocketInputStream.java:129) 
产生这个异常的原因有多种方面,单就如 Software caused 所示,
是由于程序编写的问题,而不是网络的问题引起的.
已知会导致这种异常的一个场景如下:

客户端和服务端建立tcp的短连接,每次客户端发送一次请求, 服务端响应后关闭与客户端的连接. 如果客户端在服务端关闭连接后,没有释放连接,继续试图发送请求和接收响应. 这个时候就会出错.
这个时候客户端Socket的getOutputStream返回来的OutPutStream维护 的是本地的连接状态, 无法知道远程的服务端已经关闭了对应的InputStream和socket因此 虽然调用了 out.write(sendbuf, 0, sendbuf.length); 方法,但是实际上服务端并没有接收到客户端的请求信息. 因为没有抛出异常,因此造成了误以为客户端请求发送成功的假象.
接下来调用etInputStream的in.read(header, 0, 14);方法. 因为这次要读取服务端的信息,因此产生了 Software caused connection abort: recv failed的异常
总结产生原因,在服务端/客户端单方面关闭连接的情况下,另一方依然以为 tcp连接仍然建立,试图读取对方的响应数据,导致出现 Software caused connection abort: recv failed的异常.
因此在receive数据之前,要先判断连接状态. 通过inputstream的available()方法来判断,是否有响应结果. 如果available()的返回值为0,说明没有响应数据,可能是对方已经断开连接, 如果available()的返回值大于0,说明有响应数据. 另外值得注意的是available()返回的值是非堵塞的,可以被多个线程访问
在对方释放连接后,也要释放本地的连接.

技术分享
原代码:
            URL localurl = new URL(url) ;
            URLConnection uc = localurl.openConnection() ;
            uc.setRequestProperty("User-Agent","Mozilla/3.5.7 (compatible; MSIE 5.0; Windows NT; DigExt)");
            uc.connect() ;
            InputStream localObject1 = localurl.openStream();
            System.out.println(localObject1.available()) ;
            byte[] localObject2 = new byte[131072];
            StringBuffer localStringBuffer = new StringBuffer() ;
            int j = 0 ;
            while ((j = (localObject1).read(localObject2)) > 0){
                localStringBuffer.append(new String(localObject2, 0, j, encoder));
            }
            localObject1.close() ;
修改后代码:
            URL localurl = new URL(url) ;
            URLConnection uc = localurl.openConnection() ;
            uc.setRequestProperty("User-Agent","Mozilla/3.5.7 (compatible; MSIE 5.0; Windows NT; DigExt)");
            uc.connect() ;
            InputStream localObject1 = localurl.openStream();
            System.out.println(localObject1.available()) ;
            byte[] localObject2 = new byte[131072];
            StringBuffer localStringBuffer = new StringBuffer() ;
            int j = 0 ;
            while(true){
                if(localObject1 .available()>0){
                    if((y=localObject1.read(localObject2))>0){
                        sb.append(new String(localObject2,0,y,encode)) ;
                    } else{
                        break ;
                    }
                }else if(in.available()==0){
                    System.out.println("与服务器的链接已中断") ;
                    break ;
                }
             }
            localObject1.close() ;
技术分享

 

解决2:

当Socket建立连接之后,只要我一读数据,也就是read,catch马上得到一个异常信息

"Software caused connection abort: recv failed"

后面经过论证,原来是我传输的数据和监控中心服务器规定的协议数据不一致,没有登录成功,所以根本接受不了数据

我没有使用NIO包,我现在开始怀疑任何一种java.net.SocketException的这个异常都有可能是协议数据不一致造成的,

如下:四种错误信息

java.net.SocketException:Connection reset by peer: socket write error java.net.SocketException:Connection reset java.net.SocketException:Software caused connection abort :socket write error

java.net.SocketException: Software caused connection abort: recv failed

Software caused connection abort: recv failed 错误介绍

标签:

原文地址:http://www.cnblogs.com/dengjiali2015/p/4560542.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!