三分鐘帶你掌握J(rèn)ava開發(fā)圖片驗證碼功能方法
基本流程
細(xì)分一共有7步。
- 生成驗證碼:可以使用圖形庫生成一張隨機驗證碼圖片,然后將圖片存儲在服務(wù)器端?;蛘呔幋a為base64方便傳輸。這里可以參考我的一篇文章,里面詳細(xì)講解了如何生成一張合格的驗證碼。
- 緩存驗證碼:驗證碼需要緩存在后端方便下次查詢。
- 返回驗證碼:將驗證碼和驗證碼唯一標(biāo)識返回到前端。
- 展示驗證碼:將驗證碼圖片顯示在登錄頁面:在登錄頁面中顯示驗證碼圖片,并請用戶輸入驗證碼。
- 用戶登錄:獲取用戶輸入:當(dāng)用戶提交登錄表單時,獲取用戶輸入的驗證碼并與服務(wù)器端存儲的驗證碼通過進行比對。
- 驗證驗證碼:使用某種算法(如字符串比對),根據(jù)唯一標(biāo)識對云端存儲的驗證碼和用戶輸入的驗證碼進行比對。
- 刪除驗證碼:使用一次立即刪除。
前端請求驗證碼
uuid是重點,將會貫穿整個驗證碼的生命周期。后端會根據(jù)uuid找到真實驗證碼進行比對。
getCode() { getCodeImg().then(res => { this.codeUrl = "data:image/gif;base64," + res.img; this.loginForm.uuid = res.uuid; }); },
后端生成驗證碼
/** ● 生成驗證碼 */ @GetMapping("/captchaImage") public AjaxResult getCode(HttpServletResponse response) throws IOException{ // 生成驗證碼信息 String uuid = IdUtils.simpleUUID(); String verifyKey = Constants.CAPTCHA_CODE_KEY + uuid; String capStr = null; BufferedImage image = null; // 生成驗證碼 可以配置多種類型的驗證碼 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; }
登錄
帶上 驗證碼 和 uuid 一起登錄
password: "admin123" username: "admin" uuid: "66ae1f227bf245a8b6ec2e6c00fb6189" code: "1234"
登錄接口校驗
先校驗驗證碼,再校驗賬號密碼。
@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; }
/** * 登錄驗證 * * @param username 用戶名 * @param password 密碼 * @param code 驗證碼 * @param uuid 唯一標(biāo)識 * @return 結(jié)果 */ public String login(String username, String password, String code, String uuid) { String verifyKey = Constants.CAPTCHA_CODE_KEY + uuid; // 根據(jù)UUID 去redis取出正確的驗證碼====================================================== String captcha = redisCache.getCacheObject(verifyKey); redisCache.deleteObject(verifyKey); // 驗證redis的驗證碼和用戶輸入的驗證碼是否相等。 // 驗證賬號密碼 // 驗證錯誤就拋出異常 // 生成token return tokenService.createToken(loginUser); }
總結(jié)
這是一個簡單的登錄驗證碼實現(xiàn)流程,具體實現(xiàn)可能因技術(shù)棧和需求而有所不同。但是流程基本上都是相同的。
到此這篇關(guān)于三分鐘帶你掌握J(rèn)ava開發(fā)圖片驗證碼功能方法的文章就介紹到這了,更多相關(guān)Java圖片驗證碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Springboot整合MongoDB進行CRUD操作的兩種方式(實例代碼詳解)
這篇文章主要介紹了Springboot整合MongoDB進行CRUD操作的兩種方式,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04RabbitMQ,RocketMQ,Kafka?事務(wù)性,消息丟失,消息順序性和消息重復(fù)發(fā)送的處理策略問題
這篇文章主要介紹了RabbitMQ,RocketMQ,Kafka?事務(wù)性,消息丟失,消息順序性和消息重復(fù)發(fā)送的處理策略,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03詳解Mybatis內(nèi)的mapper方法為何不能重載
這篇文章主要介紹了詳解Mybatis內(nèi)的mapper方法為何不能重載,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12Java框架篇:Spring+SpringMVC+hibernate整合開發(fā)
本篇文章將會對Spring+SpringMVC+hibernate的整合開發(fā)進行介紹。具有很好的參考價值。下面跟著小編一起來看下吧2017-02-02mybatis定義sql語句標(biāo)簽之delete標(biāo)簽解析
這篇文章主要介紹了mybatis定義sql語句標(biāo)簽之delete標(biāo)簽解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03避免sql注入_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了避免sql注入,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08