ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

springboot整合swagger2

2021-06-02 13:52:05  阅读:246  来源: 互联网

标签:wr springboot required value swagger2 整合 new import name


1、加入依赖
<dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>

        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

 

2、swagger2配置类
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

@Configuration
public class Swagger2Config {
	@Bean
	public Docket createRestApi() {
		return new Docket(DocumentationType.SWAGGER_2)
				.apiInfo(apiInfo())
				.select()
				.apis(RequestHandlerSelectors.basePackage("com.asiainfo.group"))
				.paths(PathSelectors.any())
				.build();
	}
	
	private ApiInfo apiInfo() {
		return new ApiInfoBuilder()
				.title("springboot整合swagger2的测试项目")
				.description("https://blog.csdn.net/xl_1803   by xulong")
				.termsOfServiceUrl("https://blog.csdn.net/xl_1803")
				.version("1.0")
				.build();
	}
}
3、启动类上打@EnableSwagger2注解

 

4、实体类
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import io.swagger.annotations.ApiParam;
import lombok.Data;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;

/**
 * @author xulong3
 * @Title: file_name
 * @Package package_name
 * @Description: todo
 * @date 2020/5/24 15:57
 */

@Data
@ApiModel("商品对象")
public class Product implements Serializable {

    private static final long serialVersionUID = 8170862039655345886L;

    @ApiModelProperty("商品ID")
    //@ApiParam(name="id",value="商品ID",required=true)
    private Long id;

    @ApiModelProperty("商品名称")
    //@ApiParam(name="name",value="商品名称",required=true)
    private String name;

    @ApiModelProperty("商品数量")
    //@ApiParam(name="amount",value="商品数量",required=true)
    private Integer amount;

    @ApiModelProperty("商品价格")
    //@ApiParam(name="price",value="商品价格",required=true)
    private BigDecimal price;

    @ApiModelProperty("商品创建时间")
    //@ApiParam(name="createTime",value="商品创建时间",required=false)
    private Date createTime;

    @ApiModelProperty("商品更新时间")
    //@ApiParam(name="updateTime",value="商品更新时间",required=false)
    private Date updateTime;



}

 

5、string转date类型转换器
import org.springframework.core.convert.converter.Converter;
import org.springframework.stereotype.Component;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * @author xulong3
 * @Title: file_name
 * @Package package_name
 * @Description: todo
 * @date 2020/5/24 16:58
 */

@Component
public class String2DateConverter implements Converter<String, Date> {
    @Override
    public Date convert(String s) {
        String format = "yyyy-MM-dd HH:mm:ss";
        SimpleDateFormat dateFormat = new SimpleDateFormat(format);

        try {
            return dateFormat.parse(s);
        } catch (ParseException e) {
        }
        return null;
    }
}

 

6、controller层统一返回对象
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;

/**
 * @author xulong3
 * @Title: file_name
 * @Package package_name
 * @Description: todo
 * @date 2020/5/24 16:07
 */
@Data
@ApiModel("通用响应对象")
public class WebResult<T> {

    @ApiModelProperty("状态码")
    private int code;

    @ApiModelProperty("响应信息")
    private String message;

    @ApiModelProperty("响应数据")
    private T data;


}

 

7、controller层
import com.asiainfo.group.springbootswagger2demo.entity.Product;
import com.asiainfo.group.springbootswagger2demo.util.WebResult;
import io.swagger.annotations.*;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

/**
 * @author xulong3
 * @Title: file_name
 * @Package package_name
 * @Description: todo
 * @date 2020/5/24 16:05
 */

@RestController
@RequestMapping("/product")
@Api(tags = "商品controller")
public class ProductController {

    @RequestMapping(value = "/save",method = RequestMethod.POST)
    @ApiOperation(value = "新增商品")
    @ApiImplicitParams(value={
            @ApiImplicitParam(name="id",value="商品ID",required=true,paramType="query",dataType="int"),
            @ApiImplicitParam(name="name",value="商品名称",required=true,paramType="query",dataType="string"),
            @ApiImplicitParam(name="amount",value="商品数量",required=true,paramType="query",dataType="int"),
            @ApiImplicitParam(name="price",value="商品价格",required=true,paramType="query",dataType="double"),
            @ApiImplicitParam(name="createTime",value="商品创建时间",required=false,paramType="query",dataType="string"),
            @ApiImplicitParam(name="updateTime",value="商品更新时间",required=false,paramType="query",dataType="string")
    })
    /*@ApiResponses({
            @ApiResponse(code=200,message="200成功啦!"),
            @ApiResponse(code=201,message="201啦!"),
            @ApiResponse(code=400,message="400啦!"),
            @ApiResponse(code=401,message="401啦!"),
            @ApiResponse(code=403,message="403啦!"),
            @ApiResponse(code=404,message="404啦!"),
            @ApiResponse(code=500,message="500啦!")
    })*/
    public WebResult<String> save(@ApiIgnore Product product){
        WebResult<String> wr = new WebResult<>();
        wr.setCode(200);
        wr.setMessage("success");
        wr.setData("请求成功");
        return wr;
    }

    @RequestMapping(value = "/queryAll",method = RequestMethod.GET)
    @ApiOperation(value = "查询所有商品")
    public WebResult<List<Product>> queryAll(){
        WebResult<List<Product>> wr = new WebResult<>();

        List<Product> productList = new ArrayList<>();
        for (int i = 0; i < 5; i++) {
            Product p = new Product();
            p.setId((long)i);
            p.setAmount(100);
            p.setName("香蕉"+i);
            p.setPrice(BigDecimal.valueOf(8.5));
            p.setCreateTime(new Date());
            p.setUpdateTime(new Date());
            productList.add(p);
        }

        wr.setCode(200);
        wr.setMessage("success");
        wr.setData(productList);
        return wr;
    }

    @RequestMapping(value = "/queryOne",method = RequestMethod.GET)
    @ApiOperation(value = "查询单个商品")
    @ApiImplicitParams(value={
            @ApiImplicitParam(name="id",value="商品ID",required=true,paramType="query",dataType="int")
    })
    public WebResult<Product> queryOne(long id){
        WebResult<Product> wr = new WebResult<>();

        Product p = new Product();
        p.setId(id);
        p.setAmount(100);
        p.setName("香蕉");
        p.setPrice(BigDecimal.valueOf(8.5));
        p.setCreateTime(new Date());
        p.setUpdateTime(new Date());

        wr.setCode(200);
        wr.setMessage("success");
        wr.setData(p);
        return wr;
    }

}

 

 8、访问http://localhost:8080/swagger-ui.html

 

标签:wr,springboot,required,value,swagger2,整合,new,import,name
来源: https://blog.51cto.com/u_14643435/2845676

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有