使用jsp快速生成动态验证码

在设计登录界面时验证码是必不可少,本实例将简单的生成动态验证码。
根据个人需求将生成验证码代码放到不同的的地方,可以放到前段控制器中通过请求方式生成验证码,也可已将代码放到一个JSP页面通过应用JSP页面生成验证码
工具:J2EE

通过jsp生成验证码

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@page import="java.awt.image.BufferedImage"%>  
<%@page import="java.awt.Graphics2D"%>  
<%@page import="java.awt.Color"%>  
<%@page import="java.awt.Font"%>  
<%@page import="javax.imageio.ImageIO"%>  
<%@page import="java.util.Random"%> 
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>验证码</title>
</head>
<body>
<%  
    int width = 60;//定义图片的宽度  
    int height = 20;//定义图片的高度  
    // 创建具有可访问图像数据缓冲区的Image  
    BufferedImage buffImg = new BufferedImage(width, height,  
            BufferedImage.TYPE_INT_RGB);  
    Graphics2D g = buffImg.createGraphics();  

    // 创建一个随机数生成器  
    Random random = new Random();  
    //将图像填充为 白色  
    g.setColor(Color.WHITE);  
    g.fillRect(0, 0, width, height);  

    // 创建字体,字体的大小应该根据图片的高度来定  
    Font font = new Font("Times New Roman", Font.PLAIN, 18);  
    // 设置字体  
    g.setFont(font);  

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

    // 随机产生160条干扰线 ,使图像中的验证码不易被其它程序探测到
    g.setColor(Color.LIGHT_GRAY);  
    for (int i = 0; i < 160; i++) {  
        int x = random.nextInt(width);  
        int y = random.nextInt(height);  
        int x1 = random.nextInt(12);  
        int y1 = random.nextInt(12);  
        g.drawLine(x, y, x + x1, y + y1);  
    }  

    // randomCode 用于保存随机产生的验证码  ,以便用户登陆后进行验证
    StringBuffer randomCode = new StringBuffer();  
    int red = 0, green = 0, blue = 0;  

    // 随机产生4位数字的验证码  
    for (int i = 0; i < 4; i++) {  
        // 得到随机产生的验证码数字  
        String strRand = String.valueOf(random.nextInt(10));  

        // 产生随机的颜色分量来构造颜色值 ,这样输出的每位数字的颜色值都将不同 
        red = random.nextInt(110);  
        green = random.nextInt(50);  
        blue = random.nextInt(50);  

        // 用随机产生的颜色将验证码绘制到图像中  
        g.setColor(new Color(red, green, blue));  
        g.drawString(strRand, 13 * i + 6, 16);  
        //将产生的四个随机数组合在一起
        randomCode.append(strRand);  
    }  

    // 将四位数字的验证码保存到session中  
    //HttpSession session = request.getSession();  
    session.setAttribute("randomCode", randomCode.toString());  

    // 禁止图像缓存  
    response.setHeader("Pragma", "no-cache");  
    response.setHeader("Cache-Control", "no-cache");  
    response.setDateHeader("Expires", 0);  

    response.setContentType("image/jpeg");  
    // 将图像输出到servlet输出流中  
    ServletOutputStream sos = response.getOutputStream();  
    ImageIO.write(buffImg, "jpeg", sos);  
    sos.close();  
    //sos = null;  
    out.clear();  
    out = pageContext.pushBody();  
%>  
</body>
</html>

登录页的代码,在登陆也引入这个js

</head>
<body>
<div id="loginpanelwrap" align="center">  
        <div>  
            <div>登录</div>  
        </div>  

        <form id="form1" action="do_login.jsp" method="post">  
                   <table>
                   <tr>  
                   <td> <label>用户名:</label>  
                    <input id="username" type="text" name="username" /><br>  

                   </td>  
                   </tr>
                   </table>  
                <label>密码:</label>  
                <input type="password" name="password" id="password"/><br>  

                <label>验证码:</label>  
                <input type="text" name="validationCode" id="validationCode"/>  
                <!--<img id="validationCode_img"  src="validate.jsp"><br>-->
                <img src="validate.jsp"  id="picture" onClick="change()" id="picture"><!--点击验证码可以进行动态刷新  -->
                <!--刷新验证码的src-->
                <script>  
              function change(){  
              var pic=document.getElementById("picture");  
              var i=Math.random();//目的是使页面不一样  
              pic.src="validate.jsp?id="+i;  
                 }  
                 </script>    
                <table>      
                 <tr> 
               <input type="submit" id="loginform_submit" value="登录"/>               
                </tr>  
            </table>

        </form>  

    </div>  
</body>
</html>

效果图页面是我自己的页面,你如果要用的话,js代码整个拷到你的项目里,然后再在这里插入图片描述
引入你自己的js路径
在这里插入图片描述
当你要去验证登陆时,验证码中的内容,已经放到session中了,
在这里插入图片描述
后端代码直接用session获取即可

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是 JSP 生成验证码的示例代码: ```jsp <%@ page contentType="image/jpeg" %> <%@ page import="java.awt.*, java.util.*, java.awt.image.*, javax.imageio.*, java.io.*" %> <% // 定义验证码图片的大小 int width = 100; int height = 50; // 创建一个 BufferedImage 对象来绘制验证码图片 BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); // 获取 Graphics2D 对象,用于绘制验证码图片 Graphics2D g = image.createGraphics(); // 设置背景颜色为白色 g.setColor(Color.WHITE); g.fillRect(0, 0, width, height); // 创建一个随机数生成器,用于生成验证码文本 Random random = new Random(); String captcha = ""; for (int i = 0; i < 4; i++) { // 生成一个随机数字或字母作为验证码的一个字符 int r = random.nextInt(36); if (r < 10) { captcha += r; } else { captcha += (char)('a' + (r - 10)); } } // 将验证码文本保存到 Session 中,以便后续验证 session.setAttribute("captcha", captcha); // 设置字体和字号 Font font = new Font("Arial", Font.BOLD, 24); g.setFont(font); // 绘制验证码文本 g.setColor(Color.BLACK); g.drawString(captcha, 20, 35); // 绘制干扰线 for (int i = 0; i < 10; i++) { int x1 = random.nextInt(width); int y1 = random.nextInt(height); int x2 = random.nextInt(width); int y2 = random.nextInt(height); g.setColor(Color.GRAY); g.drawLine(x1, y1, x2, y2); } // 将验证码图片输出给客户端 OutputStream out = response.getOutputStream(); ImageIO.write(image, "jpeg", out); out.flush(); out.close(); %> ``` 这段代码会生成一个大小为 100x50 像素的验证码图片,并将验证码文本保存到 Session 中。验证码文本由 4 个随机字母或数字组成,字体为 Arial、字号为 24,颜色为黑色。同时,还会绘制 10 条随机干扰线,使验证码更难被机器识别。最后,将生成验证码图片输出给客户端。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值