java 自定义注解之ElementType.PARAMETER

需求:controller方法获取数据列表,orderPackagePayedAmount等于desc时按照packagePayedAmount字段倒叙排序,等于asc时按照packagePayedAmount字段正叙排序.


@Api("项目管理")
@RestController
@RequestMapping("/project")
@Validated
public class ProjectController extends BaseController {

@ApiOperation(value = "获取项目管理列表", response = ProjectInfoVO.class)
@GetMapping("/list")
public ResultMessage queryProjectList(@OrderBy @ApiParam(value = "已结算数量排序(选填 值为desc/asc)") @RequestParam(value = "packagePayedAmount", required = false) String orderPackagePayedAmount,
                                          @ApiParam(value = "分页数量") @RequestParam(value = "pageSize", defaultValue = "10") int pageSize,
                                          @ApiParam(value = "页码") @RequestParam(value = "pageNo", defaultValue = "1") int pageNo) {


        ResultMessage resultMessage = new ResultMessage();

        //....
        
        return resultMessage;
    }
}

自定义注解OrderBy

1.new class OrderBy.如下
package com.antzb.chaos.annotations;

import javax.validation.Constraint;
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import javax.validation.Payload;
import java.lang.annotation.*;

/**
 * @Author: qubianzhong
 * @Date: 18-4-12 下午1:38
 */
@Documented
@Target({ElementType.PARAMETER, ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = OrderBy.OrderByValidator.class)
public @interface OrderBy {

    String message() default "{只能为 DESC 或者 ASC}";

    Class<?>[] groups() default {};

    Class<? extends Payload>[] payload() default {};

    class OrderByValidator implements ConstraintValidator<OrderBy, String> {

        @Override
        public void initialize(OrderBy constraintAnnotation) {
        }

        @Override
        public boolean isValid(String value, ConstraintValidatorContext context) {
            boolean isValid = true;
            if (value != null && !"DESC".equals(value.toUpperCase()) && !"ASC".equals(value.toUpperCase())) {
                isValid = false;
            }
            return isValid;
        }
    }
}

2.在controller类上添加注解@Validated


名词解释:

@Target
  • @Target 说明了Annotation所修饰的对象范围

  • 取值(ElementType)有:

  • 1.CONSTRUCTOR:用于描述构造器

  • 2.FIELD:用于描述域

  • 3.LOCAL_VARIABLE:用于描述局部变量

  • 4.METHOD:用于描述方法

  • 5.PACKAGE:用于描述包

  • 6.PARAMETER:用于描述参数

  • 7.TYPE:用于描述类、接口(包括注解类型) 或enum声明

@Retention
  • @Retention定义了该Annotation被保留的时间长短:
  • 某些Annotation仅出现在源代码中,而被编译器丢弃;而另一些却被编译在class文件中;编译在class文件中的Annotation可能会被虚拟机忽略,而另一些在class被装载时将被读取(请注意并不影响class的执行,因为Annotation与class在使用上是被分离的)。使用这个meta-Annotation可以对 Annotation的“生命周期”限制。
  • 取值(RetentionPoicy)有:
  • 1.SOURCE:在源文件中有效(即源文件保留)
  • 2.CLASS:在class文件中有效(即class保留)
  • 3.RUNTIME:在运行时有效(即运行时保留)
@Documented
  • @Documented用于描述其它类型的annotation应该被作为被标注的程序成员的公共API,因此可以被例如javadoc此类的工具文档化。Documented是一个标记注解,没有成员。

推荐一个 宝宝启蒙动物认知动物叫声 的小程序
动物叫声大全,动物声音合集,动物叫声,动物认知

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值