zoukankan      html  css  js  c++  java
  • swagger2 注解说明 @ApiImplicitParam和@ApiImplicitParams的用法

    Swagger2的具体使用方法,参见另一篇文章Swagger的使用方法和简单介绍https://blog.csdn.net/weixin_44299027/article/details/105773432

    @Api:用在请求的类上,表示对类的说明

    1. tags="说明该类的作用,可以在UI界面上看到的注解"

    2. value="该参数没什么意义,在UI界面上也看到,所以不需要配置"

    @ApiOperation:用在请求的方法上,说明方法的用途、作用

    1. value="说明方法的用途、作用"

    2. notes="方法的备注说明

     示例如下: 

    @Api(tags = "用户管理")
    @RestController
    @RequestMapping(value = "/user")
    public class UserController {
    	
        @Autowired
        private UserServiceFacade userServiceFacade;
    
        @ApiOperation("添加用户")
        @PostMapping(value = "add")
        public CommResponse<?> addUser(@RequestHeader(name = "accessToken")String accessToken,@RequestBody UserAddRequest userAddRequest,HttpServletRequest request){
    	userAddRequest.setAccessToken(accessToken);
    	userServiceFacade.addUser(userAddRequest);
    	return CommResponse.ok();
        }
    }

    @ApiImplicitParams:用在请求的方法上,表示一组参数说明

             @ApiImplicitParam:用在@ApiImplicitParams注解中,指定一个请求参数的各个方面

    1. name:参数名

    2. value:参数的汉字说明、解释

    3. required:参数是否必须传,默认false

    4. paramType:参数放在哪个地方,查询参数类型,这里有几种形式:

      1. header --> 请求参数的获取:@RequestHeader,参数在request headers 里边提交

      2. query --> 请求参数的获取:@RequestParam,直接跟参数,完成自动映射赋值

      3. path(用于restful接口)--> 请求参数的获取:@PathVariable,以地址的形式提交数据

      4. body(不常用)--> 以流的形式提交 仅支持POST

      5. form(不常用)--> 以form表单的形式提交 仅支持POST

    5. dataType:参数类型,默认String,其它值dataType="Integer"

    6. defaultValue:参数的默认值

    
    @Api(tags = "用户管理")
    @RestController
    @RequestMapping(value = "/user")
    public class UserController {
    
        @Autowired
        private UserServiceFacade userServiceFacade;
    
        @ApiOperation("修改密码")
        @ApiImplicitParams({
    	@ApiImplicitParam(name = "username",value = "账号" , dataType = "String", paramType = "query"),		
    	@ApiImplicitParam(name = "oldPassword",value = "旧密码" , dataType = "String", paramType = "query"),
    	@ApiImplicitParam(name = "newPassword",value = "新密码" , dataType = "String", paramType = "query")
    	})
        @GetMapping(value = "updatePassword")
        public CommResponse<?> updatePassword(@RequestHeader(name = "accessToken")String accessToken,String username,String oldPassword,String newPassword){
    		userServiceFacade.updatePassword(accessToken,username,oldPassword,newPassword);
    	return CommResponse.ok();
        }
    }

    @ApiResponses:用在请求的方法上,表示一组响应

             @ApiResponse:用在@ApiResponses中,一般用于表达一个错误的响应信息

    1. code:数字,例如400

    2. message:信息,例如"请求参数没填好"

    3. response:抛出异常的类

    示例如下:

    @ApiOperation(value = "select1请求",notes = "多个参数,多种的查询参数类型")
    @ApiResponses({
        @ApiResponse(code=400,message="请求参数没填好"),
        @ApiResponse(code=404,message="请求路径没有或页面跳转路径不对")
    })

    @ApiModel:用于响应类上,表示一个返回响应数据的信息

    1. (这种一般用在post创建的时候,使用@RequestBody这样的场景,

    2. 请求参数无法使用@ApiImplicitParam注解进行描述的时候)

    3. @ApiModelProperty:用在属性上,描述响应类的属性

    示例如下:

    
    import io.swagger.annotations.ApiModel;
    import io.swagger.annotations.ApiModelProperty;
     
    import java.io.Serializable;
     
    @ApiModel(description= "返回响应数据")
    public class RestMessage implements Serializable{
     
        @ApiModelProperty(value = "是否成功")
        private boolean success=true;
        @ApiModelProperty(value = "返回对象")
        private Object data;
        @ApiModelProperty(value = "错误编号")
        private Integer errCode;
        @ApiModelProperty(value = "错误信息")
        private String message;
     
        /* getter/setter */
    }
  • 相关阅读:
    [转]Spring.NET企业架构实践之 NHibernate + Spring.NET + WCF + Windows服务 + Silverlight 中小企业应用架构完整Demo
    [转]用EA 建模设计Blog全过程
    下载页面
    Expression Studio 4 ultimate x86 下载含序列号
    ACS.NET缓存技术
    Case
    再谈C#中的委托,匿名方法和Lambda表达式
    代理服务器的设置
    软件架构师之职责范围和高级软件工程师的职责范围
    WPF博客
  • 原文地址:https://www.cnblogs.com/no8g/p/13415541.html
Copyright © 2011-2022 走看看