统一记录日志

AlphaAspect
package com.nowcoder.community.aspect;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.springframework.stereotype.Component; //@Component
//@Aspect
public class AlphaAspect { @Pointcut("execution(* com.nowcoder.community.service.*.*(..))")
public void pointcut() { } @Before("pointcut()")
public void before() {
System.out.println("before");
} @After("pointcut()")
public void after() {
System.out.println("after");
} @AfterReturning("pointcut()")
public void afterRetuning() {
System.out.println("afterRetuning");
} @AfterThrowing("pointcut()")
public void afterThrowing() {
System.out.println("afterThrowing");
} @Around("pointcut()")
public Object around(ProceedingJoinPoint joinPoint) throws Throwable {
System.out.println("around before");
Object obj = joinPoint.proceed();
System.out.println("around after");
return obj;
} }


ServiceLogAspect

package com.nowcoder.community.aspect;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes; import javax.servlet.http.HttpServletRequest;
import java.text.SimpleDateFormat;
import java.util.Date; @Component
@Aspect
public class ServiceLogAspect { private static final Logger logger = LoggerFactory.getLogger(ServiceLogAspect.class); @Pointcut("execution(* com.nowcoder.community.service.*.*(..))")
public void pointcut() { } @Before("pointcut()")
public void before(JoinPoint joinPoint) {
// 用户[1.2.3.4],在[xxx],访问了[com.nowcoder.community.service.xxx()].
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
String ip = request.getRemoteHost();
String now = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
String target = joinPoint.getSignature().getDeclaringTypeName() + "." + joinPoint.getSignature().getName();
logger.info(String.format("用户[%s],在[%s],访问了[%s].", ip, now, target));
} }

  

  

最新文章

  1. 调用别人提供的WebService
  2. POJ 1236 Network of Schools(强连通分量/Tarjan缩点)
  3. 用Java计算某个日期100天后的日期
  4. 通过pycurl模块添加put和delete请求
  5. eclipse编辑器,怎么创建PHP和JAVA的工程项目?
  6. Mock, 让你的开发脱离接口
  7. windbg蓝屏调试
  8. Django REST framework+Vue 打造生鲜超市(十三)
  9. Java使用POI解析Excel表格
  10. sqlserver给用户配置存储过程查看权限
  11. 写给自己看的新手java-环境配置
  12. day1扩展作业
  13. 利用/dev/urandom文件创建随机数
  14. springboot拦截器中获取配置文件值
  15. CSS魔法(三)浮动、相对定位、绝对定位
  16. Mina.Net实现的UDP多路广播
  17. VS2010中visual assist x的一些问题
  18. ORM增删改查(django)
  19. HDU 1176 免费馅饼 (类似数字三角形的题,很经典,值得仔细理解的dp思维)
  20. Python小白学习之文件内建函数

热门文章

  1. 资源:HTML调色板
  2. The Different of Python 2.x and 3.x
  3. 1.3.9、通过权重 Weight匹配
  4. 结构型模式 -- 代理模式(静态代理&动态代理)
  5. IntelliJ idea -- 在WEB-INF下创建两个文件夹:classes 和 lib
  6. sshpass用法介绍
  7. 使用Nginx和uwsgi部署Flask项目
  8. C语言:FILE p和FILE *p
  9. ASP.NET C# 打包再修改aspx文件报错解决方案
  10. Java基础00-Java概述1