Blog / 阅读

Servlet生成验证码图片

by admin on 2014-03-29 11:13:03 in ,



1.验证码 -- 平台项目帐号登录时常用到的,有一定安全防范君子的报障,可防范没有什么技术小人呵呵,开玩笑不要认真,可能对初学者有帮助,有需要拿去吧
:Servlet生成验证码图片

 package com.logcd.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.*;
 import java.io.*;
 import javax.servlet.http.*;
 import javax.servlet.ServletException;
 import javax.servlet.http.HttpServlet;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
  
  @SuppressWarnings("serial")
  public class RandomCode extends HttpServlet {
  
      public void doGet(HttpServletRequest request, HttpServletResponse response)
              throws ServletException, IOException {
  
          this.doPost(request, response);
      }
  
      public void doPost(HttpServletRequest request, HttpServletResponse response)
              throws ServletException, IOException {
  
          // 验证码图片的宽度。
          int width = 70;
          // 验证码图片的高度。
          int height = 30;
          BufferedImage buffImg = new BufferedImage(width, height,
                  BufferedImage.TYPE_INT_RGB);
          Graphics2D g = buffImg.createGraphics();
  
          // 创建一个随机数生成器类。
          Random random = new Random();
  
          // 设定图像背景色(因为是做背景,所以偏淡)
          g.setColor(getRandColor(200, 250));
          g.fillRect(0, 0, width, height);
          // 创建字体,字体的大小应该根据图片的高度来定。
          Font font = new Font("Times New Roman", Font.HANGING_BASELINE, 28);
          // 设置字体。
          g.setFont(font);
  
          // 画边框。
          g.setColor(Color.BLACK);
          g.drawRect(0, 0, width - 1, height - 1);
          // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到。
  //g.setColor(Color.GRAY);
          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);
          }
  
          // randomCode用于保存随机产生的验证码,以便用户登录后进行验证。
          StringBuffer randomCode = new StringBuffer();
  
          // 设置默认生成4个验证码
          int length = 4;
          // 设置备选验证码:包括"a-z"和数字"0-9"
          String base = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
  
          int size = base.length();
 
          // 随机产生4位数字的验证码。
         for (int i = 0; i < length; i++) {
              // 得到随机产生的验证码数字。
              int start = random.nextInt(size);
              String strRand = base.substring(start, start + 1);
  
              // 用随机产生的颜色将验证码绘制到图像中。
  // 生成随机颜色(因为是做前景,所以偏深)
  //g.setColor(getRandColor(1, 100));
              
  //调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
              g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
  
              g.drawString(strRand, 15 * i + 6, 24);
  
              // 将产生的四个随机数组合在一起。
              randomCode.append(strRand);
          }
          // 将四位数字的验证码保存到Session中。
          HttpSession session = request.getSession();
          session.setAttribute("rand", randomCode.toString());
 
        //图象生效
          g.dispose();
  
          // 禁止图像缓存。
          response.setHeader("Pragma", "no-cache");
          response.setHeader("Cache-Control", "no-cache");
         response.setDateHeader("Expires", 0);
 
         response.setContentType("image/jpeg");
 
         // 将图像输出到Servlet输出流中。
         ServletOutputStream sos = response.getOutputStream();
         ImageIO.write(buffImg, "jpeg", sos);
         sos.flush();
         sos.close();
 
    }
 
     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);
     }
 
 }
2.配置


     <servlet>
         <servlet-name>RandomCode</servlet-name>
         <servlet-class>com.logcd.servlet.RandomCode</servlet-class>
     </servlet>
     <servlet-mapping>
         <servlet-name>RandomCode</servlet-name>
         <url-pattern>/randomCode</url-pattern>
     </servlet-mapping>
3.调用


  <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  <meta http-equiv="pragma" content="no-cache"/>
  <meta http-equiv="cache-control" content="no-cache"/>
  <meta http-equiv="expires" content="0"/>
  
  <iframe src="http://127.0.0.1/js_test/randomCode" id="codeFrame" name="codeFrame" frameborder="no" border="0" marginwidth="0"
       marginheight="0" scrolling="no" allowtransparency="yes" height="35" width="102"></iframe>
       <a href="javascript:void(0);" onclick="refreshCode();">看不清,换一张</a>
      <br> 
     <span id="codeImg"><img border=0 src="randomCode"></span>
     <a href="javascript:void(0);" onclick="reloadCode()">看不清,再换一张</a>
 


  function $(id){
      return document.getElementById(id);
  }
 
  /**刷新iframe**/
  function refreshCode(){
      window.frames["codeFrame"].location.reload();
  }
  
 /**替换图片**/
 function reloadCode(){
     $("codeImg").innerHTML = "<img border=0 src='randomCode'>";
 }



4、上项目结构图:


5、运行效果图



写评论

相关文章

上一篇:解决unity3d读写中文乱码

下一篇:DES加密算法详解- -

评论

写评论

* 必填.

分享

栏目

赞助商


热门文章

Tag 云