三分鐘帶你掌握J(rèn)ava開(kāi)發(fā)圖片驗(yàn)證碼功能方法
基本流程
細(xì)分一共有7步。
- 生成驗(yàn)證碼:可以使用圖形庫(kù)生成一張隨機(jī)驗(yàn)證碼圖片,然后將圖片存儲(chǔ)在服務(wù)器端?;蛘呔幋a為base64方便傳輸。這里可以參考我的一篇文章,里面詳細(xì)講解了如何生成一張合格的驗(yàn)證碼。
- 緩存驗(yàn)證碼:驗(yàn)證碼需要緩存在后端方便下次查詢(xún)。
- 返回驗(yàn)證碼:將驗(yàn)證碼和驗(yàn)證碼唯一標(biāo)識(shí)返回到前端。
- 展示驗(yàn)證碼:將驗(yàn)證碼圖片顯示在登錄頁(yè)面:在登錄頁(yè)面中顯示驗(yàn)證碼圖片,并請(qǐng)用戶(hù)輸入驗(yàn)證碼。
- 用戶(hù)登錄:獲取用戶(hù)輸入:當(dāng)用戶(hù)提交登錄表單時(shí),獲取用戶(hù)輸入的驗(yàn)證碼并與服務(wù)器端存儲(chǔ)的驗(yàn)證碼通過(guò)進(jìn)行比對(duì)。
- 驗(yàn)證驗(yàn)證碼:使用某種算法(如字符串比對(duì)),根據(jù)唯一標(biāo)識(shí)對(duì)云端存儲(chǔ)的驗(yàn)證碼和用戶(hù)輸入的驗(yàn)證碼進(jìn)行比對(duì)。
- 刪除驗(yàn)證碼:使用一次立即刪除。
前端請(qǐng)求驗(yàn)證碼
uuid是重點(diǎn),將會(huì)貫穿整個(gè)驗(yàn)證碼的生命周期。后端會(huì)根據(jù)uuid找到真實(shí)驗(yàn)證碼進(jìn)行比對(duì)。
getCode() {
getCodeImg().then(res => {
this.codeUrl = "data:image/gif;base64," + res.img;
this.loginForm.uuid = res.uuid;
});
},后端生成驗(yàn)證碼
/**
● 生成驗(yàn)證碼
*/
@GetMapping("/captchaImage")
public AjaxResult getCode(HttpServletResponse response) throws IOException{
// 生成驗(yàn)證碼信息
String uuid = IdUtils.simpleUUID();
String verifyKey = Constants.CAPTCHA_CODE_KEY + uuid;
String capStr = null;
BufferedImage image = null;
// 生成驗(yàn)證碼 可以配置多種類(lèi)型的驗(yàn)證碼
if ("math".equals(captchaType)){
capStr = captchaProducerMath.createText();
image = captchaProducerMath.createImage(capText);
}
else if ("char".equals(captchaType)){
capStr = captchaProducer.createText();
image = captchaProducer.createImage(capStr);
}
// 存入redis
redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);
// 轉(zhuǎn)換流信息寫(xiě)出
FastByteArrayOutputStream os = new FastByteArrayOutputStream();
try{
ImageIO.write(image, "jpg", os);
}
catch (IOException e){
return AjaxResult.error(e.getMessage());
}
AjaxResult ajax = AjaxResult.success();
ajax.put("uuid", uuid);
// 轉(zhuǎn)碼base64
ajax.put("img", Base64.encode(os.toByteArray()));
return ajax;
} 登錄
帶上 驗(yàn)證碼 和 uuid 一起登錄
password: "admin123" username: "admin" uuid: "66ae1f227bf245a8b6ec2e6c00fb6189" code: "1234"
登錄接口校驗(yàn)
先校驗(yàn)驗(yàn)證碼,再校驗(yàn)賬號(hào)密碼。
@PostMapping("/login")
public AjaxResult login(@RequestBody LoginBody loginBody) {
AjaxResult ajax = AjaxResult.success();
String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
loginBody.getUuid());
ajax.put(Constants.TOKEN, token);
return ajax;
}/**
* 登錄驗(yàn)證
*
* @param username 用戶(hù)名
* @param password 密碼
* @param code 驗(yàn)證碼
* @param uuid 唯一標(biāo)識(shí)
* @return 結(jié)果
*/
public String login(String username, String password, String code, String uuid)
{
String verifyKey = Constants.CAPTCHA_CODE_KEY + uuid;
// 根據(jù)UUID 去redis取出正確的驗(yàn)證碼======================================================
String captcha = redisCache.getCacheObject(verifyKey);
redisCache.deleteObject(verifyKey);
// 驗(yàn)證redis的驗(yàn)證碼和用戶(hù)輸入的驗(yàn)證碼是否相等。
// 驗(yàn)證賬號(hào)密碼
// 驗(yàn)證錯(cuò)誤就拋出異常
// 生成token
return tokenService.createToken(loginUser);
}總結(jié)
這是一個(gè)簡(jiǎn)單的登錄驗(yàn)證碼實(shí)現(xiàn)流程,具體實(shí)現(xiàn)可能因技術(shù)棧和需求而有所不同。但是流程基本上都是相同的。
到此這篇關(guān)于三分鐘帶你掌握J(rèn)ava開(kāi)發(fā)圖片驗(yàn)證碼功能方法的文章就介紹到這了,更多相關(guān)Java圖片驗(yàn)證碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot @ConditionalOnMissingBean注解的作用詳解
這篇文章主要介紹了springboot @ConditionalOnMissingBean注解的作用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
SpringMVC學(xué)習(xí)之JSTL條件行為和遍歷行為詳解
這篇文章主要介紹了SpringMVC學(xué)習(xí)之JSTL條件行為和遍歷行為詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
selenium+java破解極驗(yàn)滑動(dòng)驗(yàn)證碼的示例代碼
本篇文章主要介紹了selenium+java破解極驗(yàn)滑動(dòng)驗(yàn)證碼的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
Java的Flowable工作流之加簽轉(zhuǎn)簽詳解
這篇文章主要介紹了Java的Flowable工作流之加簽轉(zhuǎn)簽詳解,Flowable是一個(gè)開(kāi)源的工作流引擎,它提供了一套強(qiáng)大的工具和功能,用于設(shè)計(jì)、執(zhí)行和管理各種類(lèi)型的工作流程,需要的朋友可以參考下2023-11-11
Java簡(jiǎn)單計(jì)算器的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了Java簡(jiǎn)單計(jì)算器的實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12
詳解Spring Boot Web項(xiàng)目之參數(shù)綁定
本篇文章主要介紹了詳解Spring Boot Web項(xiàng)目之參數(shù)綁定,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03

