出现此错误一般都是在jsp中使用了输出流,没有妥善处理好的原因
具体的原因就是在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();
彩色验证码完整的例子:
- <%@ page language="java" contentType="image/jpeg" pageEncoding="utf-8"%>
- <%@ page contentType="image/jpeg" 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(new Color());
- //g.drawRect(0,0,width-1,height-1);
- // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
- 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);
- }
- // 取随机产生的认证码(4位数字)
- String sRand="";
- for (int i=0;i<4;i++){
- //String rand=String.valueOf(random.nextInt(10)); //数字
- //String rand=String.valueOf((char)(Math.round(Math.random() * 25 + 65))); //字母大写 www.itstudy.cn
- String rand=String.valueOf((char)(Math.round(Math.random() * 25 + 97))); //字母小写
- 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
- 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();
- }
- %>
参考:杨雷 http://blog.csdn.net/ray_1981/archive/2008/03/07/2157447.aspx