[急]java.net.SocketException: Connection reset by peer: socket write error

joejoe1991 2008-12-10 03:59:02
要从一个被屏蔽的网站上下载一些东西,于是写了一个Servlet,将它传到了一台境外的服务器上.
让这台服务器去下载指定的资源,然后再回传给我.相当于一个代理吧.

public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String url = request.getParameter("url"); //得到要下载的资源的URL.

if (!StringUtils.isNullOrEmpty(url)) {
System.out.println(url);
URL u = new URL(url);
URLConnection conn = u.openConnection();

try { ///把响应头设置成一样的.
for (Map.Entry<String, List<String>> m : conn.getHeaderFields()
.entrySet()) {
if (m != null && m.getKey() != null && m.getValue() != null
&& m.getValue().size() > 0) {
response.setHeader(m.getKey(), m.getValue().get(0));
}
}
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
CommonLog.log.warn(e);
}

InputStream in = conn.getInputStream(); //从 connection得到inputstream
OutputStream out = response.getOutputStream(); //得到向客户端的输出流
try {
IOUtils
.write(conn.getInputStream(), response
.getOutputStream()); //写数据.
} catch (Exception e) {
e.printStackTrace();
// TODO: handle exception
CommonLog.log.warn(e);
if (in != null) {
in.close();
}
if (out != null) {
out.close();
}
}
}
}


IOUtils.write()代码如下:

	/**
* 从input里面读取数据然后写入output,读完后自动关闭流。
* @param input inputStream
* @param output outputStream
* */
public static void write(InputStream input, OutputStream output)
throws IOException {
write(input,output,true);
}

/**
* 自动从inputstream里面读数据,然后写到outputstream里面去。
* @param input inputstream
* @param output outputstream
* @param close 读完后是否自动关闭流。
* */
public static void write(InputStream input, OutputStream output,boolean close)
throws IOException {
byte[] b = new byte[1024];
int len = input.read(b);
while (len != -1) {
output.write(b, 0, len);
len = input.read(b);
}

output.flush();
if (close) {
input.close();
output.close();
}
}


将程序传到服务器上以后,在服务器上访问
http://localhost:8080/test/down?url=http://www.xxx.com/z.zip
可以下载成功.

但是当远程访问的时候,就会出现
java.net.SocketException: Connection reset by peer: socket write error

假设服务器IP是2.2.2.2吧.

访问
http://2.2.2.2:8080/test/down?url=http://www.xxx.com/z.zip
就会出现上面的那个错误.
注意,我并没有关闭浏览器或者按停止按钮.只要一打上那个地址就会出错.


错误发生在:

output.write(b, 0, len);//执行这行代码的时候.


具体的错误信息如下:


ClientAbortException:  java.net.SocketException: Connection reset by peer: socket write error
at org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:366)
at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:432)
at org.apache.tomcat.util.buf.ByteChunk.append(ByteChunk.java:347)
at org.apache.catalina.connector.OutputBuffer.writeBytes(OutputBuffer.java:392)
at org.apache.catalina.connector.OutputBuffer.write(OutputBuffer.java:381)
at org.apache.catalina.connector.CoyoteOutputStream.write(CoyoteOutputStream.java:89)
at com.joejoe.utils.IOUtils.write(IOUtils.java:62)
at com.joejoe.utils.IOUtils.write(IOUtils.java:48)
at com.tqsoft.wdys.other.getMegavideo.doGet(getMegavideo.java:79)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:627)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:269)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188)
at com.joejoe.utils.web.CharSetFilter.doFilter(CharSetFilter.java:39)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:215)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:172)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:174)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:875)
at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:665)
at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528)
at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:689)
at java.lang.Thread.run(Unknown Source)
Caused by: java.net.SocketException: Connection reset by peer: socket write error
at java.net.SocketOutputStream.socketWrite0(Native Method)
at java.net.SocketOutputStream.socketWrite(Unknown Source)
at java.net.SocketOutputStream.write(Unknown Source)
at org.apache.coyote.http11.InternalOutputBuffer.realWriteBytes(InternalOutputBuffer.java:750)
at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:432)
at org.apache.tomcat.util.buf.ByteChunk.append(ByteChunk.java:347)
at org.apache.coyote.http11.InternalOutputBuffer$OutputStreamOutputBuffer.doWrite(InternalOutputBuffer.java:773)
at org.apache.coyote.http11.filters.IdentityOutputFilter.doWrite(IdentityOutputFilter.java:118)
at org.apache.coyote.http11.InternalOutputBuffer.doWrite(InternalOutputBuffer.java:583)
at org.apache.coyote.Response.doWrite(Response.java:560)
at org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:361)
... 27 more


