若依框架深度学习
登錄模塊
驗(yàn)證碼
采用的base64加密處理,我們通過響應(yīng)結(jié)果查看驗(yàn)證碼圖片是我們需要加上
登錄模塊
驗(yàn)證碼
采用的base64加密處理,我們通過響應(yīng)結(jié)果查看驗(yàn)證碼圖片是我們需要加上
data:image/png;base64,才能看見效果,具體如下
驗(yàn)證碼實(shí)在后臺生成的,我們會(huì)驗(yàn)證碼的生成信息以及結(jié)果存儲到redis緩存中,在保存驗(yàn)證碼信息的時(shí)候,會(huì)給它加上一個(gè)uuid
/*** 驗(yàn)證碼 redis key*/public static final String CAPTCHA_CODE_KEY = "captcha_codes:"; // 保存驗(yàn)證碼信息String uuid = IdUtils.simpleUUID();String verifyKey = Constants.CAPTCHA_CODE_KEY + uuid;驗(yàn)證碼后臺生成并且存入redis
String capText = captchaProducerMath.createText();capStr = capText.substring(0, capText.lastIndexOf("@"));code = capText.substring(capText.lastIndexOf("@") + 1);redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);最后將生成的驗(yàn)證碼信息通過流傳給前端,并且進(jìn)行對圖片進(jìn)行了加密處理
FastByteArrayOutputStream os = new FastByteArrayOutputStream();try{ImageIO.write(image, "jpg", os);}catch (IOException e){return AjaxResult.error(e.getMessage());}ajax.put("uuid", uuid);ajax.put("img", Base64.encode(os.toByteArray()));驗(yàn)證碼生成之后,前臺會(huì)接收到一個(gè)圖片的信息和uuid,當(dāng)我們講用戶名和密碼填寫好了之后我們會(huì)根據(jù)uuidredis中找到鍵根然后獲取對應(yīng)的緩存中驗(yàn)證碼的值,進(jìn)行對比看看是否正確,具體流程圖如下:
具體的登錄邏輯的實(shí)現(xiàn)我們可以通過前端發(fā)起的請求地址找到,也可以看見前端傳過來的具體參數(shù)信息
參數(shù)信息
{username: "admin", password: "admin123", code: "3", uuid: "dcb06362103d4f3889ff171c95787779"} code: "3" password: "admin123" username: "admin" uuid: "dcb06362103d4f3889ff171c95787779"因?yàn)檫@個(gè)認(rèn)證部分是使用springSecurity來做的首先會(huì)通過authenticate該方法會(huì)去調(diào)用UserDetailsServiceImpl.loadUserByUsername,最后若依后臺重寫了loadUserByUsername這個(gè)方法,最后通過用戶名去數(shù)據(jù)庫中進(jìn)行查詢,并返回響應(yīng)結(jié)果
// 該方法會(huì)去調(diào)用UserDetailsServiceImpl.loadUserByUsernameauthentication = authenticationManager.authenticate(new UsernamePasswordAuthenticationToken(username, password));通過debug主要調(diào)用過程如下
最后若依框架重寫了UserDetailsService.loadUserByUsername()方法
通過用戶名查詢出來用戶,在通過我們傳入的密碼進(jìn)行比對,具體邏輯如下
protected void additionalAuthenticationChecks(UserDetails userDetails, UsernamePasswordAuthenticationToken authentication) throws AuthenticationException {if (authentication.getCredentials() == null) {this.logger.debug("Failed to authenticate since no credentials provided");throw new BadCredentialsException(this.messages.getMessage("AbstractUserDetailsAuthenticationProvider.badCredentials", "Bad credentials"));} else {String presentedPassword = authentication.getCredentials().toString();if (!this.passwordEncoder.matches(presentedPassword, userDetails.getPassword())) {this.logger.debug("Failed to authenticate since password does not match stored value");throw new BadCredentialsException(this.messages.getMessage("AbstractUserDetailsAuthenticationProvider.badCredentials", "Bad credentials"));}}}最后返回前端登錄信息成功與否的結(jié)果
總結(jié)
- 上一篇: JavaScrpt --- es5实现
- 下一篇: app开发人脸登录和指纹登录_易讯云通讯