SWAGGER注解说明
创始人
2024-03-29 05:59:47

@ApiModelProperty:对象属性,用在出入参数对象的字段上

@Api:用于controller类上

@ApiOperation:用在controller的方法上

@ApiResponses:用在controller的方法上

@ApiResponse:用在 @ApiResponses里边

@ApiImplicitParams:用在controller的方法上

@ApiImplicitParam:用在@ApiImplicitParams的方法里边

@ApiModel:用在返回对象类上

eg1:

@ApiOperation("信息软删除")

    @ApiResponses({ @ApiResponse(code = CommonStatus.OK, message = "操作成功"),

            @ApiResponse(code = CommonStatus.EXCEPTION, message = "服务器内部异常"),

            @ApiResponse(code = CommonStatus.FORBIDDEN, message = "权限不足") })

    @ApiImplicitParams({ @ApiImplicitParam(paramType = "query", dataType = "Long", name = "id", value = "信息id", required = true) })

    @RequestMapping(value = "/remove.json", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_UTF8_VALUE)

    public RestfulProtocol remove(Long id) {

    @ApiModelProperty(value = "标题")

    private String  title;

@RequestMapping(value = "/findById1/{id}", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_UTF8_VALUE)

@ApiImplicitParams({ @ApiImplicitParam(paramType = "body", dataType = "MessageParam", name = "param", value = "信息参数", required = true) })

  @RequestMapping(value = "/findById3", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_UTF8_VALUE, consumes = MediaType.APPLICATION_JSON_VALUE)

@PathVariable(name = "id") Long id 

@Api:

作用在类上,用来标注该类具体实现内容。表示标识这个类是swagger的资源 。 
参数: 
1. tags:可以使用tags()允许您为操作设置多个标签的属性,而不是使用该属性。 
2. description:可描述描述该类作用。

@ApiImplicitParam:

作用在方法上,表示单独的请求参数 
参数: 
1. name :参数名。 
2. value : 参数的具体意义,作用。 
3. required : 参数是否必填。 
4. dataType :参数的数据类型。 
5. paramType :查询参数类型,这里有几种形式:

类型

作用

path

以地址的形式提交数据

query

直接跟参数完成自动映射赋值

body

以流的形式提交 仅支持POST

header

参数在request headers 里边提交

form

以form表单的形式提交 仅支持POST

@ApiImplicitParams:

用于方法,包含多个 @ApiImplicitParam: 
例:

@ApiImplicitParams({

            @ApiImplicitParam(name = "id", value = "book's name", required = true, dataType = "Long", paramType = "query"),

            @ApiImplicitParam(name = "date", value = "book's date", required = false, dataType = "string", paramType = "query")})

@ApiModel:

用于类,表示对类进行说明,用于参数用实体类接收;

@ApiModelProperty:

用于方法,字段 ,表示对model属性的说明或者数据操作更改 
例:

    @ApiModel(value = "User", description = "用户")

    public class User implements Serializable{

    private static final long serialVersionUID = 1546481732633762837L;

    /**

     * 用户ID

     */

    @ApiModelProperty(value = "用户ID", required = true)

    @NotEmpty(message = "{id.empty}", groups = {Default.class,New.class,Update.class})

    protected String id;

    /**

     * code/登录帐号

     */

    @ApiModelProperty(value = "code/登录帐号")

    @NotEmpty(message = "{itcode.empty}", groups = {Default.class,New.class,Update.class})

    protected String itcode;

    /**

     * 用户姓名

     */

    @ApiModelProperty(value = "用户姓名")

    @NotEmpty(message = "{name.empty}", groups = {Default.class,New.class,Update.class})

    protected String name;

@ApiOperation:

用于方法,表示一个http请求的操作 。

    @ApiOperation(value = "获取图书信息", notes = "获取图书信息", response = Book.class, responseContainer = "Item", produces = "application/json")

    @ApiImplicitParams({

            @ApiImplicitParam(name = "id", value = "book's name", required = true, dataType = "Long", paramType = "query"),

            @ApiImplicitParam(name = "date", value = "book's date", required = false, dataType = "string", paramType = "query")})

    @RequestMapping(value = "/{id}", method = RequestMethod.GET)

    @ResponseBody

    public Book getBook(@PathVariable Long id, String date) {

        return books.get(id);

    }

@ApiResponse:

用于方法,描述操作的可能响应。

@ApiResponses:

用于方法,一个允许多个ApiResponse对象列表的包装器。 
例:

@ApiResponses(value = {

            @ApiResponse(code = 500, message = "2001:因输入数据问题导致的报错"),

            @ApiResponse(code = 500, message = "403:没有权限"),

            @ApiResponse(code = 500, message = "2500:通用报错(包括数据、逻辑、外键关联等,不区分错误类型)")})

@ApiParam:

用于方法,参数,字段说明,表示对参数的添加元数据(说明或是否必填等)

@Authorization:

声明要在资源或操作上使用的授权方案。

@AuthorizationScope:

介绍一个OAuth2授权范围。

@ResponseHeader:

响应头设置,使用方法

相关内容

热门资讯

埃菲尔铁塔在哪 中国仿建埃菲尔... 2019年4月26日,广西南宁市,街头惊现一座巨型山寨版埃菲尔铁塔,高约20米,白色塔身,造型逼真,...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
埃菲尔铁塔在哪 中国仿建埃菲尔... 2019年4月26日,广西南宁市,街头惊现一座巨型山寨版埃菲尔铁塔,高约20米,白色塔身,造型逼真,...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...