使用IDEA实现java生成随机验证码

package test200.checkCode;
/*
需求:
定义方法实现随机产生一个5位的验证码,每位可能是数字、大写字母、小写字母。
分析:
定义一个方法,生成验证码返回:方法参数是位数、方法的返回值类型是String。
在方法内部使用for循环生成指定位数的随机字符,并连接起来。
把连接好的随机字符作为一组验证码进行返回。
*/

import java.util.Random;

public class check {
    public static void main(String[] args) {
        System.out.println("随机验证码为:" + CheckCode(4));
    }
    
    //定义方法随机生成5位验证码返回
    public static String CheckCode(int n) {
        Random r = new Random();

        //设置变量接收生成验证码
        String code = "";

        //定义for循环  循环n次 依次生成随机字符
        for (int i = 0; i <= n; i++) {
            int type = r.nextInt(3); //0 1 2
            switch (type) {
                case 0:
                    //大写字母(A 65 - Z 65+25)(0-25)+65
                    //char ch = (char)(r.nextInt(26)+65);
                    char ch = (char) (r.nextInt(26) + 65);
                    code += ch;
                    break;
                case 1:
                    //小写   97 - 122
                    char ch2 = (char) (r.nextInt(26) + 97);
                    code += ch2;
                    break;
                case 2:
                    //数字
                    int ch3 = r.nextInt(10);  //数字不需要强转char
                    code += ch3;
                    break;
            }
        }
        return code;
    }
}
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现验证码登录页面,需要在之前的示例代码中添加一个验证码输入框和一个生成验证码的逻辑。 下面是一个使用 Java 和 Spring Boot 框架实现验证码登录页面的示例: 1. 在 `pom.xml` 文件中添加以下依赖: ```xml <dependency> <groupId>com.github.axet</groupId> <artifactId>kaptcha</artifactId> <version>2.3.2</version> </dependency> ``` 2. 创建一个 `LoginController` 类,该类包含以下方法: ```java @GetMapping("/login") public String login() { return "login"; } @PostMapping("/doLogin") public String doLogin(@RequestParam String username, @RequestParam String password, @RequestParam String verifyCode, HttpSession session) { String kaptchaCode = (String) session.getAttribute("kaptchaCode"); if (!verifyCode.equalsIgnoreCase(kaptchaCode)) { return "redirect:/login?error=验证码错误"; } // 验证用户名和密码,如果验证通过,则跳转到主页 return "redirect:/index"; } @GetMapping("/verifyCode") public void verifyCode(HttpServletResponse response, HttpSession session) throws Exception { // 生成验证码图片,并将验证码文本存入 session response.setDateHeader("Expires", 0); response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate"); response.addHeader("Cache-Control", "post-check=0, pre-check=0"); response.setHeader("Pragma", "no-cache"); response.setContentType("image/jpeg"); String verifyCode = new Kaptcha().createText(); session.setAttribute("kaptchaCode", verifyCode); BufferedImage image = new Kaptcha().createImage(verifyCode); ServletOutputStream out = response.getOutputStream(); ImageIO.write(image, "jpg", out); out.flush(); out.close(); } ``` 3. 创建一个 `login.html` 页面,包含以下代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>验证码登录</title> <link rel="stylesheet" href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/4.5.0/css/bootstrap.min.css"> </head> <body> <div class="container"> <div class="row justify-content-center"> <div class="col-md-6"> <div class="card"> <div class="card-header">验证码登录</div> <div class="card-body"> <form action="/doLogin" method="post"> <div class="form-group"> <label for="username">用户名</label> <input type="text" class="form-control" id="username" name="username" required autofocus> </div> <div class="form-group"> <label for="password">密码</label> <input type="password" class="form-control" id="password" name="password" required> </div> <div class="form-group"> <label for="verifyCode">验证码</label> <div class="input-group"> <input type="text" class="form-control" id="verifyCode" name="verifyCode" required> <img src="/verifyCode" onclick="this.src='/verifyCode?t='+Math.random()" style="cursor: pointer;"> </div> </div> <button type="submit" class="btn btn-primary btn-block">登录</button> </form> </div> </div> </div> </div> </div> </body> </html> ``` 在这个页面中,我们创建了一个包含用户名、密码和验证码输入框的表单,并使用 Bootstrap 样式美化页面。验证码输入框旁边还有一个图像,点击图像可以刷新验证码。 这样,就实现了一个简单的验证码登录页面。当用户提交表单时,控制器会验证验证码是否正确,如果验证码正确,则继续验证用户名和密码,如果验证通过,则跳转到主页。否则,将出现错误消息并重定向到登录页面。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值