像这种很多if else的判断可以怎么优化?用什么设计模式?

VerifyCode lastVerifyCode = toBo(getRepo().getLatelyCode(mobile, type));
if (lastVerifyCode == null) {
logger.error("记录不存在,手机号: {},验证码: {}", mobile, verifyCode);
return false;

    } else if (null != lastVerifyCode.getVerifyDate()) {
        logger.error("验证码已校验,手机号: {},验证码: {}", mobile, verifyCode);
        return false;

    } else if (lastVerifyCode.getVerifyCount() >= VerifyCodeConfig.getCheckCount()) {
        logger.error("校验次数超过3次,手机号: {},验证码: {}", mobile, verifyCode);
        return false;

    } else if (!verifyCode.equals(lastVerifyCode.getVerifyCode())) {
        logger.error("验证码错误,手机号: {},验证码: {}", mobile, verifyCode);
        lastVerifyCode.setVerifyCount(lastVerifyCode.getVerifyCount() + 1);
        update(lastVerifyCode);
        return false;

    } else if (DateUtil.compare(DateUtil.offsetMinute(lastVerifyCode.getCreateDate(), VerifyCodeConfig.getPeriodOfValidity()), DateUtil.date()) < 0) {
        logger.error("验证码已失效,手机号: {},验证码: {}", mobile, verifyCode);
        return false;

    } else {
        lastVerifyCode.setVerifyCount(lastVerifyCode.getVerifyCount() + 1);
        lastVerifyCode.setVerifyDate(DateUtil.date());
        update(lastVerifyCode);
        return true;
    }

过滤器,职责链,装饰器等等

在if else相对较多的时候可以尝试使用策略模式

这有什么课优化的,用再多的方式底层也还是IF ELSE。就是代码美观问题。唯一可能优化的是你判断的条件是否重复判断

多重条件语句,如if...else语句、switch...case语句的,建议采用策略模式,具体可以看看下面这篇文章哦~