Java生成登录随机验证码

清疚 2022-03-28 10:00 413阅读 0赞

验证码工具类: VerifyUtil.java

  1. import java.awt.*;
  2. import java.awt.image.BufferedImage;
  3. import java.util.HashMap;
  4. import java.util.Map;
  5. import java.util.Random;
  6. public class VerifyUtil {
  7. // 验证码字符集
  8. private static final char[] CHARS = {
  9. '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
  10. 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
  11. 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
  12. 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
  13. 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};
  14. // 字符数量
  15. private static final int SIZE = 4;
  16. // 干扰线数量
  17. private static final int LINES = 5;
  18. // 宽度
  19. private static final int WIDTH = 80;
  20. // 高度
  21. private static final int HEIGHT = 40;
  22. // 字体大小
  23. private static final int FONT_SIZE = 30;
  24. /** * 生成随机验证码及图片 */
  25. public static Map<String, Object> createImage() {
  26. StringBuffer sb = new StringBuffer();
  27. // 1.创建空白图片
  28. BufferedImage image = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);
  29. // 2.获取图片画笔
  30. Graphics graphic = image.getGraphics();
  31. // 3.设置画笔颜色
  32. graphic.setColor(Color.LIGHT_GRAY);
  33. // 4.绘制矩形背景
  34. graphic.fillRect(0, 0, WIDTH, HEIGHT);
  35. // 5.画随机字符
  36. Random ran = new Random();
  37. for (int i = 0; i < SIZE; i++) {
  38. // 取随机字符索引
  39. int n = ran.nextInt(CHARS.length);
  40. // 设置随机颜色
  41. graphic.setColor(getRandomColor());
  42. // 设置字体大小
  43. graphic.setFont(new Font(null, Font.BOLD + Font.ITALIC, FONT_SIZE));
  44. // 画字符
  45. graphic.drawString(CHARS[n] + "", i * WIDTH / SIZE, HEIGHT * 2 / 3);
  46. // 记录字符
  47. sb.append(CHARS[n]);
  48. }
  49. // 6.画干扰线
  50. for (int i = 0; i < LINES; i++) {
  51. // 设置随机颜色
  52. graphic.setColor(getRandomColor());
  53. // 随机画线
  54. graphic.drawLine(ran.nextInt(WIDTH), ran.nextInt(HEIGHT), ran.nextInt(WIDTH), ran.nextInt(HEIGHT));
  55. }
  56. // 7.返回验证码和图片
  57. Map<String, Object> map = new HashMap<>();
  58. //验证码
  59. map.put("code", sb.toString());
  60. //图片
  61. map.put("image", image);
  62. return map;
  63. }
  64. /** * 随机取色 */
  65. public static Color getRandomColor() {
  66. Random ran = new Random();
  67. return new Color(ran.nextInt(256), ran.nextInt(256), ran.nextInt(256));
  68. }
  69. }

获取验证码

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

页面

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

发表评论

表情:
评论列表 (有 0 条评论,413人围观)

还没有评论,来说两句吧...

相关阅读