使用Java自定义注解实现获取请求的主机IP、URL、类型、方法名、入参以及返回结果

一、注解的基本知识

1.注解的定义

Java文件叫做Annotation,用@interface表示。

2.元注解

在创建注解的时候,需要使用一些注解来描述自己创建的注解,就是写在@interface上面的那些注解,这些注解被称为元注解。

2.1注解的保留策略
  • @Retention
    表示需要在什么级别保存该注解信息。可选的RetentionPolicy参数包括:
    SOURCE:注解仅存在于源码中,在class字节码文件中不包含
    CLASS:默认的保留策略,注解会在class字节码文件中存在,但运行时无法获得
    RUNTIME:注解会在class字节码文件中存在,在运行时可以通过反射获取到
2.2注解的作用目标
  • @Target
    表示该注解可以用于什么地方,可能的ElementType参数有:
    CONSTRUCTOR:作用于构造函数
    FIELD:作用于字段、枚举的常量
    LOCAL_VARIABLE:作用于局部变量
    METHOD:作用于方法
    PACKAGE:作用于包
    PARAMETER:作用于方法参数
    TYPE:作用于接口、类、枚举、注解
    ANNOTATION_TYPE:作用于注解
2.3注解包含在javadoc中
  • @Documented
2.4注解可以被继承
  • @Inherited
3.自定义注解使用
3.1注解创建

由于是对每个请求方法的捕获和监控,所以创建一个作用于方法级别的注解。
注解创建

3.2 使用aop对注解进行拦截,获取请求的主机IP、URL、类型、方法名、入参以及返回结果

拦截请求

3.3在方法上使用自定义注解

使用自定义注解

3.4 调用方法,测试
  • GET请求
    Get请求
  • 控制台输出:
127.0.0.1          							//这是目标主机IP
http://localhost:8080/annotation/get/2		//这是请求URL
GET												//这是请求类型
getAnnotationTest								//这是请求方法
id:2; 											//这是请求参数
GET SUCCESS									//这是请求返回结果

Get方法请求输出

  • POST请求
    Post请求
  • 控制台输出:
127.0.0.1									//这是目标主机IP
http://localhost:8080/annotation/post		//这是请求URL
POST										//这是请求类型
postAnnotationTest							//这是请求方法
userDTO:UserDTO(age=1, username=qianye); 	//这是请求参数
POST SUCCESS								//这是请求返回结果

Post请求方法结果

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现不同目标方法执行不同逻辑,可以使用Java自定义注解和反射机制。 首先,自定义注解需要用@Target注解来指定使用范围,例如可以指定在方法使用,即@Target(ElementType.METHOD)。 其次,注解需要用@Retention注解来指定生命周期,例如可以指定在运行时依然存在,即@Retention(RetentionPolicy.RUNTIME)。 然后,在目标方法上加上自定义注解,并通过反射获取注解信息,根据注解信息执行不同逻辑。 下面是一个简单的示例代码: ``` @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface MyAnnotation { String value(); } public class AnnotationDemo { @MyAnnotation("method1") public void method1() { System.out.println("This is method1"); } @MyAnnotation("method2") public void method2() { System.out.println("This is method2"); } public static void main(String[] args) throws Exception { AnnotationDemo demo = new AnnotationDemo(); Method[] methods = demo.getClass().getDeclaredMethods(); for (Method method : methods) { if (method.isAnnotationPresent(MyAnnotation.class)) { MyAnnotation annotation = method.getAnnotation(MyAnnotation.class); if (annotation.value().equals("method1")) { method.invoke(demo); } else if (annotation.value().equals("method2")) { method.invoke(demo); } } } } } ``` 在上面的示例代码中,定义了一个自定义注解@MyAnnotation,并在AnnotationDemo类中的两个方法上分别加上了该注解,并指定了不同的value值。 在main方法中,通过反射获取AnnotationDemo类中的所有方法,判断方法上是否加上了@MyAnnotation注解,如果有,则获取注解信息,并根据注解信息执行不同的逻辑。 在这个简单的例子中,我们可以看到使用自定义注解和反射机制可以实现不同目标方法执行不同逻辑的功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值