All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jd.blockchain.utils.http.RequestParam Maven / Gradle / Ivy

package com.jd.blockchain.utils.http;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import com.jd.blockchain.utils.http.converters.ObjectToStringConverter;

/**
 * 用于标识一个方法参数或一个类的成员该如何体现为 http 请求中的一个参数;

* * 如果采用 HTTP GET 方法发起请求,则 RequestParam 标识的参数将以查询参数的方式通过 URL 提交;

* * 如果采用 HTTP POST 方法发起请求,则 RequestParam 标识的参数将以表单字段的方式提交;

* * @author haiq * */ @Target({ElementType.PARAMETER, ElementType.FIELD, ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) public @interface RequestParam { /** * 参数名; * * @return */ public String name(); /** * 参数是否必须提供;

* * 如果必须的参数的值为 null ,将引发异常;

* * 如果非必须的参数的值为 null,则忽略此参数;

* * 默认为 true; * * @return */ public boolean required() default true; /** * 是否为数组; * *
* * 如果设为 true,则参数必须为数组类型,此参数将输出为“列表参数”; * * @return */ public boolean array() default false; /** * 忽略值; * * 仅当 require 为 false 时有效,指示当参数的值为 null 或者与 ignoreValue 相等时将忽略参数; * * @return */ public String ignoreValue() default ""; /** * 参数值转换器的类型; * * 指定的参数值转换器必须实现 StringConverter 接口; * * 如果未指定,则默认通过 toString() 方法获取参数最终的文本值; * * @return */ public Class converter() default ObjectToStringConverter.class; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy