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

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

热门标签:南京新思维电话机器人 泰州泰兴400电话 怎么申请 企业怎么在联通申请400电话 好操作的电话机器人厂家 百度地图添加标注图标样式 如何用中国地图标注数字点 南昌市地图标注app 地图标注市场怎么样 聊城智能电销机器人外呼

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

  在tomcat6.0下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;i155;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 j=0;j4;j++){
      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*j+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();
  }
%>

  如有不足之处,欢迎斧正!

2.getOutputStream() has already been called for this response问题的解决

  在jsp向页面输出图片的时候,使用response.getOutputStream()会有这样的提示:java.lang.IllegalStateException:getOutputStream() has already been called for this response,会抛出Exception

  原因一:
  JSP默认的输出流为PrintWriter ,即% %>以外的东西所默认的输出方式,如果你尝试在JSP中使用ServletOutputStream就会引起错误.要嘛直接改用Servlet输出(复写service方法),要嘛删除除%>%中的任何东西(包括HTML标签,空格,回车等东西)应该就可以。对于这样的情况应该这样来解决,删除%>%之间的所有内容包括空格和换行符,最后也要消除空格和换行符,最好再加上一句response.reset()。

  原因二: 

  在J2EE的API参考里有这么个:

  ServletResponse的getWriter()方法里会抛出这个异常:

    IllegalStateException - if the getOutputStream method has already been called for this response object

  而它的getOutputStream()方法里会抛出这个异常:

    IllegalStateException - if the getOutputStream method has already been called for this response object

  并且两者的函数申明里都有这么样的一句

    Either this method or getOutputStream() may be called to write the body, not both.
    Either this method or getWriter() may be called to write the body, not both.


  以上说明也解释了为什么在往页面中写入图片的时候要使用如下循环格式

复制代码 代码如下:
OutputStream output=response.getOutputStream();
while((len=in.read(b)) >0) {
  output.write(b,0,len);
}
output.flush();

而不是把response.getOutputStream().write()放到循环体内

在页面中直接写:

复制代码 代码如下:
body bgcolor="#ffffff">
h1>
%
    response.getOutputStream();
%>
/h1>
/body>

将会出现错误消息如下:

java.lang.IllegalStateException: getOutputStream() has already been called for this response
org.apache.catalina.connector.Response.getWriter(Response.java:604)
org.apache.catalina.connector.ResponseFacade.getWriter(ResponseFacade.java:198)
org.apache.jasper.runtime.JspWriterImpl.initOut(JspWriterImpl.java:125)
org.apache.jasper.runtime.JspWriterImpl.flushBuffer(JspWriterImpl.java:118)

以上就是tomcat6下jsp出现getOutputStream() has already been called for this response异常的原因和解决方法的全部内容,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • Tomcat常见异常及解决方案代码实例
  • SpringBoot项目打包发布到外部tomcat(出现各种异常的解决)
  • 一次因信号量引发的tomcat异常退出解决
  • tomcat加载jar异常问题的分析与解决
  • 启动tomcat时 错误: 代理抛出异常 : java.rmi.server.ExportException: Port already in use: 1099的解决办法
  • 解决idea2020.2遇到pom.xml文件报错maven插件tomcat7的问题
  • 解决IDEA配置tomcat启动报错问题
  • 解决idea导入ssm项目启动tomcat报错404的问题
  • tomcat启动报错:java.util.zip.ZipException的解决方法
  • tomcat异常解决(Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986)

标签:临汾 乌兰察布 开封 自贡 山南 白银 吉林 铜川

巨人网络通讯声明:本文标题《tomcat6下jsp出现getOutputStream() has already been called for this response异常的原因和解决方法》,本文关键词  tomcat6,下,jsp,出现,getOutputStream,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《tomcat6下jsp出现getOutputStream() has already been called for this response异常的原因和解决方法》相关的同类信息!
  • 本页收集关于tomcat6下jsp出现getOutputStream() has already been called for this response异常的原因和解决方法的相关信息资讯供网民参考!
  • 推荐文章