Spring Boot 驗證碼框架 CAPTCHA詳解
查看 Github 倉庫 | 查看 Gitee 倉庫
簡介人機識別與驗證碼是后端開發(fā)中保護(hù)接口最常見的方式之一,而此類代碼往往會與業(yè)務(wù)代碼耦合帶來項目可維護(hù)性變差。
CAPTCHA 是一個基于 Spring Boot 的驗證碼框架,它通過 AOP 的方式完成包含驗證碼生成、發(fā)送、存儲等驗證碼相關(guān)業(yè)務(wù),以避免與業(yè)務(wù)代碼耦合。開發(fā)者可以輕松地通過不同組件的組合來完成驗證業(yè)務(wù),同時可以進(jìn)行自定義實現(xiàn)以應(yīng)對自身的業(yè)務(wù)需求(例如郵箱驗證碼、短信驗證碼)。
代碼示例導(dǎo)入 Maven 依賴
<dependency> <groupId>cn.dustlight.captcha</groupId> <artifactId>captcha-core</artifactId> <version>0.0.6</version></dependency>
添加注解啟用 CAPTCHA
@SpringBootApplication@EnableCaptcha // 啟用 CAPTCHApublic class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); }}
使用注解生產(chǎn)驗證碼
@RequestMapping('/captcha') @SendCode // 生成隨機字符圖像驗證碼并發(fā)送 public void captcha(@CodeValue String code) { // 在此處進(jìn)行自定義的業(yè)務(wù),驗證碼的生成、發(fā)送與儲存已由注解 ’@SendCode’ 完成。 log.info(code); }
使用注解消費驗證碼(保護(hù)接口)
@RequestMapping('/') @VerifyCode public String index(@CodeValue String code) { // 在此處進(jìn)行自定義的業(yè)務(wù),驗證碼的驗證以及銷毀已由注解 ’@VerifyCode’ 完成。 return String.format('Hello World! (%s)', code); }實現(xiàn)原理
CAPTCHA 基于面向切面編程(AOP)思想,將驗證碼業(yè)務(wù)劃分為兩個切面:
@SendCode
生成驗證碼 儲存驗證碼 發(fā)送驗證碼@VerifyCode
讀取驗證碼 進(jìn)行驗證同時將驗證碼業(yè)務(wù)抽象為下面幾個接口:
Code—— 驗證碼 CodeGenerator—— 生成器 CodeSender—— 發(fā)送器 CodeStore—— 儲存器 CodeVerifier—— 驗證器例子
隨機字符圖像驗證碼的 AOP 實現(xiàn)
業(yè)務(wù)分析
客戶端訪問驗證碼接口獲取到圖像,同時后端服務(wù)將生成的驗證碼儲存在 Session 或者 Redis。 客戶端訪問接口(登錄、注冊等),傳入?yún)?shù)以及驗證碼,后端服務(wù)取出驗證碼進(jìn)行校驗。模塊劃分
業(yè)務(wù)邏輯
@SendCode
通過 CodeGenerator生成 Code。 通過 CodeStore儲存 Code。 通過 CodeSender輸出 Code。 執(zhí)行業(yè)務(wù)代碼。@VerifyCode
從請求參數(shù)獲取待驗證的驗證碼。 通過 CodeStore取出 Code。 通過 CodeVerify進(jìn)行驗證。 驗證完成則執(zhí)行業(yè)務(wù)代碼,否則拋出異常。拓展與組合除了圖像驗證碼(人機識別)以外,常見的驗證碼業(yè)務(wù)或者人機識別業(yè)務(wù)例如:短信驗證碼、郵箱驗證碼、谷歌 reCAPTCHA 人機識別等都可以通過實現(xiàn)上述接口來完成業(yè)務(wù)。
例如,想要使用 Redis 儲存驗證碼只需要通過 RedisTemplate實現(xiàn) CodeStore即可,再通過模塊的組合使用可以輕易地完成自定義的驗證碼業(yè)務(wù),同時又不影響業(yè)務(wù)代碼。
到此這篇關(guān)于Spring Boot 驗證碼框架 - CAPTCHA的文章就介紹到這了,更多相關(guān)Spring Boot 驗證碼框架內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. XML在語音合成中的應(yīng)用2. jscript與vbscript 操作XML元素屬性的代碼3. 不要在HTML中濫用div4. HTML5實戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)5. .NET Framework各版本(.NET2.0 3.0 3.5 4.0)區(qū)別6. ASP基礎(chǔ)入門第四篇(腳本變量、函數(shù)、過程和條件語句)7. ASP將數(shù)字轉(zhuǎn)中文數(shù)字(大寫金額)的函數(shù)8. XML入門的常見問題(三)9. php使用正則驗證密碼字段的復(fù)雜強度原理詳細(xì)講解 原創(chuàng)10. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))
