jsp生成验证码

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>

你可能感兴趣的:(java,jsp,UI,cache,servlet)