JAVA 验证码

没事用Servlet 实现了验证码 

下面是Servlet 的部分

package ch1;

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.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class ValidateCode extends HttpServlet
{
    public 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);
    }

    protected void service(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException
    {
        response.setContentType("text/html;charset=gb2312");
        //设置页面不缓存
        response.setHeader("Pragma", "No-cache");
        response.setHeader("Cache-Control", "no-cache");
        response.setDateHeader("Expires", 0);

        //   在内存中创建图象
        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("Comic   Sans   MS", Font.PLAIN, 20));

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

        //   随机产生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 sRand = "";
        for (int i = 0; i < 4; i++)
        {
            String rand = String.valueOf(random.nextInt(10));
            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
        request.getSession().setAttribute("", sRand);

        //   图象生效
        g.dispose();

        //   输出图象到页面
        ImageIO.write(image, "JPEG", response.getOutputStream());
    }
}

接着配置web.xml 部分

<servlet>
        <servlet-name>imgcode</servlet-name>
        <servlet-class>ch1.ValidateCode</servlet-class>
  </servlet>  
   <servlet-mapping>
         <servlet-name>imgcode</servlet-name>
         <url-pattern>/imgcode</url-pattern>
    </servlet-mapping>

好了现在可以写一个简单的.jsp 来测试一下了

<%@ page language="java" contentType="text/html; charset=gb2312"%>
<!DOCTYPE HTML PUBLIC "-//w3c//dtd html 4.0 transitional//en">
<html>
<head>
<title>Lomboz JSP</title>
</head>
<body bgcolor="#FFFFFF">

<div align=center>

   <form name="form1" method="post" action="">
     <table width="42%" border="0">
          <tr>
            <td width="21%">&nbsp;</td>
            <td width="68%">&nbsp;</td>
            <td width="11%">&nbsp;</td>
          </tr>
          <tr>
            <td align=right>用户名</td>
            <td align=center>
            
               <input type="text" name="username">            </td>
            <td>&nbsp;</td>
          </tr>
          <tr>
            <td align=right>密码:</td>
            <td align=center>
              <input type="password" name="usepwd">            </td>
            <td align=left><img src="imgcode"/></td>
          </tr>
          <tr>
            <td height="17" colspan="2" align='center'>&nbsp;</td>
            <td>&nbsp;</td>
          </tr>
          <tr>
            <td height="17" colspan="2" align='center'><label>&nbsp;&nbsp;
                <input type="submit" name="Submit" value="提交">
            &nbsp;&nbsp;
            <input type="reset" name="Submit2" value="重置">
            </label></td>
            <td>&nbsp;</td>
          </tr>
        </table>
   </form>
  
</div>


</body>
</html>

就这样 验证码就出来了

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值