验证码生成

package servlet;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;

import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.sun.image.codec.jpeg.JPEGCodec;
import com.sun.image.codec.jpeg.JPEGImageEncoder;

/**
 * 验证码生成servlet, 防止客户端通过批量注册工具注册;一种即时变化的编码; 原理:绘制一个图片,在图片上画A-Z,a-z,0-9
 */
public class ValidateCodeServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public ValidateCodeServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
     *      response)
     */
    protected void doGet(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse
     *      response)
     */
    protected void doPost(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException {

        // 验证码图片的大小
        int width = 150;
        int height = 50;

        Random random = new Random();

        BufferedImage buffImg = new BufferedImage(width, height,
                BufferedImage.TYPE_INT_RGB);
        Graphics g = buffImg.getGraphics();
        g.setColor(Color.white);
        g.fillRect(0, 0, width, height); // 填充背景颜色

        g.setColor(Color.black);
        g.drawRect(0, 0, width - 1, height - 1); // 画一个边框

        // 绘制多条干扰线,其目的是为了避免程序探测
        g.setColor(Color.gray);
        int x = 0, y = 0, w = 0, h = 0;
        for (int i = 0; i < 100; i++) {
            x = random.nextInt(width);
            y = random.nextInt(height);
            w = random.nextInt(width / 3);
            h = random.nextInt(height / 3);
            g.drawLine(x, y, x + w, y + h);
        }

        // 绘制验证码a-z,A-z,0-9其中任意n个组合
        StringBuffer sbCode = new StringBuffer();
        String strCode = "";
        int red = 0, green = 0, blue = 0;
        int size = 20, hsize = 10;
        for (int i = 0; i < 6; i++) {
            red = random.nextInt(255);
            green = random.nextInt(255);
            blue = random.nextInt(255);
            g.setColor(new Color(red, green, blue));

            size = random.nextInt(20) + 20;
            g.setFont(new Font("Arial", Font.BOLD | Font.ITALIC, size));

            strCode = getRandomString();
            g.drawString(strCode, hsize, height - 15);

            hsize += random.nextInt(10) + 15;

            sbCode.append(strCode);
        }

        g.dispose();

        // 把验证码保存到session中,当用户请求的时候,可以将用户的输入和session中的验证码进行比较;
        request.getSession().setAttribute("validCode", sbCode.toString());
        //打印
        System.out.println("validCode="+request.getSession().getAttribute("validCode"));
        response.setContentType("image/jpeg"); // 设置响应类型,MIME规范的image/jpeg,(text/html)
        ServletOutputStream sos = response.getOutputStream();
        JPEGImageEncoder jpegEncoder = JPEGCodec.createJPEGEncoder(sos);
        jpegEncoder.encode(buffImg);
        sos.close();
    }

    // A-Z,a-z,0-9的Ascii范围
    public static String getRandomString() {
        Random r = new Random();
        int n = r.nextInt(3);
        switch (n % 3) {
        case 1:
            n = r.nextInt(25) + 65; // 65-90 A-Z
            break;
        case 2:
            n = r.nextInt(25) + 97; // 97-112 a-z
            break;
        default:
            n = r.nextInt(9) + 48; // 48-57 0-9
            break;
        }

        char c = (char) n;
        return new String(new char[] { c });

    }

}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

灬一路前进

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值