jsp验证码 (通过单击验证码或超链接换验证码)

本文介绍了一种使用Java生成和验证验证码的方法。该方法通过在图片上绘制随机字符并将其保存在session中来实现验证码的生成。同时,还提供了一个简单的登录表单,用于输入用户名、密码及验证码,并进行验证。
#code.jsp

<%@ page language="java"
    import="java.util.*"
    import="java.awt.*"
    import="java.awt.image.BufferedImage"
    import="javax.imageio.ImageIO"
    pageEncoding="UTF-8"
%>
<%
    response.setHeader("Cache-Control","no-cache");
    int width = 60;
    int height = 20;
    int length = 4;
    BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);
    //设置画笔
    Graphics g = image.getGraphics();
    //设定背景颜色
    g.setColor(new Color(200,200,200));
    g.fillRect(0, 0, width, height);
    //取随机产生的验证码(四位数字)
    
    String randStr = "";  
    Random random = new Random();  
    for (int i = 0; i < length; i++) {  
        boolean b = random.nextBoolean();  
        if (b) { // 字符串  
            int choice = random.nextBoolean() ? 65 : 97; //取得65大写字母还是97小写字母  
            randStr += (char) (choice + random.nextInt(26));// 取得大写字母  
        } else { // 数字  
            randStr += String.valueOf(random.nextInt(10));  
        }  
    }  
    session.setAttribute("randStr", randStr);
    //将验证码显示到图像中
    g.setColor(Color.black);
    g.setFont(new Font("",Font.PLAIN,20));
    g.drawString(randStr,5,17);
    //随机产生100个干扰点,使图像不容易被其它程序探测
    for(int i=0; i<100; i++){
        int x = random.nextInt(width);
        int y = random.nextInt(height);
        g.drawOval(x,y,1,1);
    }
    //输出图像的到页面
    ImageIO.write(image,"JPEG",response.getOutputStream());
    out.clear();
    out = pageContext.pushBody();
%>


# loginForm.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
    <body>
        welcome
        <br>
        <form name="loginForm" method="post" action="/Pro27/servlet/CheckCode">
            account:<input type="text" name="account"><br>
            password:<input type="password" name="password"><br>
            code:<input type="text" size="10" name="code">
            <img name="imgValidate" src="code.jsp" onClick="refresh()">
            <a href="javascript:refresh();">看不清,换一张 </a>  
            <br>
            <input type="submit" value="login">
            <br>
            ${sessionScope.codeCheck }
            <%session.removeAttribute("codeCheck"); %>
        </form>
    </body>
    <script type="text/javascript" language="JavaScript">
        function refresh(){
            loginForm.imgValidate.src = "code.jsp?"+Math.random();//new Date(); 此处必须加上Math.random()或new Date(),否则无法刷新验证码
        }
    </script>
</html>

转载于:https://www.cnblogs.com/jxgapyw/p/5045926.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值