Java 通过反射获取实体类对应的注释

文章介绍了如何引入swagger依赖来使用@ApiModelProperty注解获取和处理实体类的注释信息,通过在实体类的字段上添加此注解,然后在main方法中遍历并提取这些注解的值,以生成API文档所需的字段描述。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、使用@ApiModelProperty 获取注释信息 需要引入 swagger 依赖

①先引入swagger依赖

在 Maven 项目中引入 Swagger 依赖是第一步,目的是为了能够使用 Swagger 的注解,如 @ApiModelProperty。这是必要的,因为没有这些依赖,编译器将无法识别这些注解。

    <dependency>
		<groupId>com.spring4all</groupId>
		<artifactId>swagger-spring-boot-starter</artifactId>
		<version>1.9.1.RELEASE</version>
	</dependency>

②准备实体类 注意(swagger 依赖没有加载无法使用@ApiModelProperty 注解)

在这个例子中,我们定义了一个名为 OrderCsv 的 Java 类。这个类实现了 Serializable 接口,表示它的对象可以被序列化。我们使用 @Data 注解(通常来自 Lombok)来自动生成 getter 和 setter 方法。

@Data
public class OrderCsv implements Serializable {

    /**
     * 名称
     */
    @ApiModelProperty("名称")
    private String name;

    /**
     * 年龄
     */
    @ApiModelProperty("年龄")
    private String age;

    /**
     * id
     */
    @ApiModelProperty("id")
    private String id;
}
详细字段解释
  • @ApiModelProperty("名称"):这个注解为 name 字段添加描述。Swagger 将使用这个描述生成 API 文档。
  • private String name;:这是字段的声明,private 修饰符表示该字段只能在 OrderCsv 类内部访问。

二、具体方法使用main方法测试

 public static void main(String[] args) {
        //获取对象 属性注释 准备集合接收 字段注释
        List<String> list = new ArrayList<>();
        //加载类
        Class<OrderCsv> orderDtoClass = OrderCsv.class;
        /*
         * 1.getDeclaredFields 获取当前类的所有字段,包括protected/默认/private修饰的字段;不包括父类public修饰的字段
         * 2.getFields 方法获取当前类或父接口的public修饰的字段 
         *  当前使用1就ok 根据需要修改方法
         */
        Field[] declaredFields = orderDtoClass.getDeclaredFields();
        //遍历数据
        for (Field declaredField : declaredFields) {
            //isAnnotationPresent 查看当前字段是否加有@ApiModelProperty注解
            boolean annotation = declaredField.isAnnotationPresent(ApiModelProperty.class);
            // true 是含有 含有再获取添加到list中
            if (annotation) {
                String value = declaredField.getAnnotation(ApiModelProperty.class).value();
                list.add(value);
            }
        }
    }
  • List<String> list = new ArrayList<>();:我们创建一个列表,用于存储所有字段的注释信息。
  • Class<OrderCsv> orderDtoClass = OrderCsv.class;:我们获取 OrderCsv 类的 Class 对象,这样就可以使用反射来获取类的元信息。
  • Field[] declaredFields = orderDtoClass.getDeclaredFields();:这行代码获取 OrderCsv 类中声明的所有字段,包括 privateprotected 和默认访问级别的字段,但不包括父类的字段。
  • for (Field declaredField : declaredFields):遍历获取到的所有字段。
  • declaredField.isAnnotationPresent(ApiModelProperty.class):检查当前字段是否有 @ApiModelProperty 注解。
  • declaredField.getAnnotation(ApiModelProperty.class).value():如果有注解,则获取注解的 value 属性,该属性包含字段的描述。
  • list.add(value);:将获取到的描述添加到列表中。

三、反射的优缺点 

优点:
  • 灵活性:反射使得代码更加动态,可以在运行时获取类的信息,适用于某些需要动态处理类的场景。
  • 元编程:允许开发者编写更通用的代码,比如框架、库和工具。
缺点:
  • 性能开销:反射操作通常比直接访问要慢,因为它需要在运行时解析类的信息。
  • 安全性:使用反射可能会绕过 Java 的访问控制,可能导致安全隐患。
  • 复杂性:反射代码通常比常规代码更复杂,调试和维护起来也较困难。

注意点: 1.实体类字段是否添加@ApiModelProperty 注解

             2.实体类字段修饰符问题 根据修饰符使用不同的方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路漫漫,其修远兮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值