• Software caused connection abort: recv failed 错误介绍


    解决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

  • 相关阅读:
    司法相关学习网站视频资料
    小型网站如何防范DDoS攻击
    教你9招 破解多种系统登陆密码方法 (1)
    加快Win7整体运行速度的12个小技巧
    手机指令大全,需要可以看看
    Java、fileless恶意软件威胁桌面安全
    浅谈Android手机木马手工查杀
    Win7路由器设置过程
    如何加强移动应用开发安全?
    FTP常用故障代码注解
  • 原文地址:https://www.cnblogs.com/langtianya/p/4284209.html
Copyright © 2020-2023  润新知