三分鐘帶你掌握J(rèn)ava開發(fā)圖片驗(yàn)證碼功能方法
基本流程
細(xì)分一共有7步。
- 生成驗(yàn)證碼:可以使用圖形庫生成一張隨機(jī)驗(yàn)證碼圖片,然后將圖片存儲(chǔ)在服務(wù)器端?;蛘呔幋a為base64方便傳輸。這里可以參考我的一篇文章,里面詳細(xì)講解了如何生成一張合格的驗(yàn)證碼。
- 緩存驗(yàn)證碼:驗(yàn)證碼需要緩存在后端方便下次查詢。
- 返回驗(yàn)證碼:將驗(yàn)證碼和驗(yàn)證碼唯一標(biāo)識(shí)返回到前端。
- 展示驗(yàn)證碼:將驗(yàn)證碼圖片顯示在登錄頁面:在登錄頁面中顯示驗(yàn)證碼圖片,并請(qǐng)用戶輸入驗(yàn)證碼。
- 用戶登錄:獲取用戶輸入:當(dāng)用戶提交登錄表單時(shí),獲取用戶輸入的驗(yàn)證碼并與服務(wù)器端存儲(chǔ)的驗(yàn)證碼通過進(jìn)行比對(duì)。
- 驗(yàn)證驗(yàn)證碼:使用某種算法(如字符串比對(duì)),根據(jù)唯一標(biāo)識(shí)對(duì)云端存儲(chǔ)的驗(yàn)證碼和用戶輸入的驗(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)證碼 可以配置多種類型的驗(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)換流信息寫出
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 用戶名
* @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)證碼和用戶輸入的驗(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開發(fā)圖片驗(yàn)證碼功能方法的文章就介紹到這了,更多相關(guān)Java圖片驗(yàn)證碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Springboot整合MongoDB進(jìn)行CRUD操作的兩種方式(實(shí)例代碼詳解)
這篇文章主要介紹了Springboot整合MongoDB進(jìn)行CRUD操作的兩種方式,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
RabbitMQ,RocketMQ,Kafka?事務(wù)性,消息丟失,消息順序性和消息重復(fù)發(fā)送的處理策略問題
這篇文章主要介紹了RabbitMQ,RocketMQ,Kafka?事務(wù)性,消息丟失,消息順序性和消息重復(fù)發(fā)送的處理策略,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
詳解Mybatis內(nèi)的mapper方法為何不能重載
這篇文章主要介紹了詳解Mybatis內(nèi)的mapper方法為何不能重載,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
Java框架篇:Spring+SpringMVC+hibernate整合開發(fā)
本篇文章將會(huì)對(duì)Spring+SpringMVC+hibernate的整合開發(fā)進(jìn)行介紹。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-02-02
mybatis定義sql語句標(biāo)簽之delete標(biāo)簽解析
這篇文章主要介紹了mybatis定義sql語句標(biāo)簽之delete標(biāo)簽解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
避免sql注入_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了避免sql注入,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08

