选择奋斗,选择挑战

发布新日志

  • java.io.IOException: Stream closed

    2012-07-31 17:00:48

    java.io.IOException: Stream closed

    严重: Servlet.service() for servlet jsp threw exception。出现此错误一般都是在jsp中使用了输出流,没有妥善处理好的原因。
    原因:
    在tomcat中jsp编译成servlet之后在函数_jspService(HttpServletRequest request, HttpServletResponse response)的最后
    有一段这样的代码
    finally {
    if (_jspxFactory != null) _jspxFactory.releasePageContext(_jspx_page_context);
    }
    这里是在释放在jsp中使用的对象,会调用response.getWriter(),因为这个方法是和
    response.getOutputStream()相冲突的!所以会出现以上这个异常。

    解决的办法
    在使用完输出流以后调用以下两行代码即可:
    out.clear();
    out = pageContext.pushBody();

    java.io.IOException: Stream closed出现这个异常的原因:举个例子

    BufferedReader Input1 = new BufferedReader(new InputStreamReader(System.in));
    BufferedReader Input2 = new BufferedReader(new InputStreamReader(System.in));

    这两句话中的Input1和Input2都是由System.in封装而来。这是设计模式中的装饰模式的应用,顾名思义,装饰模式就是对最原始的东西进行装饰,只改变了外表,但实质并没有改变。System.in就是最原始的东西,Input1和Input2只是他被装饰后的外表,所以程序中的Input1和Input2的实质上都是System.in。调用Input1.close(),会自动调用Input1的实质System.in.close(),所以对于Input2来说他的实质System.in已经关闭掉,所以多个线程索引同一个input  stream,当某一个thread在执行完之后,把这个inputstream关闭了;而此时正在从这个input  stream流中读取信息的线程就会抛出  java.io.IOException:  Stream  closed  异常。

    终于找到这个异常的根源所在,原来是两个页面同时调用一个jsp,这个jsp中的内建对象
    out在执行out.close()时发生的异常,也就是当某一个thread(对应一个jsp)在执行完之
    后,把这个stream关闭了;而此时正在从这个stream中读取信息的另一个jsp就会抛出  java.io.IOException:  Stream  closed  异常。 

Open Toolbar