Springboot项目中kaptcha验证码的使用方式
Springboot项目kaptcha验证码使用
引入依赖
<!--kaptcha--> <dependency> <groupId>com.baomidou</groupId> <artifactId>kaptcha-spring-boot-starter</artifactId> <version>1.1.0</version> </dependency>
添加配置
#验证码 kaptcha: content: #源字符 source: wjl
验证码生成
package com.example.security.security; import com.google.code.kaptcha.Producer; import org.apache.commons.codec.binary.Base64; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.util.FastByteArrayOutputStream; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; import javax.imageio.ImageIO; import javax.servlet.http.HttpSession; import java.awt.image.BufferedImage; import java.io.IOException; @RestController public class KaptchaController{ @Autowired private Producer producer; @GetMapping("/verify-code.png") public String getVerifyCode(HttpSession session) throws IOException{ //1.生成验证码 String kaptcha=producer.createText(); //验证码图片 BufferedImage bi=producer.createImage(kaptcha); //2.存入session session.setAttribute("kaptcha",kaptcha); //3.把验证码图片转换成base64然后返回,前端拿到后解码然后渲染即可成图片. FastByteArrayOutputStream fos=new FastByteArrayOutputStream(); ImageIO.write(bi,"png",fos); return Base64.encodeBase64String(fos.toByteArray()); } }
CAPTCHA是什么
CAPTCHA是"Completely Automated Public Turing test to tell Computers and Humans Apart"的缩写,中文通常译为“完全自动化的公共图灵测试以区分计算机和人类”。
CAPTCHA是一种安全性检测机制,旨在确定用户是人类还是自动化软件(俗称“机器人”或“bot”)。
它通过要求用户完成一个简单测试来实现这一目标,这个测试对大多数人类来说相对容易,但对计算机自动程序则困难重重。
CAPTCHA通常以图形验证码的形式出现,要求用户识别扭曲的文字、数字,或在一系列图像中识别特定的物体。
除了这些传统形式外,还有其他类型的CAPTCHA,例如:
- 音频CAPTCHA:为视觉障碍用户设计,播放一段含有数字或字母的音频,用户需要输入所听到的内容。
- 逻辑CAPTCHA:要求用户解决一个简单的数学问题或逻辑问题。
- 交互式CAPTCHA:例如拖放拼图,要求用户执行一个简单的鼠标操作来完成一个挑战。
CAPTCHA的主要目的是保护网站免受滥用和自动化攻击,如自动注册账户、垃圾邮件评论发布、密码猜测等。
通过确保只有人类用户可以通过测试,CAPTCHA有助于增加在线服务的安全性和可用性。
然而,随着人工智能和机器学习技术的发展,开发出能够解决复杂CAPTCHA的算法变得越来越容易,因此,设计更加复杂和创新的CAPTCHA方法成为了一项持续的挑战。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Java servlet 使用 PrintWriter 时的编码与乱码的示例代码
本篇文章主要介绍了Java servlet 使用 PrintWriter 时的编码与乱码的示例代码,探讨了 PrintWriter 的缺省编码与普通字符流的缺省编码的差异,具有一定的参考价值,有兴趣的可以了解一下2017-11-11为何修改equals方法时还要重写hashcode方法的原因分析
这篇文章主要介绍了为何修改equals方法时还要重写hashcode方法的原因分析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-06-06SpringBoot集成Spring Security的方法
Spring security,是一个强大的和高度可定制的身份验证和访问控制框架。这篇文章主要介绍了SpringBoot集成Spring Security的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-07-07SpringBoot Test 多线程报错的根本原因(dataSource already
在使用Springboot test进行相关测试的时候,发现开启线程操作数据库的时候异常,这篇文章主要介绍了SpringBoot Test 多线程报错:dataSource already closed的根本原因及解决方法,需要的朋友可以参考下2022-06-06
最新评论