Lorsque nous nous connectons et utilisons le code de vérification dans le projet, autant essayer Kaptcha pour générer le code de vérification, c'est très simple
1 Tout d'abord, nous introduisons la dépendance maven de kaptcha dans le pom.xml. file
<!-- kaptcha验证码 --> <dependency> <groupId>com.github.penggle</groupId> <artifactId>kaptcha</artifactId> <version>2.3.2</version> </dependency>
2. Ensuite, nous écrivons la classe de configuration de kaptcha : KaptchaConfig.java
package com.lzzy.meet.common.kaptcha; import com.google.code.kaptcha.impl.DefaultKaptcha; import com.google.code.kaptcha.util.Config; import lombok.extern.slf4j.Slf4j; import org.springframework.context.annotation.Bean; import org.springframework.stereotype.Component; import java.util.Properties; /** * @ClassName KaptchaConfig * kaptcha配置类 * @Author * @Date 2019-09-05 13:50:50 * @Version 1.0 **/ @Slf4j @Component public class KaptchaConfig { @Bean public DefaultKaptcha getKaptcheCode() { DefaultKaptcha defaultKaptcha = new DefaultKaptcha(); Properties properties = new Properties(); properties.setProperty("kaptcha.border", "no"); properties.setProperty("kaptcha.textproducer.font.color", "black"); properties.setProperty("kaptcha.image.width", "100"); properties.setProperty("kaptcha.image.height", "36"); properties.setProperty("kaptcha.textproducer.font.size", "30"); properties.setProperty("kaptcha.obscurificator.impl", "com.google.code.kaptcha.impl.ShadowGimpy"); properties.setProperty("kaptcha.session.key", "code"); properties.setProperty("kaptcha.noise.impl", "com.google.code.kaptcha.impl.NoNoise"); properties.setProperty("kaptcha.background.clear.from", "232,240,254"); properties.setProperty("kaptcha.background.clear.to", "232,240,254"); properties.setProperty("kaptcha.textproducer.char.length", "4"); properties.setProperty("kaptcha.textproducer.font.names", "彩云,宋体,楷体,微软雅黑"); Config config = new Config(properties); defaultKaptcha.setConfig(config); return defaultKaptcha; } }
3 Ensuite, nous écrivons la couche de contrôle de kaptcha : KaptchaController.java
package com.lzzy.meet.common.kaptcha; import com.google.code.kaptcha.Constants; import com.google.code.kaptcha.Producer; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import javax.imageio.ImageIO; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.awt.image.BufferedImage; /** * @ClassName KaptchaController * kaptcha调用 * @Author * @Date 2019-09-05 13:59:59 * @Version 1.0 **/ @Slf4j @Controller @RequestMapping("kaptcha") public class KaptchaController { @Autowired private Producer producer; @GetMapping("kaptcha-image") public void getKaptchaImage(HttpServletRequest request, HttpServletResponse response) throws Exception { 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 capText = producer.createText(); log.info("******************当前验证码为:{}******************", capText); // 将验证码存于session中 request.getSession().setAttribute(Constants.KAPTCHA_SESSION_KEY, capText); BufferedImage bi = producer.createImage(capText); ServletOutputStream out = response.getOutputStream(); // 向页面输出验证码 ImageIO.write(bi, "jpg", out); try { // 清空缓存区 out.flush(); } finally { // 关闭输出流 out.close(); } } }
4. le frontal pour générer le code de vérification :
<img th:src="@{/kaptcha/kaptcha-image}" class="ver_btn" onclick="this.src=this.src+'?c='+Math.random();"/ alt="Comment SpringBoot utilise Kaptcha pour implémenter les fonctions de génération de code de vérification et de vérification" >
Puisque j'utilise ici le moteur de modèle thymeleaf, le nom du chemin sera un peu étrange. Le style du code de vérification généré est celui indiqué dans la figure :
5. Enfin, nous saisirons le code de vérification saisi par l'utilisateur lors de sa connexion sur le client. Envoyer au serveur pour vérification :
/** * 验证验证码 * @param * @return 正确:true/错误:false */ public static boolean validate(String registerCode) { // 获取Session中验证码 Object captcha = ServletUtils.getAttribute(Constants.KAPTCHA_SESSION_KEY); // 判断验证码是否为空 if (StringUtils.isEmpty(registerCode)) { return false; } // 校验验证码的正确与否 boolean result = registerCode.equalsIgnoreCase(captcha.toString()); if (result) { // 正确了后,将验证码从session中删掉 ServletUtils.getRequest().getSession().removeAttribute(Constants.KAPTCHA_SESSION_KEY); } // 返回验证结果 return result; }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!