下面的程序是我根据别人的修改的 具体地址我也不清楚,不是原创 :) 标明下 呵呵 以免误会


import java.awt.*;

import java.awt.image.*;

import javax.imageio.*;

import java.util.Random;

import java.io.IOException;

import javax.servlet.*;

import javax.servlet.http.*;


public class CheckCode extends HttpServlet {


    private 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);

    }


    public void doGet(HttpServletRequest req, HttpServletResponse res)

              throws IOException, ServletException {

        // 设置页面不缓存

        res.setHeader("Pragma", "No-cache");

        res.setHeader("Cache-Control", "no-cache");

        res.setDateHeader("Expires", 0);

        HttpSession session = req.getSession(true);


        // 在内存中创建图象

        int width = 60, height = 20;

        BufferedImage image = new BufferedImage(width, height,

                  BufferedImage.TYPE_INT_RGB);


        // 获取图形上下文

        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));


        // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到

        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);

        }


        // 取随机产生的认证码(4位数字)

        String[] code = { "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", "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" };

        // 数组长度

        int length = code.length;


        String sRand = "";

        for (int i = 0; i < 4; i++) {

              // String rand=String.valueOf(random.nextInt(10)); //原来方法这个是产生数字的0-9

              // sRand+=rand;

              int start = random.nextInt(length);

              String rand = code[start];

              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("rand", sRand);


        // 图象生效

        g.dispose();


        // 输出图象到页面

        ImageIO.write(image, "JPEG", res.getOutputStream());

    }

}