网站首页 > java教程 正文
咱是这么一个场景,通过注解能接口的请求参数拿到,这样每个方法在执行的时候,都能比较统一简单的方式的去获取。
首先引入aop切面的依赖包
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
定义注解
在定义这个注解之前,咱们先了解一下注解的生命周期。通过@Retention定义注解的生命周期,举个例子
@Retention(RetentionPolicy.RUNTIME)
他有三种生命周期的定义,如下,其中RetentionPolicy的不同策略,对应不同的生命周期。
- RetentionPolicy.SOURCE : 仅存在于源代码中,编译阶段会被丢弃,不会包含于class字节码文件中。@Override, @SuppressWarnings都属于这类注解。
- RetentionPolicy.CLASS : 默认策略,在class字节码文件中存在,在类加载的时被丢弃,运行时无法获取到。
- RetentionPolicy.RUNTIME : 始终不会丢弃,可以使用反射获得该注解的信息。自定义的注解最常用的使用方式。
第二个就是注解的作用目标
通过@Target 定义注解的作用目标,比如作用于类、属性或方法等。
@Target(ElementType.TYPE)
对应ElementType参数值适用范围如下
- ElementType.TYPE: 类、接口、注解、enum
- ElementType.CONSTRUCTOR: 构造函数
- ElementType.FIELD: 成员变量、对象、属性、枚举的常量
- ElementType.LOCAL_VARIABLE: 局部变量
- ElementType.METHOD: 方法
- ElementType.PACKAGE: 包
- ElementType.PARAMETER: 参数
- ElementType.ANNOTATION_TYPE): 注解
- ElementType.TYPE_PARAMETER:类型参数,表示这个注解可以用在 Type的声明式前,jdk1.8引入。
- ElementType.TYPE_USE:类型的注解,表示这个注解可以用在所有使用Type的地方(如:泛型,类型转换等),jdk1.8引入。
还一个注解,框架自带的注解 Inherited。
@Inherited 注解 是定义注解和字类之间的关系。在使用此类的注解,子类会自动继承此注解,否则,子类不会继承此注解。
用实例验证一下
1) 定义一个注解
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface PrintLog {
}
2)在定义一个切面类
@Aspect
@Component
public class PrintLogAspect {
@Pointcut("@annotation(org.example.myannotion.PrintLog)")
public void logPoint(){
}
@Around("logPoint()")
public void logAround(ProceedingJoinPoint joinPoint){
String methodName = joinPoint.getSignature().getName();
Object[] param = joinPoint.getArgs();
StringBuilder sb = new StringBuilder();
for(Object o: param){
sb.append(o+";");
}
System.out.println("方法:"+methodName+",请求参数是:"+sb.toString());
try {
joinPoint.proceed();
} catch (Throwable throwable) {
throwable.printStackTrace();
}
System.out.println("方法执行结束!");
}
说明:
@Pointcut("@annotation(org.example.myannotion.PrintLog)")
代表定义了一个切点,@annotation表示这个切点切到一个注解上,后面带该注解的全类名。
切面最重要的就是切点,所有的动作都是围绕切点发生。
logPoint() 这个是切点名称,在环绕通知使用的时候,通过 @Around("logPoint()") 使用。
上边介绍完了。下边通过实例去验证一下。
@PrintLog
@GetMapping("/t3/{p1}/{p2}")
public String t3(@PathVariable("p1") String p1, @PathVariable("p2") String p2){
return "visit t3";
}
@PrintLog
@PostMapping("/t4")
public String t4(@RequestBody Map param ){
return "visit t3";
}
分别请求两个接口后,显示如下。
t3方法:请求参数是:123;bac;
t4方法: 请求参数是:{k1=11, k2=22};
OK 自定义注解,通过切面监听切点的方式,实现方法的参数的打印。
大家有什么想法或问题,欢迎指正。
- 上一篇: 不懂这些,你敢说自己知道Java标准输入输出流?
- 下一篇: 第九章:Java输入输出流和文件操作
猜你喜欢
- 2024-10-31 阿里经典面试-java三线程轮流打印A、B、C的ReentrantLock实现
- 2024-10-31 学习廖雪峰的JAVA教程---反射(名叫Class的类、动态加载)
- 2024-10-31 Java案例-求和与打印九九乘法表(用java打印九九乘法口诀)
- 2024-10-31 Java面试题:怎么让两个线程交替打印1和2(生产者消费者问题)
- 2024-10-31 第九章:Java输入输出流和文件操作
- 2024-10-31 Java基础学习:java输出整数类型(java分别输出整数和小数)
- 2024-10-31 不懂这些,你敢说自己知道Java标准输入输出流?
- 2024-10-31 Java高阶面试:如何实现三个线程交替循环打印
- 2024-10-31 字节流的输入输出,JAVA基础知识笔记
- 2024-10-31 IntelliJ IDEA 如何针对Java 代码快速打印 println
你 发表评论:
欢迎- 07-15采用Oracle OSB总线进行服务注册和接入
- 07-15javaEE 新闻管理系统 oracle11+tomcat6
- 07-15从Oracle演进看数据库技术的发展(oracle数据库发展史)
- 07-15如何升级oracle数据库安全补丁(oraclepsu补丁升级)
- 07-15【权威发布】关于Oracle WebLogic Server未授权远程代码执行高危漏洞的预警通报
- 07-15【mykit-data】 数据库同步工具(数据库表同步工具)
- 07-15[Java速成] 数据库基础,Connector/J、JDBC、JPA的关系(day 7)
- 07-15Google前工程主管“入住”Oracle(google浏览器找不到以前的书签)
- 最近发表
-
- 采用Oracle OSB总线进行服务注册和接入
- javaEE 新闻管理系统 oracle11+tomcat6
- 从Oracle演进看数据库技术的发展(oracle数据库发展史)
- 如何升级oracle数据库安全补丁(oraclepsu补丁升级)
- 【权威发布】关于Oracle WebLogic Server未授权远程代码执行高危漏洞的预警通报
- 【mykit-data】 数据库同步工具(数据库表同步工具)
- [Java速成] 数据库基础,Connector/J、JDBC、JPA的关系(day 7)
- Google前工程主管“入住”Oracle(google浏览器找不到以前的书签)
- Oracle数据库云服务系列新增前所未有的企业级功能
- 直播预告丨如何实现Oracle存储过程到java的一键转化
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)