From 5f1e5c8f4bf57072dae2006b8aa604fe4ef138ac Mon Sep 17 00:00:00 2001 From: kl <632104866@QQ.com> Date: Mon, 14 Aug 2023 13:20:33 +0800 Subject: [PATCH] =?UTF-8?q?=E9=87=8D=E6=9E=84=E9=AA=8C=E8=AF=81=E7=A0=81?= =?UTF-8?q?=E7=94=9F=E6=88=90=E6=96=B9=E6=B3=95=20(#481)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/cn/keking/utils/CaptchaUtil.java | 29 +++++-------------- .../main/java/cn/keking/utils/WebUtils.java | 13 +++++++++ .../keking/web/controller/FileController.java | 28 +++++++++--------- 3 files changed, 36 insertions(+), 34 deletions(-) diff --git a/server/src/main/java/cn/keking/utils/CaptchaUtil.java b/server/src/main/java/cn/keking/utils/CaptchaUtil.java index 168cbaba..0fe25262 100644 --- a/server/src/main/java/cn/keking/utils/CaptchaUtil.java +++ b/server/src/main/java/cn/keking/utils/CaptchaUtil.java @@ -1,18 +1,14 @@ package cn.keking.utils; -import com.aspose.cad.Tuple; -import org.springframework.util.ObjectUtils; +import org.springframework.util.Assert; import java.awt.*; import java.awt.image.BufferedImage; -import java.util.HashMap; -import java.util.Map; import java.util.Random; public class CaptchaUtil { public static final String captcha_code = "captchaCode"; - public static final String captcha_code_pic = "captchaCodePic"; public static final String captcha_generate_time = "captchaTime"; private static final int width = 100;// 定义图片的width @@ -25,11 +21,12 @@ public class CaptchaUtil { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'j', 'k', 'm', 'n', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', '2', '3', '4', '5', '6', '7', '8', '9'}; /** - * 指定验证码、或生成验证码。 - * @param captchaCode 指定验证码, 如果为 null,则生成验证码。否则,使用指定的验证码。 - * @return 验证码和验证码图片 + * 指定验证码、生成验证码图片。 + * @param captchaCode 验证码 + * @return 验证码图片 */ - public static Map generateCaptcha(String captchaCode) { + public static BufferedImage generateCaptchaPic(final String captchaCode) { + Assert.notNull(captchaCode, "captchaCode must not be null"); // 定义图像buffer BufferedImage buffImg = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); Graphics gd = buffImg.getGraphics(); @@ -54,11 +51,6 @@ public class CaptchaUtil { } // randomCode用于保存随机产生的验证码,以便用户登录后进行验证。 int red, green, blue; - - if (ObjectUtils.isEmpty(captchaCode)) { - captchaCode = generateCaptchaCode(); - } - // 产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同。 red = random.nextInt(255); green = random.nextInt(255); @@ -66,19 +58,14 @@ public class CaptchaUtil { // 用随机产生的颜色将验证码绘制到图像中。 gd.setColor(new Color(red, green, blue)); gd.drawString(captchaCode, 18, codeY); - - Map map = new HashMap<>(); - map.put(captcha_code, captchaCode); - //存放生成的验证码BufferedImage对象 - map.put(captcha_code_pic, buffImg); - return map; + return buffImg; } /** * 生成随机字符串。 * @return 字符串 */ - private static String generateCaptchaCode() { + public static String generateCaptchaCode() { Random random = new Random(); StringBuilder randomCode = new StringBuilder(); for (int i = 0; i < codeLength; i++) { diff --git a/server/src/main/java/cn/keking/utils/WebUtils.java b/server/src/main/java/cn/keking/utils/WebUtils.java index f888fbd5..347a81f0 100644 --- a/server/src/main/java/cn/keking/utils/WebUtils.java +++ b/server/src/main/java/cn/keking/utils/WebUtils.java @@ -293,6 +293,19 @@ public class WebUtils { return Long.parseLong(value); } + /** + * session 中设置属性 + * @param request 请求 + * @param key 属性名 + */ + public static void setSessionAttr(HttpServletRequest request, String key, Object value) { + HttpSession session = request.getSession(); + if (session == null) { + return; + } + session.setAttribute(key, value); + } + /** * 移除 session 中的属性 * @param request 请求 diff --git a/server/src/main/java/cn/keking/web/controller/FileController.java b/server/src/main/java/cn/keking/web/controller/FileController.java index 9f075be1..41330e7c 100644 --- a/server/src/main/java/cn/keking/web/controller/FileController.java +++ b/server/src/main/java/cn/keking/web/controller/FileController.java @@ -2,9 +2,9 @@ package cn.keking.web.controller; import cn.keking.config.ConfigConstants; import cn.keking.model.ReturnResponse; +import cn.keking.utils.CaptchaUtil; import cn.keking.utils.DateUtils; import cn.keking.utils.KkFileUtils; -import cn.keking.utils.CaptchaUtil; import cn.keking.utils.RarUtils; import cn.keking.utils.WebUtils; import org.slf4j.Logger; @@ -22,16 +22,21 @@ import javax.imageio.ImageIO; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; -import java.awt.image.RenderedImage; import java.io.File; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.nio.file.Files; import java.nio.file.Paths; -import java.util.*; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.Objects; -import static cn.keking.utils.CaptchaUtil.*; +import static cn.keking.utils.CaptchaUtil.captcha_code; +import static cn.keking.utils.CaptchaUtil.captcha_generate_time; /** * @author yudian-it @@ -104,22 +109,19 @@ public class FileController { long captchaGenerateTime = WebUtils.getLongSessionAttr(request, captcha_generate_time); long timeDifference = DateUtils.calculateCurrentTimeDifference(captchaGenerateTime); - Map codeMap; - // 验证码为空,且生成验证码超过50秒,重新生成验证码 if (timeDifference > 50 && ObjectUtils.isEmpty(captchaCode)) { - codeMap = CaptchaUtil.generateCaptcha(null); + captchaCode = CaptchaUtil.generateCaptchaCode(); // 更新验证码 - request.getSession().setAttribute(captcha_code, codeMap.get(captcha_code).toString()); - request.getSession().setAttribute(captcha_generate_time, DateUtils.getCurrentSecond()); + WebUtils.setSessionAttr(request, captcha_code, captchaCode); + WebUtils.setSessionAttr(request, captcha_generate_time, DateUtils.getCurrentSecond()); } else { captchaCode = ObjectUtils.isEmpty(captchaCode) ? "wait" : captchaCode; - codeMap = CaptchaUtil.generateCaptcha(captchaCode); } - ServletOutputStream sos = response.getOutputStream(); - ImageIO.write((RenderedImage) codeMap.get(captcha_code_pic), "jpeg", sos); - sos.close(); + ServletOutputStream outputStream = response.getOutputStream(); + ImageIO.write(CaptchaUtil.generateCaptchaPic(captchaCode), "jpeg", outputStream); + outputStream.close(); } @GetMapping("/listFiles")