login_image.jsp
<%@ page contentType="image/jpeg" import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*" pageEncoding="utf-8"%>
<%!
//随机获取图片颜色
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);
}
%>
<%
//response设置
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);
//Graphics图片对象
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
session.setAttribute("VALIDATION_CODE",sRand);
g.dispose();
ImageIO.write(image, "JPEG", response.getOutputStream());
out.clear();
out = pageContext.pushBody();
%>
loginform.jsp
验证码:
<input type="text" name="j_validation_code" id="j_validation_code"
style="font-size: 9pt; background-color: #EDEDED;
border: 1 inset #BEBEBE"
size="17" onfocus="this.style.backgroundColor='#FFF7DA'"
tabindex="3"
onblur="this.style.backgroundColor='#EDEDED'">
<img src="<c:url value="/common/loginimage.jsp"/>"
onclick="refurbish()" alt="点击图片显示新的验证码"
style="margin-top: 10px">
ValidationCodeFilter.java
import javax.servlet.http.HttpServletRequest;
import org.acegisecurity.Authentication;
import org.acegisecurity.AuthenticationException;
import org.acegisecurity.ui.webapp.AuthenticationProcessingFilter;
import com.uiiang.iknow.common.exception.ValidationCodeException;
public class ValidationCodeFilter
extends AuthenticationProcessingFilter {
public Authentication attemptAuthentication(
HttpServletRequest httpServletRequest)
throws AuthenticationException {
String inputValidationCode = httpServletRequest
.getParameter("j_validation_code");
// 从Session中取出验证码
String ssnValidationCode = (String)
httpServletRequest.getSession()
.getAttribute("VALIDATION_CODE");
// 取出后就失效,
httpServletRequest.getSession()
.setAttribute("VALIDATION_CODE",
"Game Over");
if (ssnValidationCode == null
|| ssnValidationCode.equalsIgnoreCase("Game Over")
|| !ssnValidationCode.equals(inputValidationCode)) {
// 用户输入的值与看到的不一致,抛出异常
httpServletRequest
.setAttribute("errorMsg", "验证码输入错误!");
throw new ValidationCodeException("验证码输入错误!");
}
return super.attemptAuthentication(httpServletRequest);
}
}
ValidationCodeException.java
import org.acegisecurity.AuthenticationException;
public class ValidationCodeException extends AuthenticationException {
private static final long serialVersionUID = 1L;
public ValidationCodeException(String s) {
super(s);
}
}
<bean id="authenticationProcessingFilter"
class="com.uiiang.iknow.common.webapp.filter.ValidationCodeFilter">
<property name="authenticationManager" ref="authenticationManager" />
<property name="authenticationFailureUrl" value="/login.jsp?error=true" />
<property name="defaultTargetUrl" value="/login.do" />
<property name="filterProcessesUrl" value="/j_security_check" />
<property name="alwaysUseDefaultTargetUrl" value="true" />
</bean>
分享到:
相关推荐
"jsp生成验证码很好的例子"这个标题暗示我们将探讨如何使用JavaServer Pages(JSP)技术来创建一个有效的验证码系统。 首先,验证码的生成过程包括以下几个步骤: 1. **随机字符生成**:验证码通常由一组随机的...
在本主题中,我们关注的是"最新JSP生成验证码"的技术实现。JSP(JavaServer Pages)是Java平台上的一个动态网页技术,允许开发者在HTML页面中嵌入Java代码,以生成动态内容。现在让我们深入探讨如何在JSP中生成...
在IT行业中,JSP(JavaServer Pages)是一种用于创建动态网页的技术,它...总的来说,理解和掌握JSP生成验证码的原理和实现方式,对于提升Web开发中的安全性具有重要意义,也是每一个Java Web开发者必备的技能之一。
### JSP生成验证码知识点详解 #### 一、概述 在Web应用中,为了防止机器自动填写表单,经常需要加入验证码这一环节。验证码的主要作用是确保操作是由人类而非自动化脚本执行的。本文将详细介绍如何使用Java Server...
JSP生成验证码源程序源代码
### JSP生成验证码图片:深度解析与实现细节 在当今的网络应用中,验证码作为一种防止自动化工具滥用的有效手段,被广泛应用于用户登录、表单提交等场景中。本文将深入探讨如何利用Java Server Pages(JSP)技术...
JSP生成图片验证码.txtJSP生成图片验证码.txtJSP生成图片验证码.txtJSP生成图片验证码.txtJSP生成图片验证码.txt
采用jsp 生成验证码,我自己使用过的。使用方法: <img src="./../function/imagejsp.jsp" style="float: left">
1. **随机生成验证码**:首先,我们需要创建一个包含随机字符的字符串作为验证码。这些字符可以是字母、数字或者是两者混合。通常,验证码的长度为4到6个字符。在JSP中,我们可以使用`java.util.Random`类来生成...
生成验证码,用于resin服务器的验证码生成
在Web开发中,使用JSP(JavaServer Pages)来生成验证码图片是一种常见的方法。下面我们将详细讨论如何在JSP中实现验证码的生成。 首先,我们需要理解验证码的基本原理。验证码通常包含一串随机的字母和数字,有时...
jsp生成动态验证码,jsp生成动态验证码。
经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码经典JSP生成验证码
JSP生成验证码是一个常见的Web应用需求,通常用于防止恶意的自动注册、自动登录、信息采集等行为。本文档详细介绍了在JSP页面中生成并显示一个4位数验证码的方法,该验证码由数字和字母混合组成,同时提供了一个测试...
Jsp生成随机验证码 1.使用方式:在Jsp页面使用标签即可,例如:<img src="../image.jsp" title="验证码" alt="验证码" id="vCode" /> 2.本代码生成的验证码是一张 由26个英文字母和0-9随机组成的一个组合
在jsp登录页面生成验证码,并在登录的时候在后台进行验证码是否一致的比较。
1. **随机生成验证码**:首先,我们需要创建一个函数,它能生成一个随机的字符串,长度通常为4-6位。这个字符串可以包含大小写字母和数字。可以使用Java的`Random`类和`StringBuilder`来实现。 2. **绘制图片**:...
1. JSP 验证码生成:使用 JSP 生成验证码,包括生成验证码图片、将验证码存入 SESSION 等。 * 使用 JSP 生成验证码图片,通过 BufferedImage 和 Graphics 实现验证码图片的生成。 * 将验证码存入 SESSION,以便...
JSP生成验证码图片 在JSP中,我们通常使用Servlet来生成验证码图片,因为Servlet更适合作为处理逻辑的组件。首先,我们需要一个随机字符串生成器,它可以生成包含字母和数字的组合。接着,我们将这个字符串转化为...