SpringBoot前后端分離實現(xiàn)驗證碼操作
1.SpringBoot版本
本文基于的Spring Boot的版本是2.6.7 。
2.引入依賴
captcha一款超簡單的驗證碼生成,還挺好玩的.還有中文驗證碼,動態(tài)驗證碼. 。在項目中pom.xml配置文件中添加依賴,如下:
<!--驗證碼-->
<dependency>
<groupId>com.github.whvcse</groupId>
<artifactId>easy-captcha</artifactId>
<version>1.6.2</version>
</dependency>
3.實現(xiàn)思路
把生成的驗證碼結(jié)果保存到redis緩存中,并設(shè)置過期時間。
前端通過提交驗證碼和key,其中key就是保存到redis中的鍵,通過這個鍵獲取到對應(yīng)的值,再與前端提交的值對比,相同就通過驗證。
新建驗證碼枚舉類
由于captcha這款驗證碼提供了好幾種驗證碼方法,有中文驗證碼,動態(tài)驗證碼,算術(shù)驗證碼等等,新建一個驗證碼每周類存放這幾種驗證碼類型。代碼如下:
public enum LoginCodeEnum {
/**
* 算數(shù)
*/
ARITHMETIC,
/**
* 中文
*/
CHINESE,
/**
* 中文閃圖
*/
CHINESE_GIF,
/**
* 閃圖
*/
GIF,
SPEC
}定義驗證碼配置信息
該類是定義驗證碼的基本信息,例如高度、寬度、字體類型、驗證碼類型等等、并且我們把它轉(zhuǎn)成通過SpringBoot配置文件類型來定義更加方便。
@Data
public class LoginCode {
/**
* 驗證碼配置
*/
private LoginCodeEnum codeType;
/**
* 驗證碼有效期 分鐘
*/
private Long expiration = 2L;
/**
* 驗證碼內(nèi)容長度
*/
private int length = 2;
/**
* 驗證碼寬度
*/
private int width = 111;
/**
* 驗證碼高度
*/
private int height = 36;
/**
* 驗證碼字體
*/
private String fontName;
/**
* 字體大小
*/
private int fontSize = 25;
/**
* 驗證碼前綴
* @return
*/
private String codeKey;
public LoginCodeEnum getCodeType() {
return codeType;
}
}把配置文件轉(zhuǎn)換Pojo類的統(tǒng)一配置類
@Configuration
public class ConfigBeanConfiguration {
@Bean
@ConfigurationProperties(prefix = "login")
public LoginProperties loginProperties() {
return new LoginProperties();
}
}定義驗證邏輯生成類
@Data
public class LoginProperties {
private LoginCode loginCode;
/**
* 獲取驗證碼生產(chǎn)類
* @return
*/
public Captcha getCaptcha(){
if(Objects.isNull(loginCode)){
loginCode = new LoginCode();
if(Objects.isNull(loginCode.getCodeType())){
loginCode.setCodeType(LoginCodeEnum.ARITHMETIC);
}
}
return switchCaptcha(loginCode);
}
/**
* 依據(jù)配置信息生產(chǎn)驗證碼
* @param loginCode
* @return
*/
private Captcha switchCaptcha(LoginCode loginCode){
Captcha captcha = null;
synchronized (this){
switch (loginCode.getCodeType()){
case ARITHMETIC:
captcha = new FixedArithmeticCaptcha(loginCode.getWidth(),loginCode.getHeight());
captcha.setLen(loginCode.getLength());
break;
case CHINESE:
captcha = new ChineseCaptcha(loginCode.getWidth(),loginCode.getHeight());
captcha.setLen(loginCode.getLength());
break;
case CHINESE_GIF:
captcha = new ChineseGifCaptcha(loginCode.getWidth(),loginCode.getHeight());
captcha.setLen(loginCode.getLength());
break;
case GIF:
captcha = new GifCaptcha(loginCode.getWidth(),loginCode.getHeight());
captcha.setLen(loginCode.getLength());
break;
case SPEC:
captcha = new SpecCaptcha(loginCode.getWidth(),loginCode.getHeight());
captcha.setLen(loginCode.getLength());
default:
System.out.println("驗證碼配置信息錯誤!正確配置查看 LoginCodeEnum ");
}
}
if(StringUtils.isNotBlank(loginCode.getFontName())){
captcha.setFont(new Font(loginCode.getFontName(),Font.PLAIN,loginCode.getFontSize()));
}
return captcha;
}
static class FixedArithmeticCaptcha extends ArithmeticCaptcha{
public FixedArithmeticCaptcha(int width,int height){
super(width,height);
}
@Override
protected char[] alphas() {
// 生成隨機數(shù)字和運算符
int n1 = num(1, 10), n2 = num(1, 10);
int opt = num(3);
// 計算結(jié)果
int res = new int[]{n1 + n2, n1 - n2, n1 * n2}[opt];
// 轉(zhuǎn)換為字符運算符
char optChar = "+-x".charAt(opt);
this.setArithmeticString(String.format("%s%c%s=?", n1, optChar, n2));
this.chars = String.valueOf(res);
return chars.toCharArray();
}
}
}在控制層上定義驗證碼生成接口
@ApiOperation(value = "獲取驗證碼", notes = "獲取驗證碼")
@GetMapping("/code")
public Object getCode(){
Captcha captcha = loginProperties.getCaptcha();
String uuid = "code-key-"+IdUtil.simpleUUID();
//當驗證碼類型為 arithmetic時且長度 >= 2 時,captcha.text()的結(jié)果有幾率為浮點型
String captchaValue = captcha.text();
if(captcha.getCharType()-1 == LoginCodeEnum.ARITHMETIC.ordinal() && captchaValue.contains(".")){
captchaValue = captchaValue.split("\\.")[0];
}
// 保存
redisUtils.set(uuid,captchaValue,loginProperties.getLoginCode().getExpiration(), TimeUnit.MINUTES);
// 驗證碼信息
Map<String,Object> imgResult = new HashMap<String,Object>(2){{
put("img",captcha.toBase64());
put("uuid",uuid);
}};
return imgResult;
}效果體驗

在前端調(diào)用接口
<template>
<div class="login-code">
<img :src="codeUrl" @click="getCode">
</div>
</template>
<script>
methods: {
getCode() {
getCodeImg().then(res => {
this.codeUrl = res.data.img
this.loginForm.uuid = res.data.uuid
})
},
}
created() {
// 獲取驗證碼
this.getCode()
},
</script>

到此這篇關(guān)于SpringBoot前后端分離實現(xiàn)驗證碼操作的文章就介紹到這了,更多相關(guān)SpringBoot驗證碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實現(xiàn)學(xué)生管理系統(tǒng)詳解流程
這篇文章主要為大家詳細介紹了如何利用Java語言實現(xiàn)學(xué)生管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-06-06
Java 獲取網(wǎng)絡(luò)302重定向URL的方法
在本篇文章里小編給大家整理的是關(guān)于Java 獲取網(wǎng)絡(luò)302重定向URL的方法以及相關(guān)知識點,有興趣的朋友們參考下。2019-08-08
Spring boot從安裝到交互功能實現(xiàn)零基礎(chǔ)全程詳解
這篇文章主要介紹了Spring boot從安裝到交互功能得實現(xiàn)全程詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07

