若依的验证码改为漂亮的EasyCaptcha

281 阅读1分钟

一、 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;
}