目的:實現在任何想要切的地方添加一個注解就能實現面向切面編程
自定義注解類
@Target({ElementType.PARAMETER, ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) public @interface LongOu { }
@Target,@Retention都是java的元注解(總共有4個):
@Target:設置注解的使用范圍,這里設置可以用在參數上和方法上。
@Retention:設置注解的生命周期,這里設置在運行時。
切面類:
@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類:
@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; } }
實體類:
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; } }
運行結果:
方法前.......
方法中。。。。。