zoukankan      html  css  js  c++  java
  • springboot 实现 aop

    1. pom.xml 导入 springboot aop 依赖
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-aop</artifactId>
    </dependency>
    
    1. 创建 aspect,在 execution 参数中写上被切的类
    @Aspect
    @Component
    public class IndexAspect {
        private static final Logger logger = LoggerFactory.getLogger(IndexAspect.class);
    
    <span class="hljs-comment">// 公用的切点,该类下所有方法</span>
    <span class="hljs-meta">@Pointcut</span>(<span class="hljs-string">"execution(public * com.example.IndexController.*(..))"</span>)
    <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">log</span><span class="hljs-params">()</span> </span>{
        logger.info(<span class="hljs-string">"调用 log() "</span>);
    }
    
    <span class="hljs-comment">// 使用log函数定义的 execution,不执行log()方法</span>
    <span class="hljs-meta">@Before</span>(<span class="hljs-string">"log()"</span>)
    <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">doBefore</span><span class="hljs-params">(JoinPoint joinPoint)</span> </span>{
        logger.info(<span class="hljs-string">"调用 doBefore"</span>);
        ServletRequestAttributes attributes = (ServletRequestAttributes)RequestContextHolder.getRequestAttributes();
        logger.info(<span class="hljs-string">"获取 request"</span>);
        HttpServletRequest request = attributes.getRequest();
        logger.info(<span class="hljs-string">"获取 reponse"</span>);
        attributes.getResponse();
        logger.info(<span class="hljs-string">"获取 session"</span>);
        attributes.getRequest().getSession();
        logger.info(<span class="hljs-string">"获取 class:"</span> + joinPoint.getSignature().getDeclaringTypeName().toString());
        logger.info(<span class="hljs-string">"获取 args:"</span> + joinPoint.getArgs());
    }
    
    <span class="hljs-comment">// 获取返回值</span>
    <span class="hljs-meta">@AfterReturning</span>(pointcut = <span class="hljs-string">"log()"</span>, returning = <span class="hljs-string">"object"</span>)
    <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">doAfterReturning</span><span class="hljs-params">(Object object)</span> </span>{
        logger.info(<span class="hljs-string">"获取返回值"</span> + object.toString());
    }
    

    }

    1. 启动项目,查看控制台日志
    com.example.IndexAspect: 调用 doBefore
    com.example.IndexAspect: 获取 request
    com.example.IndexAspect: 获取 reponse
    com.example.IndexAspect: 获取 session
    com.example.IndexAspect: 获取 class:com.example.thymeleaf.IndexController
    com.example.IndexAspect: 获取 args:
    com.example.IndexAspect: index
    

    参考:http://www.fengyunxiao.cn

          </div>
    
  • 相关阅读:
    2016.10.09
    Httpie 进行web请求模拟
    Python-集合
    python-字典
    MySQL权限系统
    MySQL8.0安装以及介绍(二进制)
    数据库对象中英文介绍
    Python-字符串
    GIT安装部署
    Cobbler安装部署
  • 原文地址:https://www.cnblogs.com/jpfss/p/11081485.html
Copyright © 2011-2022 走看看