当前位置: 代码迷 >> 综合 >> (开发工具)日志记录LogUtils编写
  详细解决方案

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

热度:61   发布时间:2024-01-24 11:39:59.0

获取当前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,",") +")");}
}