public void setEnd_time(Date end_time) {
this.end_time = end_time;
}
}
import lombok.Data;
import java.util.Date;
/**
-
项目名称:
-
类 名 称:TbLoggingSelect
-
类 描 述:TODO
-
创建时间:2020/6/11 19:30
-
创 建 人:heng
*/
@Data
public class TbLoggingSelect {
//id
private Integer id;//id
//类名
private String class_name;//类名
//方法名
private String method_name;//方法名
//参数
private String param;//参数
//访问的url
private String url;//访问的url
//操作人ip
private String ip;//操作人ip
//创建人id
private String create_user_id;//创建人id
//创建时间
private Date create_time;//创建时间
//执行开始时间
private Date state_time;//执行开始时间
//执行结束时间
private Date end_time;//执行结束时间
//耗时
private String long_time;//耗时
//请求方式GET、POST…
private String method;//请求方式GET、POST…
//操作模块描述
private String module_name;//操作模块描述 //操作模块描述
//返回值
private String return_value;//返回值
//当前操作的浏览器
private String browser;//当前操作的浏览器
//是否删除 0、未删除 1、删除
private Integer is_delete;//是否删除 0、未删除 1、删除
private String state;//操作模块描述
public Date getCreate_time() {
return create_time;
}
public void setCreate_time(Date create_time) {
this.create_time = create_time;
}
public Date getState_time() {
return state_time;
}
public void setState_time(Date state_time) {
this.state_time = state_time;
}
public Date getEnd_time() {
return end_time;
}
public void setEnd_time(Date end_time) {
this.end_time = end_time;
}
}
拦截器采集日志
id是用redis生成的小伙伴可以用别的
新增语句这里就不贴出来了
以下操作查询的放一个表
其他放一张表
package com.web.common.intercept;
import cn.hutool.core.date.DateUtil;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.web.common.controller.BaseController;
import com.web.entity.TbLogging;
import com.web.entity.TbLoggingSelect;
import nl.bitwalker.useragentutils.UserAgent;
import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
import redis.clients.jedis.Jedis;
import web.dao.hsdao.TbLoggingMapper;
import web.dao.hsdao.TbLoggingSelectMapper;
import web.util.JedisUtil;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.Date;
/**
-
@ClassName SginAop
-
@Description
-
@Author heng
-
@Date 2020/4/26 10:41
-
@Version 1.0
*/
public class LogInterceptor extends HandlerInterceptorAdapter {
private final String redisKey = “LOG:LOGGING_KEY”;
private final static Logger LOGGER = LoggerFactory.getLogger(LogInterceptor.class);
//请求开始时间标识
private static final String LOGGER_SEND_TIME = “_send_time”;
//请求日志实体标识
private static final String LOGGER_ENTITY = “_logger_entity”;
@Autowired
private TbLoggingSelectMapper tbLoggingSelectMapper;
@Autowired
private TbLoggingMapper tbLoggingMapper;
public Long incr(String key) {
Jedis jedis =JedisUtil.getJedis();
try {
return jedis.incr(key);
} finally {
if (null != jedis) {
jedis.close();
}
}
}
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
if (handler.getClass().isAssignableFrom(HandlerMethod.class)) {
try {
TbLogging tbLogging = new TbLogging();
Long start_long_time = System.currentTimeMillis();
tbLogging.setState_time(DateUtil.date(start_long_time));
//获取ip
tbLogging.setIp(getRemoteHost(request));
//获取控制器的名字
tbLogging.setClass_name(((HandlerMethod) handler).getBean().getClass().getName());
//获取方法名
tbLogging.setMethod_name(((HandlerMethod) handler).getMethod().getName());
//获取请求参数信息
String param = JSON.toJSONString(request.getParameterMap(),
SerializerFeature.DisableCircularReferenceDetect,
SerializerFeature.WriteMapNullValue);
tbLogging.setParam(param);
try {
tbLogging.setCreate_user_id(new BaseController().obtainLoginUserId(request));
}catch (Exception ex){
LOGGER.info(“拿到当前登录人失败”);
}
//请求方法
tbLogging.setMethod(request.getMethod());
//请求url到后端的url
tbLogging.setUrl(request.getRequestURI());
//浏览器
//获取浏览器信息
String ua = request.getHeader(“User-Agent”);
//转成UserAgent对象
UserAgent userAgent = UserAgent.parseUserAgentString(ua);
tbLogging.setBrowser(userAgent.toString());
//获取返回值
//tbLogging.setReturn_value(response.getWriter().toString());
//设置请求开始时间
request.setAttribute(LOGGER_SEND_TIME, start_long_time);
//设置请求实体到request内,方便afterCompletion方法调用
request.setAttribute(LOGGER_ENTITY, tbLogging);
} catch (Exception e) {
LOGGER.info(“日志添加失败”);
}
}
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
try {
String uri = request.getRequestURI();
String contextPath = request.getContextPath();
if (StringUtils.length(contextPath) > 0) {
contextPath = StringUtils.substring(uri, contextPath.length());
}
TbLogging tbLogging = (TbLogging) request.getAttribute(LOGGER_ENTITY);
//获取请求错误码
int status = response.getStatus();
//当前时间
long currentTime = System.currentTimeMillis();
//请求开始时间
long time = Long.valueOf(request.getAttribute(LOGGER_SEND_TIME).toString());
//获取本次请求日志实体
tbLogging.setState(status+“”);
//设置请求时间差
tbLogging.setLong_time((currentTime - time)+“”);
tbLogging.setEnd_time(DateUtil.date(currentTime));
tbLogging.setCreate_time(DateUtil.date(currentTime));
// Long longId = IdUtil.createSnowflake(1, 1).nextId();
Long longId = incr(redisKey);
tbLogging.setId(longId.intValue());
if(tbLogging.getClass_name().indexOf(“TbLoggingController”) == -1){
if (contextPath.indexOf(“search_”) == -1
&& !tbLogging.getMethod_name().startsWith(“search”)
&& !tbLogging.getMethod_name().startsWith(“get”)
&& !tbLogging.getMethod_name().startsWith(“query”)
&& !tbLogging.getMethod_name().startsWith(“find”)
&& !tbLogging.getMethod_name().startsWith(“select”)
&& !tbLogging.getMethod_name().equals(“index”)) {
//执行将日志写入数据库,可以根据实际需求进行保存
// sysLogRepo.save(sysLog);
tbLoggingMapper.insertTbLogging(tbLogging);
}else {
TbLoggingSelect select = new TbLoggingSelect();
//把tbLogging的值给select
BeanUtils.copyProperties(select,tbLogging);
tbLoggingSelectMapper.insertTbLoggingSelect(select);
}
}
}catch (Exception e){
LOGGER.info(“日志添加失败”);
}
}
public int difference(Date nowDate, String decrypted){
return Math.abs((int)(nowDate.getTime()-Long.valueOf(decrypted))/1000);
}
/**
-
@Title: getRemoteHost
-
@Description: 获取Ip地址
-
@return: String
-
@version V1.0
*/
public String getRemoteHost(HttpServletRequest request) {
String ip = request.getHeader(“x-forwarded-for”);
if (ip == null || ip.length() == 0 || “unknown”.equalsIgnoreCase(ip)) {
ip = request.getHeader(“Proxy-Client-IP”);
}
if (ip == null || ip.length() == 0 || “unknown”.equalsIgnoreCase(ip)) {
ip = request.getHeader(“WL-Proxy-Client-IP”);
}
if (ip == null || ip.length() == 0 || “unknown”.equalsIgnoreCase(ip)) {
ip = request.getHeader(“HTTP_CLIENT_IP”);
}
if (ip == null || ip.length() == 0 || “unknown”.equalsIgnoreCase(ip)) {
ip = request.getHeader(“HTTP_X_FORWARDED_FOR”);
}
if (ip == null || ip.length() == 0 || “unknown”.equalsIgnoreCase(ip)) {
ip = request.getRemoteAddr();
}
return ip.equals(“0:0:0:0:0:0:0:1”) ? “127.0.0.1” : ip;
}
}
以下操作用于查询
mapper.xml
/**
-
用于分表分页查询
-
@param map
-
@return
*/
List pageListTbLoggingSelectByObj(Map<String,Object> map);
int pageListTbLoggingSelectByObjCount(Map<String,Object> map);
SELECT
FROM tb_logging_select
is_delete = 0
AND date_format(create_time,‘%Y-%m-%d’) = #{create_time}
AND id > #{maxId}
AND id < #{minId}
order by id asc
order by id desc
order by id desc
LIMIT #{pageSize}
SELECT count(1)
FROM tb_logging_select
is_delete = 0
AND date_format(create_time,‘%Y-%m-%d’) = #{create_time}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
最后
小编精心为大家准备了一手资料
以上Java高级架构资料、源码、笔记、视频。Dubbo、Redis、设计模式、Netty、zookeeper、Spring cloud、分布式、高并发等架构技术
【附】架构书籍
- BAT面试的20道高频数据库问题解析
- Java面试宝典
- Netty实战
- 算法
BATJ面试要点及Java架构师进阶资料
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!**
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-UFGZY3cl-1712658686960)]
最后
小编精心为大家准备了一手资料
[外链图片转存中…(img-vERPCRIW-1712658686961)]
[外链图片转存中…(img-S6E5Xfh5-1712658686961)]
以上Java高级架构资料、源码、笔记、视频。Dubbo、Redis、设计模式、Netty、zookeeper、Spring cloud、分布式、高并发等架构技术
【附】架构书籍
- BAT面试的20道高频数据库问题解析
- Java面试宝典
- Netty实战
- 算法
[外链图片转存中…(img-U7YCp3p6-1712658686961)]
BATJ面试要点及Java架构师进阶资料
[外链图片转存中…(img-na2KNBbU-1712658686961)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-9A3i9L3e-1712658686962)]