一、 maven 的pom.xml中引入,即分别在若依工程的根pom.xml和ruoyi-admin的pom.xml中引入第三方的EasyCaptch包,例如:
工程根pom.xml中引入:
<!-- 自己加的验证码EasyCaptcha依赖 -->
<dependency>
<groupId>com.github.whvcse</groupId>
<artifactId>easy-captcha</artifactId>
<version>1.6.2</version>
</dependency>
ruoyi-admin的pom.xml中引入:
<!-- 自己加的验证码EasyCaptcha依赖 -->
<dependency>
<groupId>com.github.whvcse</groupId>
<artifactId>easy-captcha</artifactId>
</dependency>
二、改造 CatchaController.java文件为:
// 改造成为EasyCaptcha的验证码
@GetMapping("/captchaImage")
public AjaxResult getCode(HttpServletResponse response) throws IOException
{
AjaxResult ajax = AjaxResult.success();
boolean captchaEnabled = configService.selectCaptchaEnabled();
ajax.put("captchaEnabled", captchaEnabled);
if (!captchaEnabled)
{
return ajax;
}
// 保存验证码信息
String uuid = IdUtils.simpleUUID();
String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid;
// 生成验证码
Captcha captcha = null;
String captchaType = RuoYiConfig.getCaptchaType();
// 测试 captchaType = "char";
if ("math".equals(captchaType))
{
// 算术验证码
captcha = new ArithmeticCaptcha(115,42,2);
}
else if ("char".equals(captchaType))
{
// 字符验证码 静态png类型
captcha = new SpecCaptcha(115,42,4);
// 纯数字
captcha.setCharType(Captcha.TYPE_ONLY_NUMBER);
// 字符验证码 动态gif 图类型
// captcha = new GifCaptcha(115,42);
}
else if ("gif".equals(captchaType))
{
// 字符验证码 动态gif 图类型
captcha = new GifCaptcha(115,42, 4);
// 纯数字
captcha.setCharType(Captcha.TYPE_ONLY_NUMBER);
}
else if ("chinese".equals(captchaType)){
// 中文验证
captcha = new ChineseCaptcha(115,42,4);
}
// 验证码的值
String code = captcha.text();
redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);
ajax.put("uuid", uuid);
// base64的头部data:image/png;base64
// 若依的前端需要修改为 this.codeUrl = res.img;
// ajax.put("img", captcha.toBase64());
// 如果不想要base64的头部data:image/png;base64
// 若依的前端不需要改,还是 this.codeUrl = "data:image/gif;base64," + res.img;
ajax.put("img", captcha.toBase64("")); // 加一个空的参数即可
return ajax;
}