Jsp生成图片验证码

package cn.z.servlet;

import java.awt.Color;import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
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 java.awt.Font;

public class GenerateCheckCodeServlet extends HttpServlet {
   
   
// 生成的验证码的宽与高
    int WIDTH = 80, HEIGHT = 30;

   
public void doGet(HttpServletRequest request, HttpServletResponse response)
           
throws ServletException, IOException {
        response.setDateHeader(
"Expires", 0);
        response.setHeader(
"Cache-control", "no-cache");
        response.setHeader(
"Pragma", "no-cache");

        ServletOutputStream out
= response.getOutputStream();
       
// 得到随机的验证码
        char[] rands = generateCheckCode();

        BufferedImage image
= new BufferedImage(WIDTH, HEIGHT,
                BufferedImage.TYPE_INT_RGB);
        Graphics g
= image.getGraphics();
       
// 先画背景
        drawBackground(g);
       
// 再画验证码
        drawCheckCode(g, rands);

        g.dispose();
       
// 设置响应头为image/jpeg
        response.setContentType("image/jpeg");

       
// 把验证码也放到session里,以便和用户手工输入的进行对比
        request.getSession().setAttribute("check-code", new String(rands));
        System.out.println(
new String(rands));

       
// 输出图片
        ImageIO.write(image, "JPEG", out);

 

 

        //一定要的

        out.clear();
        out
= pageContext.pushBody();

        out.flush();
        out.close();
    }

   
// 生成4位随机验证码的函数
    private char[] generateCheckCode() {
       
// 这个是用ASCII的方法,
        char[] rands = new char[4];
       
int rand = -1;
       
for (int i = 0; i < rands.length; i++) {
           
while (rand < 48 || (rand > 57 && rand < 65)
                   
|| (rand > 90 && rand < 97) || rand > 122) {

                rand
= (int) (Math.random() * 127);
               
// System.out.print(rand + "/t");
            }
            rands[i]
= (char) rand;
        }
       
return rands;
    }

   
// 第二种生成验证码的方法
    private char[] generateCheckCode2() {
       
// 这个是随机取出字符串中的字符.
        String chars = "abcdefghijklmnopqrstuvwxyz123456789";
       
char[] rands = new char[4];
       
int rand = -1;
       
for (int i = 0; i < rands.length; i++) {

            rand
= (int) (Math.random() * chars.length());
            rands[i]
= chars.charAt(rand);
        }
       
return rands;
    }

   
private void drawCheckCode(Graphics g, char[] rands) {
       
// 在不同的高度画验证码的每一个字符
        g.setColor(Color.BLACK);
        g.setFont(
new Font(null, Font.ITALIC | Font.BOLD, 18));
        g.drawString(
"" + rands[0], 11, 25);
        g.drawString(
"" + rands[1], 26, 15);
        g.drawString(
"" + rands[2], 41, 23);
        g.drawString(
"" + rands[3], 56, 18);
    }

   
private void drawBackground(Graphics g) {
       
// 画背景
        g.setColor(new Color(0xdcdcdc));
        g.fillRect(
0, 0, WIDTH, HEIGHT);

       
for (int i = 0; i < 500; i++) {
           
// 随机生成500个位置随机,颜色随机的干扰点,并画在背景上

           
int x = (int) (Math.random() * WIDTH);
           
int y = (int) (Math.random() * HEIGHT);

           
int red = (int) (Math.random() * 255);
           
int green = (int) (Math.random() * 255);
           
int blue = (int) (Math.random() * 255);

            g.setColor(
new Color(red, green, blue));
            g.drawOval(x, y,
2, 0);
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值