# tianai-captcha-springboot-starter **Repository Path**: martin_repository/tianai-captcha-springboot-starter ## Basic Information - **Project Name**: tianai-captcha-springboot-starter - **Description**: 滑块验证码的springboot快速启动器 - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 62 - **Created**: 2022-04-08 - **Last Updated**: 2022-04-08 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 这是 滑块验证码(tianai-captcha)的springboot启动类 ## [在线体验](https://www.tianai.cloud) ## 验证码demo移步 [tianai-captcha-demo](https://gitee.com/tianai/tianai-captcha-demo) ## 不说废话,直接上代码 ```xml cloud.tianai.captcha tianai-captcha-springboot-starter 1.2.7 ``` - 注解版风格 ```java // 只需要在需要验证的controller层加入 @Captcha 注解, // 并且接受的参数指定成CaptchaRequest即可自动进行校验 // 自己真实的参数可以写到 CaptchaRequest对象的泛型中 // 如果校验失败,会抛出CaptchaValidException异常 // 对校验失败的处理,可以使用sping的全局异常拦截CaptchaValidException异常进行处理 @Captcha @PostMapping("/login") public ApiResponse login(@RequestBody CaptchaRequest request) { // 进入这个方法就说明已经校验成功了 } ``` - 编码式风格 ```java import cloud.tianai.captcha.template.slider.validator.SliderCaptchaTrack; public class Test { @Autowired private SliderCaptchaApplication application; public void test() { // 生成滑块验证码 该方法会通过request获取浏览器内核是否是谷歌内核,如果是则返回webp类型的图片 否则返回jpeg+png类型的图片 // 也可以手动指定返回哪种类型的 只需要在request中提供 key为captcha-type的参数(可以放到参数中或者header中) , 值为 webp、jpeg-png // 来通过参数选择返回哪种类型的图片 CaptchaResponse res1 = application.generateSliderCaptcha(); // 也可以用编码判断返回哪种类型的图片, 返回webp类型的图片 res1 = application.generateSliderCaptcha(CaptchaImageType.WEBP); // 返回 底图是jpeg,滑块部分是png类型的图片 res1 = application.generateSliderCaptcha(CaptchaImageType.JPEG_PNG); // 其它扩展方法可以自己在源码中查看,都有详细注释 // 匹配验证码是否正确 // 该参数包含了滑动轨迹滑动时间等数据,用于校验滑块验证码。 由前端传入 SliderCaptchaTrack sliderCaptchaTrack = new SliderCaptchaTrack(); boolean match = application.matching(res1.getId(), sliderCaptchaTrack); } } ``` - 前端展示效果 ![](image/1.png) ![](image/2.png) - springboot配置文件说明 ```yaml # 滑块验证码配置, 详细请看 cloud.tianai.captcha.autoconfiguration.SliderCaptchaProperties 类 captcha: slider: # 如果项目中使用到了redis,滑块验证码会自动把验证码数据存到redis中, 这里配置redis的key的前缀,默认是captcha:slider prefix: |- captcha:slider # 验证码过期时间,默认是1分钟,单位毫秒, 可以根据自身业务进行调整 expire: 60000 # 使用加载系统自带的资源, 默认是true init-default-resource: false # 验证码会提前缓存一些生成好的验证数据, 默认是20 cacheSize: 20 # 因为缓存池会缓存 webp 和jpg+png 两种类型的图片, 所有这里可以配置webp生成的数量, 默认是 总缓存的70%(captcha.cacheSize*0.7) webp-cache-size: 16 # 缓存拉取失败后等待时间 默认是 5秒钟 wait-time: 5000 # 缓存检查间隔 默认是2秒钟 period: 2000 # 是否加入混淆滑块,默认不加入 obfuscate: false ``` - 该自动装配器可以自动选择redis做缓存还是缓存到本地,自动进行识别装配 - 本地缓存参考了本人写的 [expiring-map](https://gitee.com/tianai/expiring-map) (使用redis淘汰策略) 做过期处理, 有兴趣可以看一下 - 关于[tianai-captcha](https://gitee.com/tianai/tianai-captcha) - 扩展接口 - ResourceStore 资源存储器,负责存档图片资源和滑块模板 - SliderCaptchaResourceManager 资源调度器,负责随机取滑块模板和 背景资源 - SliderCaptchaTemplate 滑块验证码模板,核心接口,负责生成展示的滑块底图和 滑块图片 - SliderCaptchaValidator 滑块验证器,负责校验用户滑动的轨迹数据 校验用户滑动使用正确或者判断是否是机器人操作 - SliderCaptchaApplication 滑块应用程序,上面一些接口的组合和增强,比如负责把验证的数据存到缓存中,用户一般直接使用这个接口方便的生成滑块图片和校验数据 - 可以自定义这些接口的实现注入到spring中替换默认的实现 - qq群: 1021884609