SpringBoot集成Kaptcha验证码
创始人
2024-06-03 08:44:51
0

目录

简介

实现步骤

1. 在 pom.xml 配置文件中,添加如下配置;由于国内限制了谷歌网络的访问,推荐使用下面的依赖下载

2. 在系统公共配置类中添加如下代码;当然关于 Kaptcha 的配置也可以添加到 application.properties 配置文件中

3. 在 KaptchController.class 中添加提供验证码生成的方法

4. 前端页面直接使用 img 标签引用即可

补充:Kaptcha 更多配置


简介

在开发中,验证码功能是一个常见且重要的功能,Kaptcha 是大名鼎鼎的谷歌公司提供的一款用于生成验证码的插件,支持高度可配置;本章将通过一个简单的示例展示如何实现验证码功能

实现步骤

1. 在 pom.xml 配置文件中,添加如下配置;由于国内限制了谷歌网络的访问,推荐使用下面的依赖下载

com.github.pengglekaptcha2.3.2

2. 在系统公共配置类中添加如下代码;当然关于 Kaptcha 的配置也可以添加到 application.properties 配置文件中

@Configuration
public class AppConfigure implements WebMvcConfigurer {/*** 验证码配置*/@Beanpublic DefaultKaptcha kaptcha() {DefaultKaptcha kaptcha = new DefaultKaptcha();Properties properties = new Properties();properties.put("kaptcha.border", "yes");properties.put("kaptcha.image.width", "100");properties.put("kaptcha.image.height", "33");properties.put("kaptcha.session.key", "code");properties.put("kaptcha.border.color", "105,179,90");properties.put("kaptcha.textproducer.font.size", "30");properties.put("kaptcha.textproducer.char.length", "4");properties.put("kaptcha.textproducer.font.color", "blue");properties.put("kaptcha.textproducer.font.names", "宋体,楷体,微软雅黑");kaptcha.setConfig(new Config(properties));return kaptcha;}
}

3. 在 KaptchController.class 中添加提供验证码生成的方法

