spring aop 做请求日志

1.maven配置文件

<dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.8.10</version>
        </dependency>
        <dependency>
            <groupId>cglib</groupId>
            <artifactId>cglib</artifactId>
            <version>3.2.4</version>
        </dependency>
2.applicaiton.xml 配置
xmlns:aop="http://www.springframework.org/schema/aop"
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd

<aop:aspectj-autoproxy proxy-target-class="true"/>

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import com.welink.business.sys.SystemLogService;
import com.welink.business.sys.SystemSwitchService;
import com.welink.common.entity.sys.SystemLog;
import com.welink.core.vo.response.ComResponse;

@Aspect
@Component
public class LoginAspect {
	
	@Autowired
	private SystemLogService systemLogService;
	@Autowired
	private SystemSwitchService systemSwithService;
	
	@Around("execution (* com.welink.core.*.*.*(..))")
	private Object doAround(ProceedingJoinPoint pjp) throws Throwable {  
//        Object[] args = pjp.getArgs();//获得请求参数
        Long startTime=System.currentTimeMillis();
        //调用核心逻辑
        Object retVal = pjp.proceed();  
        if(retVal instanceof ComResponse){
        	String urlSwith=systemSwithService.getURLString();//需要记录日志的链接
        	HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); 
        	String ip=request.getRemoteAddr();//请求IP
        	HttpSession session = request.getSession();
        	String url = ((String)request.getAttribute("org.springframework.web.servlet.HandlerMapping.bestMatchingPattern")).split("/")[1];  //日志开关控制在模块
        	if(!StringUtils.isEmpty(urlSwith) && !StringUtils.isEmpty(url) && urlSwith.contains(url)){
        		url=((String)request.getAttribute("org.springframework.web.servlet.HandlerMapping.bestMatchingPattern")); //获得完整的URL
        		String username=(String)session.getAttribute("username");//获得登录用户名
        		Long duration=System.currentTimeMillis()-startTime;//请求总共花费多少毫 秒
        		if(pjp.getArgs().length>0){
        			systemLogService.insertLog(new SystemLog(ip, username, pjp.getArgs()[0].toString(), ((ComResponse)retVal).toString(), url, duration));
        		}
        	}
        }
        return retVal;  
    }  

}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值