婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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異常的原因和解決方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 防城港市| 陆良县| 海淀区| 会昌县| 都昌县| 肥城市| 卓尼县| 达拉特旗| 南城县| 马龙县| 龙里县| 监利县| 新民市| 山西省| 定远县| 巴楚县| 乌兰县| 乐业县| 烟台市| 富裕县| 南江县| 汪清县| 达日县| 罗平县| 北票市| 大宁县| 武乡县| 松滋市| 库尔勒市| 普兰店市| 绵阳市| 积石山| 喀什市| 陕西省| 襄樊市| 安康市| 大洼县| 普定县| 文昌市| 弥渡县| 郓城县|