@Controller
@RequestMapping("/kaptcha")
@Slf4j
public class KaptchaController {@Resourceprivate DefaultKaptcha kaptcha;/*** 申请验证码*/@GetMapping("/kaptcha")public void getKaptcha(HttpServletRequest request, HttpServletResponse response) {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");HttpSession session = request.getSession();ServletOutputStream outputStream = null;try {//生成验证码String kaptchaText = kaptcha.createText();// 将验证码保存 5 分钟CommonUtils.setSession(session, Properties.KAPTCHA.desc(), kaptchaText, Properties.EXPIRETIME_KAPTCHA.value());log.info("captcha code: " + kaptchaText);//向客户端输出BufferedImage bufferedImage = kaptcha.createImage(kaptchaText);outputStream = response.getOutputStream();ImageIO.write(bufferedImage, "jpg", outputStream);outputStream.flush();} catch (IOException e) {throw new BusinessException(ErrorCode.CLOSE_IO_EXCEPTION);} finally {CommonUtils.closeio(outputStream);}}......
}

4. 前端页面直接使用 img 标签引用即可

补充:Kaptcha 更多配置

属性(常量)描述默认值
kaptcha.border图片边框,合法值:yes , noyes
kaptcha.border.color边框颜色,合法值: r,g,b (and optional alpha) 或者 white,black,blue.black
kaptcha.border.thickness边框厚度,合法值:>01
kaptcha.image.width图片宽200
kaptcha.image.height图片高50
kaptcha.producer.impl图片实现类com.google.code.kaptcha.impl.DefaultKaptcha  
kaptcha.textproducer.impl文本实现类com.google.code.kaptcha.text.impl.DefaultTextCreator  
kaptcha.textproducer.char.string文本集合,验证码值从此集合中获取abcde2345678gfynmnpwx
kaptcha.textproducer.char.length验证码长度5
kaptcha.textproducer.font.names字体Arial, Courier
kaptcha.textproducer.font.size字体大小40px
kaptcha.textproducer.font.color字体颜色,合法值: r,g,b  或者 white,black,blue.black
kaptcha.textproducer.char.space文字间隔2
kaptcha.noise.impl干扰实现类com.google.code.kaptcha.impl.DefaultNoise
kaptcha.noise.color干扰颜色,合法值: r,g,b 或者 white,black,blue.black
kaptcha.obscurificator.impl图片样式: 水纹com.google.code.kaptcha.impl.WaterRipple 鱼眼com.google.code.kaptcha.impl.FishEyeGimpy 阴影com.google.code.kaptcha.impl.ShadowGimpycom.google.code.kaptcha.impl.WaterRipple
kaptcha.background.impl背景实现类com.google.code.kaptcha.impl.DefaultBackground
kaptcha.background.clear.from背景颜色渐变,开始颜色light grey
kaptcha.background.clear.to背景颜色渐变,结束颜色white
kaptcha.word.impl文字渲染器com.google.code.kaptcha.text.impl.DefaultWordRenderer  
kaptcha.session.keysession keyKAPTCHA_SESSION_KEY
kaptcha.session.datesession dateKAPTCHA_SESSION_DATE

相关内容

热门资讯

索纳塔安卓系统软件,智能驾驶体... 你有没有发现,现在的汽车越来越智能了?这不,最近我试驾了一辆搭载了索纳塔安卓系统软件的新车,简直让我...
车载安卓系统怎么重装,轻松恢复... 你那车载安卓系统是不是突然间就卡得跟蜗牛一样慢了?别急,今天就来手把手教你如何重装车载安卓系统,让你...
小米手机点击安卓系统,安卓系统... 你有没有发现,最近小米手机在市场上可是越来越火了?尤其是它搭载的安卓系统,简直让人爱不释手。今天,就...
安卓系统哪些公司开发,安卓系统... 你有没有想过,我们每天离不开的安卓系统,究竟是由哪些公司联手打造的?这背后可是有着不少有趣的故事呢!...
安卓系统显示网络错误,安卓系统... 最近是不是发现你的安卓手机屏幕上时不时地跳出“网络错误”的提示?别急,这可不是什么世界末日,只是小插...
索尼的原生安卓系统,极致流畅体... 你有没有想过,为什么索尼的智能手机总是那么特别?没错,就是那个拥有原生安卓系统的索尼!今天,就让我带...
安卓系统可以打印吗,开启移动打... 你有没有想过,你的安卓手机或者平板,除了打电话、刷微博、玩游戏,还能干点啥?没错,今天我要给你揭秘一...
安卓怎么调用系统拨号,Andr... 你是不是也和我一样,对安卓手机的系统功能充满了好奇?比如说,你知道怎么让你的安卓手机像打电话一样,直...
什么叫安卓双系统,一机多能的智... 你有没有想过,为什么你的手机可以同时运行两个操作系统呢?这就是我们今天要聊一聊的安卓双系统。想象一边...
安卓系统有哪些表情,轻松表达你... 你知道吗?安卓系统里的表情包那可真是五花八门,让人眼花缭乱。今天,就让我带你一起探索一下安卓系统里那...
安卓系统怎么下载树洞,安卓系统... 你有没有想过,在安卓手机上下载一个可以让你畅所欲言、分享心情的树洞应用呢?树洞,顾名思义,就是一个可...
山寨安卓导航升级系统,功能升级... 你有没有发现,手机导航越来越智能了?但是你知道吗,市面上那些看似高大上的安卓导航升级系统,其实有不少...
诺基亚原生安卓系统怎,创新与体... 你有没有想过,那个曾经风靡一时的诺基亚手机,竟然也玩起了原生安卓系统?没错,就是那个经典的“诺基亚”...
如果安卓系统换成ios,系统更... 想象如果安卓系统突然宣布:“咱们来个大的改变,把安卓换成iOS!”这得是多大的新闻啊!想象你的手机、...
安卓开发新手引导系统,掌握核心... 你刚踏入安卓开发的广阔天地,是不是有点晕头转向呢?别担心,今天我就要给你来一场新手引导大作战,让你从...
国外安卓操作系统,全球视角下的... 你知道吗?在手机的世界里,操作系统可是个大头戏呢!今天,咱们就来聊聊国外那些风头正劲的安卓操作系统,...
安卓17系统窗口调用,Andr... 你知道吗?最近安卓系统又出新花样了!安卓17系统窗口调用,这可是个大招啊!今天,我就要带你深入了解一...
苹果庄安卓通讯系统,通讯系统融... 你知道吗?在手机江湖里,有两个门派可是鼎鼎大名,一个是以苹果为首的iOS,另一个则是安卓阵营。今天,...
安卓系统10寸屏幕,功能与体验... 你有没有想过,拥有一台10寸屏幕的安卓系统设备,会是怎样的体验呢?想象小巧的机身,却拥有强大的功能,...
安卓刷入linux系统,轻松刷... 你有没有想过,你的安卓手机其实可以变身成一个强大的Linux工作站呢?没错,就是那个在服务器上大显神...