若依源码学习3:BaseController通用数据处理

本文介绍BaseController类的实现细节,包括日志添加、日期格式自动转换、分页数据处理等功能,适用于前后端分离的项目。
首图

BaseController通用数据处理

总体框架:

import java.beans.PropertyEditorSupport;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.WebDataBinder;
import org.springframework.web.bind.annotation.InitBinder;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.domain.AjaxResult.Type;
import com.ruoyi.common.core.page.PageDomain;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.core.page.TableSupport;
import com.ruoyi.common.utils.DateUtils;
import com.ruoyi.common.utils.ServletUtils;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.utils.sql.SqlUtil;

public class BaseController
{
   
   
    1.1、添加日志
    1.2、将前台传递过来的日期格式的字符串,自动转化为Date类型
    1.3、设置请求分页数据
    1.4、响应数据分页
    1.5、获取request、response、session
    1.6、统一类型返回
    
}

1.1、添加日志

    // protected 修饰,子类能够直接使用
    protected final Logger logger = LoggerFactory.getLogger(this.getClass());

优点:使用指定类初始化日志对象,在日志输出的时候,可以打印出日志信息所在类

如:

Logger logger = LoggerFactory.getLogger(com.User.class);
logger.debug("日志信息");

​ 将会打印出: com.User: 日志信息

原理:

image-20210409142352079

日志级别由高到底是:fatal -> error -> warn -> info -> debug,低级别的会输出高级别的信息,高级别的不会输出低级别的信息,如等级设为Error的话,warn,info,debug的信息不会输出。

1.2、日期格式自动转换

    /**
    * 将前台传递过来的日期格式的字符串,自动转化为Date类型
    */
    @InitBinder
    public void initBinder(WebDataBinder binder)
    {
   
   
        // Date 类型转换
        binder.registerCustomEditor(Date.class, new PropertyEditorSupport(){
   
   
            @Override
            public void setAsText(String text)
            {
   
   
                setValue(DateUtils.parseDate(text));
            }
        });
    }
  • 由@InitBinder表示的方法,可以对WebDataBinder对象进行初始化。WebDataBinder是DataBinder的子类,用于完成由表单到JavaBean属性的绑定。
  • @InitBinder方法不能有返回值,它必须盛名为void。
  • @InitBinder方法的参数通常是WebDataBinder,@InitBinder可以对WebDataBinder进行初始化

1.3、设置分页数据

前端如果需要分页传递的数据固定

image-20210408215342504

1、新建分页数据

/**
 * 分页数据
 */
public class PageDomain
{
   
   
    /** 当前记录起始索引 */
    private Integer pageNum;

    /** 每页显示记录数 */
    private Integer pageSize;

    /** 排序列 */
    private String orderByColumn;

    /** 排序的方向desc或者asc */
    private String isAsc = "asc";

    public String getOrderBy()
    {
   
   
        if (StringUtils.isEmpty(orderByColumn))
        {
   
   
            return "";
        }
        return StringUtils.toUnderScoreCase(orderByColumn) + " " + isAsc;
    }
}

2、通过getParameter获取前端每次传过来的分页数据并封装为实体类

/**
 * 表格数据处理
 */
public class TableSupport
{
   
   
    /**
     * 封装分页对象
     */
    public static PageDomain getPageDomain()
    {
   
   
        PageDomain pageDomain = new PageDomain();
        pageDomain.setPageNum(ServletUtils.getParameterToInt(Constants.PAGE_NUM));
        pageDomain.setPageSize(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值