三分鐘帶你掌握Java開發(fā)圖片驗證碼功能方法
基本流程
細分一共有7步。
- 生成驗證碼:可以使用圖形庫生成一張隨機驗證碼圖片,然后將圖片存儲在服務器端。或者編碼為base64方便傳輸。這里可以參考我的一篇文章,里面詳細講解了如何生成一張合格的驗證碼。
- 緩存驗證碼:驗證碼需要緩存在后端方便下次查詢。
- 返回驗證碼:將驗證碼和驗證碼唯一標識返回到前端。
- 展示驗證碼:將驗證碼圖片顯示在登錄頁面:在登錄頁面中顯示驗證碼圖片,并請用戶輸入驗證碼。
- 用戶登錄:獲取用戶輸入:當用戶提交登錄表單時,獲取用戶輸入的驗證碼并與服務器端存儲的驗證碼通過進行比對。
- 驗證驗證碼:使用某種算法(如字符串比對),根據(jù)唯一標識對云端存儲的驗證碼和用戶輸入的驗證碼進行比對。
- 刪除驗證碼:使用一次立即刪除。
前端請求驗證碼
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); // 轉換流信息寫出 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); // 轉碼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 唯一標識 * @return 結果 */ 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); }
總結
這是一個簡單的登錄驗證碼實現(xiàn)流程,具體實現(xiàn)可能因技術棧和需求而有所不同。但是流程基本上都是相同的。
到此這篇關于三分鐘帶你掌握Java開發(fā)圖片驗證碼功能方法的文章就介紹到這了,更多相關Java圖片驗證碼內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Springboot整合MongoDB進行CRUD操作的兩種方式(實例代碼詳解)
這篇文章主要介紹了Springboot整合MongoDB進行CRUD操作的兩種方式,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04RabbitMQ,RocketMQ,Kafka?事務性,消息丟失,消息順序性和消息重復發(fā)送的處理策略問題
這篇文章主要介紹了RabbitMQ,RocketMQ,Kafka?事務性,消息丟失,消息順序性和消息重復發(fā)送的處理策略,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03Java框架篇:Spring+SpringMVC+hibernate整合開發(fā)
本篇文章將會對Spring+SpringMVC+hibernate的整合開發(fā)進行介紹。具有很好的參考價值。下面跟著小編一起來看下吧2017-02-02