zoukankan      html  css  js  c++  java
  • spring boot使用AOP切面编程

    spring boot使用AOP

    1.在pom文件中添加依赖:

    <!--spring boot aop切面-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-aop</artifactId>
            </dependency>

    2.建立如下所示类:WebLogAspect

    3.WebLogAspect类如下:

    package com.example.mapper.mybatisMap.aspect;

    import
    org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.AfterReturning; 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.util.Arrays; @Aspect @Component public class WebLogAspect { private Logger logger = LoggerFactory.getLogger(getClass()); ThreadLocal<Long> startTime = new ThreadLocal<>(); /*execution(): 表达式的主体 *第一个“*”符号: 表示返回值的类型任意 * com.example.mapper.mybatisMap.controller: AOP所切的服务的包名,即,需要进行横切的业务类 * 包名后面的“..”: 表示当前包及子包 * 第二个“*”: 表示类名,* 即所有类 * .*(..); 表示任何方法名,括号表示参数,两个点表示任何参数类型 * */ @Pointcut("execution(public * com.example.mapper.mybatisMap.controller..*.*(..))") public void webLog(){} @Before("webLog()") public void doBefore(JoinPoint joinPoint) throws Throwable { startTime.set(System.currentTimeMillis()); //接收到请求,记录请求内容 ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); HttpServletRequest request = attributes.getRequest(); //记录下请求 logger.info("URL : " + request.getRequestURL().toString()); logger.info("HTTP_METHOD : " + request.getMethod()); logger.info("IP : " + request.getRemoteAddr()); logger.info("CLASS_METHOD : " + joinPoint.getSignature().getDeclaringTypeName() + "." + joinPoint.getSignature().getName()); logger.info("ARGS : " + Arrays.toString(joinPoint.getArgs())); } @AfterReturning(returning = "ret", pointcut = "webLog()") public void doAfterReturning(Object ret) throws Throwable { //处理完请求,返回内容 logger.info("RESPONSE : " + ret); logger.info("SPEND TIME : " + (System.currentTimeMillis() - startTime.get())); } }

    4.在com.example.mapper.mybatisMap在建立一个包controller,在controller建立一个HelloController类:

    @RestController
    public class HelloController {
    
        private Logger logger = LoggerFactory.getLogger(getClass());
    
        /**
         * hello world 第一个程序
         * @return
         */
        @RequestMapping("/hello")
        public String hello(){
            return "Hello World!";
        }
    }

    5.运行程序,访问http://localhost:8080/hello ,控制台输出:

    浏览器页面输出:

    Hello World!

  • 相关阅读:
    【 Java框架】Spring的核心IOC源码分析
    小猪学设计模式——模板方法模式
    小猪学设计模式——工厂模式之抽象工厂
    小猪学设计模式——工厂模式之工厂方法模式
    小猪学设计模式——工厂模式之简单工厂(静态工厂)
    HTML5 Server-sent Events ASP.NET向Web客户端推送信息
    jquery.min.map 404 (Not Found)
    C# HTTP 断点续传
    C#操作JSON字符串
    Visual Studio 解决Windows Web服务框架中出现了无法识别的错误
  • 原文地址:https://www.cnblogs.com/heqiyoujing/p/9459828.html
Copyright © 2011-2022 走看看