一个不会报错的jsp彩色验证码程序
一般的,会报servlet错误:
getOutputStream() has already been called for this response
但是这个程序不会报错,原因是把里面的空格都删除
-------------------------------------------------------------
在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();
--------------------------------------------------------
分割线内为引用~
1<%@ page import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*" %>
2<%@ page import="java.io.OutputStream" %>
3<%!
4Color getRandColor(int fc,int bc){
5Random random = new Random();
6if(fc>255) fc=255;
7if(bc>255) bc=255;
8int r=fc+random.nextInt(bc-fc);
9int g=fc+random.nextInt(bc-fc);
10int b=fc+random.nextInt(bc-fc);
11return new Color(r,g,b);
12}
13%>
14<%
15try{
16response.setHeader("Pragma","No-cache");
17response.setHeader("Cache-Control","no-cache");
18response.setDateHeader("Expires", 0);
19int width=60, height=20;
20BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
21OutputStream os=response.getOutputStream();
22Graphics g = image.getGraphics();
23Random random = new Random();
24g.setColor(getRandColor(200,250));
25g.fillRect(0, 0, width, height);
26
27g.setFont(new Font("Times New Roman",Font.PLAIN,18));
28g.setColor(getRandColor(160,200));
29for (int i=0;i<155;i++)
30{
31int x = random.nextInt(width);
32int y = random.nextInt(height);
33int xl = random.nextInt(12);
34int yl = random.nextInt(12);
35g.drawLine(x,y,x+xl,y+yl);
36}
37String sRand="";
38for (int i=0;i<4;i++){
39String rand=String.valueOf(random.nextInt(10));
40sRand+=rand;
41g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
42g.drawString(rand,13*i+6,16);
43}
44session.setAttribute("rand",sRand);
45g.dispose();
46
47ImageIO.write(image, "JPEG",os);
48os.flush();
49os.close();
50os=null;
51response.flushBuffer();
52out.clear();
53out = pageContext.pushBody();
54}
55catch(IllegalStateException e)
56{
57System.out.println(e.getMessage());
58e.printStackTrace();
59}%>
60
分享到:
相关推荐
JSP彩色验证码JSP彩色验证码JSP彩色验证码
本文将详细介绍如何在JSP环境中实现一种彩色验证码的功能。 #### 二、技术栈与环境 - **后端技术**:JSP(Java Server Pages) - **服务器环境**:如Tomcat等支持JSP的服务器 - **前端展示**:通过浏览器展示生成...
通过以上步骤,我们可以实现一个基本的JSP彩色验证码程序。然而,随着技术的发展,更高级的验证码解决方案如谷歌的reCAPTCHA已经出现,它们提供了更高的安全性,同时也降低了用户的输入难度。在实际应用中,应根据...
总结来说,JSP彩色验证码源码是一个结合了Java图形处理和JSP动态生成的实用示例,它提供了一种安全、视觉友好的方式来防止自动程序的恶意行为。通过理解和实践这段源码,开发者不仅可以掌握验证码的实现原理,还能...
本教程将深入探讨如何使用Java Server Pages (JSP) 技术来实现一个彩色的验证码功能。我们将涵盖以下几个关键知识点: 1. **JSP基础**:JSP是Java Web开发的一种技术,它允许开发者在HTML页面中嵌入Java代码,以...
jsp彩色验证码.rar jsp彩色验证码.rar
在这个"JSP生成彩色验证码程序例子"中,我们将深入探讨如何利用JSP实现一个功能丰富的彩色验证码生成器。 验证码的主要目的是为了防止自动机器人或恶意脚本进行非法操作,例如防止垃圾邮件、注册机等。它通过显示一...
jsp彩色验证码.rar jsp彩色验证码.rar 和csdn上传资源时的验证码一样
经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码
- 在此页面中需要引入`image.jsp`生成的验证码图像,并提供一个表单让用户输入他们看到的验证码。 ```html <img src="image.jsp" alt="验证码"> 请输入验证码"> 提交 ``` 2. **验证 (`check.jsp`)**: - ...
本文将详细解析一个用于生成彩色验证码的JSP源程序,该程序能够生成包含四个随机数字和杂乱背景的图片,并且数字与背景的颜色都会随机变化。此外,还介绍了一个用于展示验证码图片并进行验证的示例页面。 #### 二、...
JSP中彩色验证码 注册验证码 中文验证码 图片验证码的生成
总的来说,“JSP彩色验证码--Md5类”是一个结合了动态网页技术、色彩设计和安全哈希的解决方案,用于提供一种可靠的用户验证方法。理解并掌握这种技术有助于提升Web应用的安全性,防止恶意自动化行为。
JSP实现彩色验证码(源码示例)
在IT行业中,验证码是一种常见的安全机制,用于防止自动化的机器人程序进行恶意操作,例如垃圾邮件发送、刷票等。本文将深入探讨如何使用jCaptcha库来为JSP(Java Server Pages)创建彩色的验证码。 jCaptcha是一个...
本项目重点在于使用JSP(Java Server Pages)技术自动生成彩色验证码,为用户提供一个视觉上更友好的验证体验。下面我们将深入探讨这个主题。 首先,验证码通常由一组随机字符组成,这些字符可以是数字、字母或其他...
整个html打开可以看到效果,不包含验证码背景图片,自己找一个命名为code.jpg就有背景了,js验证码比jsp...这个程序既可以直接验证,也可以点击验证码刷新一个新的验证码(当原来的验证码看不清楚的时候),再验证
本篇将详细介绍如何在JSP环境下创建一个彩色的验证码,以提高用户体验并增强安全性。 首先,我们需要了解JSP(JavaServer Pages)的基本概念。JSP是Java的一种动态网页技术,允许开发者将Java代码嵌入到HTML或XML文...
总的来说,"jsp验证码程序"是一个利用JSP技术构建的简单但有效的安全防护措施,旨在保护网站免受自动化攻击,确保用户交互的真实性。了解并掌握如何创建这样的验证码对于开发安全的Web应用至关重要。
通过以上步骤,我们就能在JSP中实现一个彩色且具有汉字和数字的验证码功能。这样的验证码既能提供良好的用户体验,又能有效地防止自动化攻击,确保网站的安全性。在实际应用中,还可以根据需要调整验证码的复杂度,...