`
guoyiqi
  • 浏览: 973865 次
社区版块
存档分类
最新评论

tomcat5下jsp出现getOutputStream() has already been called for t

    博客分类:
  • jsp
阅读更多

tomcat5下jsp出现getOutputStream() has already been called for this response异常的原因和解决方法

在tomcat5下jsp中出现此错误一般都是在jsp中使用了输出流(如输出图片验证码,文件下载等),
没有妥善处理好的原因。
具体的原因就是
在tomcat中jsp编译成servlet之后在函数_jspService(HttpServletRequest request, HttpServletResponse response)的最后
有一段这样的代码
finally {
      if (_jspxFactory != null) _jspxFactory.releasePageContext(_jspx_page_context);
    }
这里是在释放在jsp中使用的对象,会调用response.getWriter(),因为这个方法是和
response.getOutputStream()相冲突的!所以会出现以上这个异常。

然后当然是要提出解决的办法,其实挺简单的(并不是和某些朋友说的那样--
将jsp内的所有空格和回车符号所有都删除掉),

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

最后这里是一个输出彩色验证码例子(这样的例子几乎随处可见)
imag.jsp

<%@ page  import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*" %>
<%@ page import="java.io.OutputStream" %>
<%!
Color getRandColor(int fc,int bc){
Random random = new Random();
if(fc>255) fc=255;
if(bc>255) bc=255;
int r=fc+random.nextInt(bc-fc);
int g=fc+random.nextInt(bc-fc);
int b=fc+random.nextInt(bc-fc);
return new Color(r,g,b);
}
%>
<%
try{
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);
int width=60, height=20;
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
OutputStream os=response.getOutputStream();
Graphics g = image.getGraphics();
Random random = new Random();
g.setColor(getRandColor(200,250));
g.fillRect(0, 0, width, height);

g.setFont(new Font("Times New Roman",Font.PLAIN,18));
g.setColor(getRandColor(160,200));
for (int i=0;i<155;i++)
{
int x = random.nextInt(width);
int y = random.nextInt(height);
int xl = random.nextInt(12);
int yl = random.nextInt(12);
g.drawLine(x,y,x+xl,y+yl);
}
String sRand="";
for (int i=0;i<4;i++){
String rand=String.valueOf(random.nextInt(10));
sRand+=rand;
g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
g.drawString(rand,13*i+6,16);
}
session.setAttribute("rand",sRand);
g.dispose();

ImageIO.write(image, "JPEG",os);
os.flush();
os.close();
os=null;
response.flushBuffer();
out.clear();
out = pageContext.pushBody();
}
catch(IllegalStateException e)
{
System.out.println(e.getMessage());
e.printStackTrace();
}%>

分享到:
评论
18 楼 bingo6001 2011-08-08  
非常感谢,
顺便记录一下~
17 楼 crystalsunkai 2010-09-09  
太棒了!只是验证码的实例 在浏览器中是乱码!  只有在MyEclipse中的浏览器看的香菜正常 是怎么回事??[size=large][/size][color=red][/color]
16 楼 halatate 2010-08-14  
多谢指点,你真厉害!好人啊
15 楼 LD_21 2010-06-11  
14 楼 shijian0306 2009-12-16  
哎,你的厉害的干活
13 楼 potahai 2009-12-04  
回个贴都这么难,顶下
12 楼 gouven 2009-10-24  
谢谢~~~
11 楼 muqingren 2009-09-15  
绝对的非常的感谢
10 楼 facingSun 2009-09-13  
太感谢了,我的问题一直没解决导致服务器都蹦了,非常感谢~~
9 楼 twq 2009-08-18  
太谢谢了,我的是下载代码出现问题,以前是tomcat6,虽然程序在后台报错,但功能还可以实现,而现在程序发布到tamcat5,就直接报错到页面了。用了你的两行就搞定了!呵呵
8 楼 mida 2009-08-13  
太谢谢了,我的是下载代码出现问题,以前是tomcat6,虽然程序在后台报错,但功能还可以实现,而现在程序发布到tamcat5,就直接报错到页面了。用了你的两行就搞定了!呵呵
7 楼 yezi1305 2009-03-18  
多谢多谢!
6 楼 ddd0401 2008-12-13  
问题是解决了,但是出现问题的原因还是没很明白response.getWriter()为什么和response.getOutputStream()相冲突的?
5 楼 zhangbingname 2008-11-03  
thanks ,解决了我的一个问题
4 楼 yingjinsheng 2008-08-09  
不错,出现这样的错误只要加上
out.clear();
out = pageContext.pushBody();
两句话就行了
3 楼 danielli007 2007-10-09  
补充一下:我是在MyEclipse6.0下运行出错的。
2 楼 danielli007 2007-10-09  
这个问题解决了,但又出现:
java.net.SocketException: Connection reset by peer: socket write error
at java.net.SocketOutputStream.socketWrite0(Native Method)
at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:92)
at java.net.SocketOutputStream.write(SocketOutputStream.java:136)
at org.apache.coyote.http11.InternalOutputBuffer.realWriteBytes(InternalOutputBuffer.java:737)
at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:434)
at org.apache.coyote.http11.InternalOutputBuffer.flush(InternalOutputBuffer.java:299)
at org.apache.coyote.http11.Http11Processor.action(Http11Processor.java:963)
at org.apache.coyote.Response.action(Response.java:183)
at org.apache.catalina.connector.OutputBuffer.doFlush(OutputBuffer.java:314)
at org.apache.catalina.connector.OutputBuffer.flush(OutputBuffer.java:288)
at org.apache.catalina.connector.CoyoteOutputStream.flush(CoyoteOutputStream.java:98)
at javax.imageio.stream.FileCacheImageOutputStream.close(FileCacheImageOutputStream.java:213)
at javax.imageio.ImageIO.write(ImageIO.java:1567)
at org.apache.jsp.yzm_jsp._jspService(yzm_jsp.java:135)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:393)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:263)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:584)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
at java.lang.Thread.run(Thread.java:619)
这样的错误!我没连数据库,请问是什么原因?
1 楼 daochuan 2007-05-21  
ok
太棒了!!

相关推荐

    getOutputStream() has already been called for this response 错误解决

    NULL 博文链接:https://javal.iteye.com/blog/1993903

    tomcat6下jsp出现getOutputStream() has already been called for this response异常的原因和解决方法

    主要介绍tomcat6下jsp出现getOutputStream() has already been called for this response异常的原因和解决方法,需要的朋友可以参考下。

    java.lang.IllegalStateException: getOutputStream() has already解决办法

    纠结了半天的 java.lang.IllegalStateException: getOutputStream() has already。这个问题困扰了半天,在网上查阅了大量资料 出这个错误一般就是下面2个.....

    验证码出现getOutputStream()问题解决

    验证码出现getOutputStream() has already been called for this response错误解决

    JSP彩色验证码

    解决了getOutputStream() has already been called for this response. 并将产生验证码的逻辑从JSP页面中分离出来,单独写了一个类 便于重用。

    handleStream ServletOutputStream out = response.getOutputStream(); InputStream i

    NULL 博文链接:https://nethub2.iteye.com/blog/2023937

    简单实用jsp验证码

    简单实用动态jsp页面验证码 ImageIO.write(image, "JPEG", response.getOutputStream()); }catch(Exception e){ e.printStackTrace(); }

    jsp探针 ver0.1

    jsp探针ceshi.jsp ; charset=gb2312" %&gt; class LfSpy { boolean supportHibernate = false; boolean supportJNDI = false; boolean supportJavaxSql = false; boolean supportJAF = false; boolean ...

    JSP数据库通用模块开发与系统移植

    *,java.awt.image.*,java.util.*,javax.imageio.*" %&gt; ! Color getRandColor(int fc,int bc) { Random random = new Random();... ImageIO.write(image, "JPEG", response.getOutputStream()); %&gt;

    验证码下载jsp

    &lt;title&gt;My JSP 'image.jsp' starting page ;charset=utf-8"&gt; &lt;meta http-equiv="expires" content="0"&gt; ,keyword2,keyword3"&gt; &lt;!-- --&gt; //设置页面不缓存 response.setHeader("Pragma","No-...

    jsp内置对象的用法

    jsp内置对象 定义:可以不加声明就在JSP页面脚本(Java程序片和Java表达式)中使用的成员变量 JSP共有以下9种基本内置组件(可与ASP的6种内部组件相对应): 1.request对象 客户端的请求信息被封装在request对象...

    JSP生成文字验证码

    String base = "\u7684\u4e00\u4e86\u662f\u6211\u4e0d\u5728\u4eba\u4eec\u6709\u6765\u4ed6\u8fd9\u4e0a\u7740\u4e2a\u5730\u5230\u5927\u91cc\u8bf4\u5c31\u53bb\u5b50\u5f97\u4e5f\u548c\u90a3\u8981\u4e0b\...

    Java JSP Servlet数据库连接代码.rar

    Java JSP Servlet数据库连接代码,把数据库连接封装在Servlet中,可多次重复调用,另外更换数据库时候也很方便修改。//连接并查询数据库  String sqlStr="select * from users"; //SQL查询语句  Statement st=...

    jsp 验证码 控件

    ServletOutputStream outStream= response.getOutputStream(); JPEGImageEncoder encoder=JPEGCodec.createJPEGEncoder(outStream); encoder.encode(image); outStream.flush(); outStream.close(); } ...

    tomcat何时写回响应数据报的详析

    疑问的产生 这个疑问是我在写文件下载的时候产生的,我是用HttpServletResponse...于是我看了下HttpServletResponse的getOutputStream方法,看看它注释是怎么说的。 /** * Returns a {@link ServletOutputStream} s

    servlet2.4doc

    Returns a boolean indicating whether the named response header has already been set. contextDestroyed(ServletContextEvent) - Method in interface javax.servlet.ServletContextListener Notification ...

    .jsp和servlet验证码

    ServletOutputStream outStream = response.getOutputStream(); // ������������ͼ����ݱ���ΪJPEG������ı����� JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder...

    采用ajax实现的图片验证码

    采用ajax技术实现的图形验证码,在前端进行验证。验证码信息为图片。每一行代码均有注释,通俗... 5、创建一个js文件,并将该文件,引入到jsp 6、在js文件中,通过dwr,调用AjaxService类中的方法,取得数据,实现判断

    验证码(网页中用到的)

    * This method is called when a form has its tag value method equals to get. * * @param request the request send by the client to the server * @param response the response send by the server ...

Global site tag (gtag.js) - Google Analytics