当前位置: 首页 > 工具软件 > LogUtils > 使用案例 >

(开发工具)日志记录LogUtils编写

单于扬
2023-12-01

获取当前action,controller名,ip地址

package com.jeesite.modules.util;

import BP.Tools.DateUtils;
import com.jeesite.modules.entityk.JdbcTemplate;
import com.jeesite.modules.sys.utils.CompanyUtils;
import com.jeesite.modules.sys.utils.EmpUtils;
import com.jeesite.modules.sys.utils.UserUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Component;

import java.net.InetAddress;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * @description:
 * @author: yangkai
 * @date: 2019/12/26
 */
@Component
public class LogUtils {
    /**
     * saveLog 方法
     * 说明:日志保存
     * 创建人:yangkai
     * @param archtypeid:档案id
     * @param archlevel:档案类型(文件,案卷,项目,盒)
     * @param op:日志说明
     * @param id:详情id(文件id,案卷id,项目id,盒id)
     * @return void
     * @throws
     */
    public static void saveLog(String archtypeid,String archlevel,String op,String id)throws Exception{
        String queryName="";
        if("文件".equals(archlevel)){
            queryName="doctableid";
        }else if("案卷".equals(archlevel)){
            queryName="voltableid";
        }else if("项目".equals(archlevel)){
            queryName="projtableid";
        }else if("盒".equals(archlevel)){
            queryName="boxtableid";
        }else {

        }
        Map<String,Object> s_archive_type= JdbcTemplate.getJdbcTemplate("edoc").queryForMap("SELECT name,"+queryName+" FROM s_archive_type WHERE id="+archtypeid);
        String archtypename=String.valueOf(s_archive_type.get("name"));
        String tableid=String.valueOf(s_archive_type.get(queryName));

        Map<String,Object> temp= JdbcTemplate.getJdbcTemplate("edoc").queryForMap("SELECT status,archcode,title,security FROM "+tableid+" WHERE id="+id);

        List<String> values=new ArrayList<>();
        values.add(CompanyUtils.getCurrentFond().getId());
        values.add(IDUtil.getID());
        values.add(InetAddress.getLocalHost().getHostAddress());
        values.add(UserUtils.getUser().getUserCode());
        values.add(UserUtils.getUser().getUserName());
        values.add(EmpUtils.getOffice().getOfficeCode());
        values.add(EmpUtils.getOffice().getOfficeName());
        values.add(id);
        values.add(tableid);
        values.add(temp.get("status").toString());
        values.add(archtypeid);
        values.add(archtypename);
        values.add(archlevel);
        values.add(temp.get("archcode").toString());
        values.add(temp.get("title").toString());
        values.add(temp.get("security").toString());
        values.add(op);
        values.add(DateUtils.getCurrentDate());
        values.add(UserUtils.getUser().getUserCode());
        values.add("null");
        values.add("null");
        /**/
        String[] strings=StringUtils.split(Thread.currentThread().getStackTrace()[2].getClassName(),".");
        int num=strings.length;
        /**/
        values.add(strings[num-1]);
        values.add(Thread.currentThread().getStackTrace()[2].getMethodName());
        values.add("null");
        values.add(CompanyUtils.getCurrentFond().getId());

        for (int i = 0; i < values.size(); i++) {
            if("null".equals(values.get(i))){

            } else if(!StringUtils.isNumeric(values.get(i))){//判断参数是否是纯数字
                values.set(i,"'"+values.get(i)+"'");
            } else {

            }
        }
        System.out.println("INSERT INTO log_archive (fondsid,id,ip,userid,username,deptid,deptname,archid,tableid,status,archtypeid,archtypename,archlevel,archcode,archtitle,secret,op,optime,oper,special,opcount,controller,action,type,comid) " +
                "VALUES ("+ StringUtils.join(values,",") +")");
        JdbcTemplate.getJdbcTemplate("edoc").execute("INSERT INTO log_archive (fondsid,id,ip,userid,username,deptid,deptname,archid,tableid,status,archtypeid,archtypename,archlevel,archcode,archtitle,secret,op,optime,oper,special,opcount,controller,action,type,comid) " +
                "VALUES ("+ StringUtils.join(values,",") +")");
    }
}

 

 类似资料: