前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java 自定义注解之ElementType.PARAMETER

java 自定义注解之ElementType.PARAMETER

作者头像
qubianzhong
发布2018-09-19 13:38:59
4.6K0
发布2018-09-19 13:38:59
举报
文章被收录于专栏:行者常至

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

代码语言:javascript
复制
@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.如下
代码语言:javascript
复制
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是一个标记注解,没有成员。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018年04月14日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 需求:controller方法获取数据列表,orderPackagePayedAmount等于desc时按照packagePayedAmount字段倒叙排序,等于asc时按照packagePayedAmount字段正叙排序.
  • 自定义注解OrderBy
    • 1.new class OrderBy.如下
      • 2.在controller类上添加注解@Validated
      • 名词解释:
        • @Target
          • @Retention
            • @Documented
            相关产品与服务
            项目管理
            CODING 项目管理(CODING Project Management,CODING-PM)工具包含迭代管理、需求管理、任务管理、缺陷管理、文件/wiki 等功能,适用于研发团队进行项目管理或敏捷开发实践。结合敏捷研发理念,帮助您对产品进行迭代规划,让每个迭代中的需求、任务、缺陷无障碍沟通流转, 让项目开发过程风险可控,达到可持续性快速迭代。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档