自定义注解类java
@Target({ElementType.PARAMETER, ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) public @interface LongOu { }
@Target,@Retention都是java的元注解(总共有4个):spring
@Target:设置注解的使用范围,这里设置能够用在参数上和方法上。编程
@Retention:设置注解的生命周期,这里设置在运行时。springboot
切面类:app
@Aspect//声明这是一个切面 @Component//把这个类交给spring管理 public class LogOuAspect { // 把切面的链接点放在了咱们的注解上 @Pointcut("@annotation(com.example.demo.log.LongOu)") public void ouAspect() { } // 在这里定义前置切面 @Before("ouAspect()") public void beforeMethod(JoinPoint joinPoint) { // 这里执行保存日志的动做 System.out.println("方法前......."); //获得被切方法的参数 System.out.println(joinPoint.getArgs()[0]); } }
conctronller类:this
@RestController //springboot注解,类下的全部方法返回的数据类型为jason public class AspectController { @RequestMapping("/getUser") @LongOu//这是咱们自定义的注解,加上这个注解后就可以切到这个方法了。 public User getUser(@PathVariable Integer id,HttpServletRequest request) { System.out.println("方法中。。。。。"); User user=new User(); user.setName("小明"); user.setPassword("xxxx"); return user; } }
实体类:spa
public class User { Integer id; String name; String password; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
运行结果:日志
方法前.......
方法中。。。。。code