请问如何解决.谢谢.
...全文
35747 70 打赏 收藏 转发到动态 举报
写回复
用AI写文章
70 条回复
切换为时间正序
请发表友善的回复…
发表回复
逆风的菜鸟 2012-10-26
  • 打赏
  • 举报
回复
求关注,求大侠解决,拯救。
武汉小朱 2012-08-31
  • 打赏
  • 举报
回复
此贴发表于2008年12月,如今2012-8月,何未结贴。。。。

继续关注中。。。。。。。。。。。。
huqingfu 2012-08-28
  • 打赏
  • 举报
回复
我也遇到同样的问题,我的是在IE6上下载异常,IE6以上、firefox、chrome都能够正常下载。后来发现了解决方法,将链接的下载转换成按钮的下载,IE6上解决。具体的原因还不清楚,希望还遇到这个问题的朋友们有帮助。
ausky 2012-07-27
  • 打赏
  • 举报
回复
关注中!!学习
xiaolei1221 2012-05-21
  • 打赏
  • 举报
回复
去掉<a></a>这个链接还怎么用啊?
liuqiboluoxuejuan 2011-11-27
  • 打赏
  • 举报
回复
30\31楼太感谢了。我在ajax 提交到spring mvc也遇到这个问题。在图片有了onclick事件时加了<a>,困扰了两天。谢谢。
Kevin-K先森 2011-10-29
  • 打赏
  • 举报
回复
[Quote=引用 60 楼 missprogram 的回复:]

关掉防火墙就ok了
[/Quote]


我的防火墙 一直是关的呀···
还是出现那个问题···
liufangdan2008 2011-09-07
  • 打赏
  • 举报
回复
小弟近期在写jsp页面的数据导出到excel的时候,也出现上述问题,经分析是jsp页面有2个action调用导致,删除一个后,问题不在出现。
sqcjy111 2011-06-09
  • 打赏
  • 举报
回复
以上很多方法都试过了,还是不行,有哪位大虾解决了吗,给个方案
peanut_love 2011-06-09
  • 打赏
  • 举报
回复
31楼正解
missprogram 2011-05-20
  • 打赏
  • 举报
回复
关掉防火墙就ok了
仙茅 2011-05-17
  • 打赏
  • 举报
回复
怎么都出现这个异常了...求答案!
云淡风轻的猪 2011-05-17
  • 打赏
  • 举报
回复
mark
love_liyuanyuan 2011-04-25
  • 打赏
  • 举报
回复
唉,真烦躁,今天我也遇到同样的问题了,希望有高手解决啊,越简单越好啊
kaka200877 2011-04-19
  • 打赏
  • 举报
回复
30,31楼 正解,我试了将<a></a>标签去掉就OK了
博海喻强龙 2011-04-19
  • 打赏
  • 举报
回复
怎么没一个答案是我想要的啊
qingfengyueshen 2011-03-16
  • 打赏
  • 举报
回复
坐等高手解决
yuanfang10hao 2011-03-16
  • 打赏
  • 举报
回复
只看到不会的到那里GGYY,没看到会的说话。。悲剧啊。我的也是碰到这个问题,烦死了都!
aiyingya 2011-03-13
  • 打赏
  • 举报
回复
[Quote=引用 33 楼 kaiweidawang 的回复:]
我用的SSH,也出现这个问题:
严重: Servlet.service() for servlet jsp threw exception
java.net.SocketException: Connection reset by peer: socket write error

但是该SocketException不会影响程序正常运行!什么原因俺也不明白。。
[/Quote]

我的就是这个样子,运行正常的
txltxl 2011-02-25
  • 打赏
  • 举报
回复
我是这样解决的:
分步完成下载:1.先创建好要下载的文件。2.设置一点点时间延迟。3.开始下载文件。
不知道对你有没有帮助。
加载更多回复(49)

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