Servlet动态生成验证码

1、使用Servlet动态生成验证码

package com.xuhu.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.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet implementation class CheckCode
 */
@WebServlet("/CheckCode")
public class CheckCode extends HttpServlet
{
    private static final long serialVersionUID = 1L;

    private static final int IMG_WIDTH = 100;
    private static final int IMG_HEIGHT = 25;

    //验证码字符
    private char[] chs = new char[]
    {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E',
            'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'S',
            'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f',
            'g', 'h', 'i', 'j', 'k', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't',
            'u', 'v', 'w', 'x', 'y', 'z'};

    protected void doGet(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException
    {
        this.doPost(request, response);
    }

    protected void doPost(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException
    {
        // 1、在内存中创建图片对象
        BufferedImage img = new BufferedImage(IMG_WIDTH, IMG_HEIGHT,
                BufferedImage.TYPE_INT_RGB);
        
        // 2、获取这个图像画笔
        Graphics g = img.getGraphics();
        
        // 3、设置图像的背景色
        setImageBackground(g);
        
        // 4、设置图片的边框
        setImageBorder(g);
        
        // 5、设置图片随机线
        setImageRandomLine(g);
        
        // 6、设置图片的随机数据
        setImageRandomData(g);

        // 7、将生成的验证码图片回传给浏览器,并通知浏览器以图片的方式打开数据
        response.setContentType("image/jpeg");
        
        //设置浏览器不缓存数据
        response.setHeader("Expires", "0");
        response.setHeader("Cache-Control", "no-cache");
        response.setHeader("Pragma", "no-cache");
        
        ImageIO.write(img, "jpg", response.getOutputStream());

    }

    /**
     * 设置图片背景色
     * @param g
     */
    private void setImageBackground(Graphics g)
    {
        g.setColor(Color.WHITE);
        g.fillRect(0, 0, IMG_WIDTH, IMG_HEIGHT);
    }

    /**
     * 设置图片边框
     * @param g
     */
    private void setImageBorder(Graphics g)
    {
        g.setColor(Color.BLUE);
        g.drawRect(1, 1, IMG_WIDTH - 2, IMG_HEIGHT - 2);
    }

    /**
     * 设置干扰线
     * @param g
     */
    private void setImageRandomLine(Graphics g)
    {
        g.setColor(Color.GREEN);

        for (int i = 0; i < 6; i++)
        {
            int x1 = new Random().nextInt(IMG_WIDTH);
            int y1 = new Random().nextInt(IMG_HEIGHT);

            int x2 = new Random().nextInt(IMG_WIDTH);
            int y2 = new Random().nextInt(IMG_HEIGHT);

            g.drawLine(x1, y1, x2, y2);
        }

    }

    /**
     * 填充数据
     * @param g
     */
    private void setImageRandomData(Graphics g)
    {
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < 4; i++)
        {
            sb.append(chs[new Random().nextInt(chs.length)] + " ");
        }

        g.setColor(Color.RED);
        g.setFont(new Font(null, Font.BOLD | Font.ITALIC, 20));
        g.drawString(sb.toString(), 15, 20);
    }

}

2、实现点击图片刷新验证码功能

<script type="text/javascript">
//点击刷新验证码图片
function refresh()
{
	var r = Math.random();
	var img = document.getElementById("CheckCode");
	img.src = "CheckCode?r=" + r;
}
</script>

<body>
	用户名:<input type="text" /><br />
	密   码:<input type="password" /><br />
	验证码:<input type="text" style="width: 80px;"/>
	<img id="CheckCode" src="CheckCode" οnclick="refresh();" style="cursor: pointer;" />
</body>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值