> Java > java지도 시간 > 본문

무작위 인증코드 기능 완성예(Java 구현)

PHPz
풀어 주다: 2017-05-01 14:54:39
원래의
1618명이 탐색했습니다.

본 글은 자바에서 무작위 인증코드 기능을 구현하는 간단한 예시에 대한 내용을 주로 소개하고 있으니, 필요하신 분들은 참고하시면 됩니다.

랜덤 인증코드 구현에 대한 간단한 예시 Java의 기능

이제 많은 시스템에는 자동 등록 프로그램이나 자동 게시 프로그램의 사용을 피하기 위해 등록, 로그인 또는 정보 게시 모듈에 임의 코드 기능이 추가되어 있습니다.

인증 코드는 실제로 일부 문자를 무작위로 선택하여 페이지에 그림 형식으로 표시합니다. 제출 작업 중 사진 속 문자를 동시에 제출해야 하는 경우, 제출된 문자가 서버 세션에 저장된 정보와 다르면 제출된 정보가 유효하지 않은 것으로 간주됩니다. 자동 프로그램이 이미지를 분석하고 분석하는 것을 방지하기 위해 일반적으로 이미지에 일부 간섭선이 무작위로 생성되거나 문자가 왜곡되어 자동 인식이 더 어려워집니다.

여기에서는 서블릿을 사용하여 무작위 인증 코드를 구현합니다.

구현 코드 :

package com.servlet;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

/**
 * 生成随机验证码
 * @author bitiliu
 *
 */
public class ValidateCodeServlet extends HttpServlet 
{

 private static final long serialVersionUID = 1L;
 
 //验证码图片的宽度。
  private int width=60;
  //验证码图片的高度。
  private int height=20;
  //验证码字符个数
  private int codeCount=4;
  
  
  private int x=0;
  //字体高度
  private int fontHeight;  
  private int codeY;
  
  char[] codeSequence = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
  'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
  'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' };
  
  /**
   * 初始化验证图片属性
   */
  public void init() throws ServletException
 {
   //从web.xml中获取初始信息
   //宽度
 String strWidth=this.getInitParameter("width");
 //高度
 String strHeight=this.getInitParameter("height");
 //字符个数
 String strCodeCount=this.getInitParameter("codeCount"); 
 
 //将配置的信息转换成数值
 try
 {
  if(strWidth!=null && strWidth.length()!=0)
  {
  width=Integer.parseInt(strWidth);
  }
  if(strHeight!=null && strHeight.length()!=0)
  {
  height=Integer.parseInt(strHeight);
  }
  if(strCodeCount!=null && strCodeCount.length()!=0)
  {
  codeCount=Integer.parseInt(strCodeCount);
  }
 }
 catch(NumberFormatException e)
 {}
 
 x=width/(codeCount+1);
 fontHeight=height-2;
 codeY=height-4;
 
 }
  
  protected void service(HttpServletRequest req, HttpServletResponse resp)
  throws ServletException, java.io.IOException {
   
   //定义图像buffer
 BufferedImage buffImg = new BufferedImage(
width, height,BufferedImage.TYPE_INT_RGB);
 Graphics2D g = buffImg.createGraphics();

 //创建一个随机数生成器类
 Random random = new Random();

 //将图像填充为白色
 g.setColor(Color.WHITE);
 g.fillRect(0, 0, width, height);

 //创建字体,字体的大小应该根据图片的高度来定。
 Font font = new Font("Fixedsys", Font.PLAIN, fontHeight);
 //设置字体。
 g.setFont(font);

 //画边框。
 g.setColor(Color.BLACK);
 g.drawRect(0, 0, width - 1, height - 1);

 //随机产生160条干扰线,使图象中的认证码不易被其它程序探测到。
 g.setColor(Color.BLACK);
 for(int i = 0; i < 160; 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);
 }

 //randomCode用于保存随机产生的验证码,以便用户登录后进行验证。
 StringBuffer randomCode = new StringBuffer();
 int red = 0, green = 0, blue = 0;

 //随机产生codeCount数字的验证码。
 for (int i = 0; i < codeCount; i++) {
  //得到随机产生的验证码数字。
  String strRand = String.valueOf(codeSequence[random.nextInt(36)]);
  //产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同。
  red = random.nextInt(255);
  green = random.nextInt(255);
  blue = random.nextInt(255);

  //用随机产生的颜色将验证码绘制到图像中。
  g.setColor(new Color(red, green, blue));
  g.drawString(strRand, (i + 1) * x, codeY);

  //将产生的四个随机数组合在一起。
  randomCode.append(strRand);
 }
 // 将四位数字的验证码保存到Session中。
 HttpSession session = req.getSession();
 session.setAttribute("validateCode", randomCode.toString());

 // 禁止图像缓存。
 resp.setHeader("Pragma", "no-cache");
 resp.setHeader("Cache-Control", "no-cache");
 resp.setDateHeader("Expires", 0);

 resp.setContentType("image/jpeg");

 //将图像输出到Servlet输出流中。
 ServletOutputStream sos = resp.getOutputStream();
 ImageIO.write(buffImg, "jpeg", sos);
 sos.close();
 }

}
로그인 후 복사

web.xml에서 서블릿 선언 필요

<servlet>
 <servlet-name>ValidateCodeServlet</servlet-name>
 <servlet-class>com.servlet.ValidateCodeServlet</servlet-class>
 <init-param>
 <param-name>width</param-name>
 <param-value>200</param-value>
 </init-param>
 <init-param>
 <param-name>height</param-name>
 <param-value>80</param-value>
 </init-param>
 <init-param>
 <param-name>codeCount</param-name>
 <param-value>5</param-value>
 </init-param>
 </servlet>

 <servlet-mapping>  
 <servlet-name>ValidateCodeServlet</servlet-name>  
 <url-pattern>/validateCodeServlet</url-pattern>  
 </servlet-mapping>
로그인 후 복사

참조해야 하는 페이지 쓰기:


<ccid_file values="validateCodeServlet" width="100/" />
로그인 후 복사

사용자가 제출한 후 사용자가 입력한 인증 코드를 세션에 저장된 문자열과 비교하여 인증 효과를 얻을 수 있습니다.

위 내용은 무작위 인증코드 기능 완성예(Java 구현)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!