解决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 错误介绍的更多相关文章

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

    最近做java swing程序在模拟httprequest请求的时候出现了这个错误 java.net.SocketException: Software caused connection abort ...

  2. FTP上传文件,报错java.net.SocketException: Software caused connection abort: recv failed

    FTP上传功能,使用之前写的代码,一直上传都没有问题,今天突然报这个错误: java.net.SocketException: Software caused connection abort: re ...

  3. java.net.SocketException:Software caused connection abort: recv failed 异常分析 +socket客户端&服务端代码

    java.net.SocketException:Software caused connection abort: recv failed 异常分析 分类: 很多的技术 2012-01-04 12: ...

  4. 报错java.net.SocketException: Software caused connection abort: recv failed 怎么办

    产生这个异常的原因有多种方面,单就如 Software caused 所示, 是由于程序编写的问题,而不是网络的问题引起的. 已知会导致这种异常的一个场景如下: 客户端和服务端建立tcp的短连接,每次 ...

  5. ActiveMQ——activemq的报错见解javax.jms.JMSException: Software caused connection abort: recv failed

    activeMQ出现javax.jms.JMSException: Software caused connection abort: recv failed的问题解决 一直找不到原因,原来是在本地的 ...

  6. AndroidStudio报错Software caused connection abort: recv failed

    Software caused connection abort: recv failed 这个问题网上有一种说法 已知会导致这种异常的一个场景如下: 客户端和服务端建立tcp的短连接,每次客户端发送 ...

  7. 关于javaSocket中 Software caused connection abort: recv failed问题

    在学习Socket中今天突然遇到了以下这种问题 原来是网路连接出了问题,由于我測试的是远程连接所以是在学校的局域网下,结果非常不稳定,開始还以为怎么了一会连上了一会又出现故障然后把IP地址改为本机的1 ...

  8. ClientAbortException: java.net.SocketException: Software caused connection abort: socket write erro

    1.错误描述 ClientAbortException: java.net.SocketException: Software caused connection abort: socket writ ...

  9. LoadRunner Error code 10053,Software caused connection abort

    发现问题的应用场景  C/S结构程序,请求响应采用异步机制.即客户端发送一个请求后不是一直等待这个结果,客户端将请求存放在请求队列并获得一个JOBID,服务器运行后将运行结果存放在响应队列,客户端定时 ...

随机推荐

  1. 中科院Oracle 10G 数据库系统培训视频教程(828MB )

    中科院Oracle 10G 数据库系统培训视频教程(828MB  )第一章.安装及体系结构概述 Oracle数据库基础知识第二章.SQL*PLUS 基础.实例的创建启动与关闭第三章.SQL语言基础第四 ...

  2. Linux第二次学习笔记

    #Linux第二次实验(第三周) 学习目标 熟悉Linux系统下的开发环境 熟悉vi的基本操作 熟悉gcc编译器的基本原理 熟练使用gcc编译器的常用选项 熟练使用gdb调试技术 熟悉makefile ...

  3. 信息安全系统设计基础exp_5

    北京电子科技学院(BESTI) 实     验    报     告 课程:信息安全系统设计基础 班级:1353 姓名:郑伟.吴子怡 学号:20135322.20135313 指导教师: 娄嘉鹏 实验 ...

  4. 使用logstash+elasticsearch+kibana快速搭建日志平台

    日志的分析和监控在系统开发中占非常重要的地位,系统越复杂,日志的分析和监控就越重要,常见的需求有: * 根据关键字查询日志详情 * 监控系统的运行状况 * 统计分析,比如接口的调用次数.执行时间.成功 ...

  5. .NET MVC控制器向视图传递数据的四种方式

    .NET MVC控制器向视图传递数据的四种方式: 1.ViewBag  ViewBag.Mvc="mvc"; 2.ViewData ViewBag["Mvc"] ...

  6. Android WebView使用深入浅出

    目前很多android app都内置了可以显示web页面的界面,会发现这个界面一般都是由一个叫做WebView的组件渲染出来的,学习该组件可以为你的app开发提升扩展性. 先说下WebView的一些优 ...

  7. 在 Area 中使用RouteAttribute 定义路由, 并支持多语言

    业务上的一个需求, 同一页面, 两种不同的使用方法, 为了区分这两种需求, 需要加一个参数到 URL 中,不改路由的话, 是这样: http://localhost:16269/en-US/Forwa ...

  8. 第四章 Js的面向对象的初窥视(天生的哈希表)

    对象就有键值对 var speaker = { text: "Hello World", say: function(){ console.log("Hello Worl ...

  9. 云计算之路-阿里云上:2014年6月12日14:40出现CPU 100%

    这是今天遇到的第2次故障,主站1台云服务器在14:40:33-14:41:09期间出现CPU突然跑满的状况,而CPU跑满之前,请求量并没有明显增长. 向阿里云提交之后,说晚上会对这台云服务器的虚拟机进 ...

  10. 开源分布式计算引擎 & 开源搜索引擎 Iveely 0.5.0 为大数据而生

    Iveely Computing 产生背景 08年的时候,我开始接触搜索引擎,当时遇到的第一个难题就是大数据实时并发处理,当时实验室的机器我们可以随便用,至少二三十台机器,可以,却没有程序可以将这些机 ...