数据库用的是SQL SERVER2005,   数据库中存的是图片和MP3的二进制对象,直接看代码吧
batchFrame.setImage(rs.getBinaryStream("MF_IMAGE"));
batchFrame.setAudio(rs.getBinaryStream("MF_AUDIO"));
try {
System.out.println("[image available] : " + batchFrame.getImage().available());
System.out.println("[audio available] : " + batchFrame.getAudio().available());
} catch (IOException e) {
e.printStackTrace();
}
异常

java.io.IOException: 该流已关闭。
at com.microsoft.sqlserver.jdbc.BaseInputStream.checkClosed(SimpleInputStream.java:93)
at com.microsoft.sqlserver.jdbc.SimpleInputStream.available(SimpleInputStream.java:225)
at com.glenet.mms.dao.MMSDao.getBatchFrames(MMSDao.java:159)
at com.glenet.mms.dao.MMSDao.getBatch(MMSDao.java:116)
at com.glenet.mms.dao.MMSDao.getMMS(MMSDao.java:65)
at com.glenet.mms.job.MMSJob.run(MMSJob.java:21)
at java.lang.Thread.run(Thread.java:619)

解决方案 »

  1.   

    严重: 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已经关闭掉,所以...