当前位置: 首页 > 编程笔记 >

java如何生成登录随机验证码

宦宏爽
2023-03-14
本文向大家介绍java如何生成登录随机验证码,包括了java如何生成登录随机验证码的使用技巧和注意事项,需要的朋友参考一下

本文实例为大家分享了java生成登录随机验证码的具体代码,供大家参考,具体内容如下

验证码工具类: VerifyUtil.java

import java.awt.*;
import java.awt.image.BufferedImage;
import java.util.HashMap;
import java.util.Map;
import java.util.Random;

public class VerifyUtil {
  // 验证码字符集
  private static final char[] CHARS = {
      '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
      'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
      'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
      'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
      'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};
  // 字符数量
  private static final int SIZE = 4;
  // 干扰线数量
  private static final int LINES = 5;
  // 宽度
  private static final int WIDTH = 80;
  // 高度
  private static final int HEIGHT = 40;
  // 字体大小
  private static final int FONT_SIZE = 30;

  /**
   * 生成随机验证码及图片
   */
  public static Map<String, Object> createImage() {
    StringBuffer sb = new StringBuffer();
    // 1.创建空白图片
    BufferedImage image = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);
    // 2.获取图片画笔
    Graphics graphic = image.getGraphics();
    // 3.设置画笔颜色
    graphic.setColor(Color.LIGHT_GRAY);
    // 4.绘制矩形背景
    graphic.fillRect(0, 0, WIDTH, HEIGHT);
    // 5.画随机字符
    Random ran = new Random();
    for (int i = 0; i < SIZE; i++) {
      // 取随机字符索引
      int n = ran.nextInt(CHARS.length);
      // 设置随机颜色
      graphic.setColor(getRandomColor());
      // 设置字体大小
      graphic.setFont(new Font(null, Font.BOLD + Font.ITALIC, FONT_SIZE));
      // 画字符
      graphic.drawString(CHARS[n] + "", i * WIDTH / SIZE, HEIGHT * 2 / 3);
      // 记录字符
      sb.append(CHARS[n]);
    }
    // 6.画干扰线
    for (int i = 0; i < LINES; i++) {
      // 设置随机颜色
      graphic.setColor(getRandomColor());
      // 随机画线
      graphic.drawLine(ran.nextInt(WIDTH), ran.nextInt(HEIGHT), ran.nextInt(WIDTH), ran.nextInt(HEIGHT));
    }
    // 7.返回验证码和图片
    Map<String, Object> map = new HashMap<>();
    //验证码
    map.put("code", sb.toString());
    //图片
    map.put("image", image);
    return map;
  }

  /**
   * 随机取色
   */
  public static Color getRandomColor() {
    Random ran = new Random();
    return new Color(ran.nextInt(256), ran.nextInt(256), ran.nextInt(256));
  }
}

获取验证码

@GetMapping("/verify-code")
public void getCode(HttpServletResponse response) throws Exception{
  Map<String, Object> map = VerifyUtil.createImage();
  //将图片输出给浏览器
  BufferedImage image = (BufferedImage) map.get("image");
  response.setContentType("image/png");
  OutputStream os = response.getOutputStream();
  ImageIO.write(image, "png", os);
}

页面

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>获取验证码</title>
</head>
<body onload="getVerify()">
<h1>点击图片切换验证码</h1><img id="img-verify" src="" alt="更换验证码" height="36" onclick="getVerify()">
</body>
<script>
  //获取验证码
  function getVerify(){
    document.getElementById("img-verify").src="/verify-code?"+Math.random();
  }
</script>
</html>

更多关于验证码的文章请点击查看: 《java验证码》

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍js随机生成一个验证码,包括了js随机生成一个验证码的使用技巧和注意事项,需要的朋友参考一下 之前接触过的验证码都是图片,今天碰到了一个用js生成随机验证码的demo,拿来敲一敲和大家分享。 效果: html代码: 给div设置了一个click点击事件,js代码如下: 定义一个变量,令它的值为26个字母和0-9十个数字。 Math.random()是令系统随机选取大于等于 0.0 且

  • 本文向大家介绍C#生成随机验证码代码分享,包括了C#生成随机验证码代码分享的使用技巧和注意事项,需要的朋友参考一下 使用YZMHelper帮助类即可 使用例子

  • 本文向大家介绍python生成随机图形验证码详解,包括了python生成随机图形验证码详解的使用技巧和注意事项,需要的朋友参考一下 使用python生成随机图片验证码,需要使用pillow模块 1.安装pillow模块 2.pillow模块的基本使用 1.创建图片 运行程序,程序会在py文件的同级下生成一个名为"pic.png"的小图片,图片长为400px,宽为400px,颜色为白色. 2.创建画

  • 问题内容: 在java中如何生成随机数? 问题答案: 在Java 1.7或更高版本中,执行此操作的标准方法如下: 请参阅相关的JavaDoc。这种方法的优点是不需要显式初始化java.util.Random实例,如果使用不当,可能会引起混乱和错误。 但是,相反,没有办法明确设置种子,因此在有用的情况下(例如测试或保存游戏状态或类似情况),很难重现结果。在这种情况下,可以使用下面显示的Java 1.

  • 每当我看到这行代码 后面总是有一个很长的序列号..这个数字是如何产生的?如果我想随机生成这个值,我该怎么做呢?谢谢你的帮助。

  • 本文向大家介绍JavaScript 随机验证码的生成实例代码,包括了JavaScript 随机验证码的生成实例代码的使用技巧和注意事项,需要的朋友参考一下 随机验证码的生成 1: 主体部分 接下来时如何放入到验证框里面了 <input type="text"  id="checkCode" class="unchanged" style="width: 80px"  readonly/>    接