Spring Boot 集成swagger2,以及Springboot报错的一些小问题。

昨天在开发的过程遇到了,代码一直报错的问题,在写mapper的时候,因为导入的包有问题,但是书写的报错日志却更报错信息没有一点关系,是应为在Springboot编译的过程中,他会把之前的编译的结果打成包,所以说要clean一下重新的install一下maven项目 就可以了。。也算是,在之前开发中遇到的坑了
spring-boot作为当前最为流行的Java web开发脚手架,相信越来越多的开发者会使用其来构建企业级的RESTFul API接口。这些接口不但会服务于传统的web端(b/s),也会服务于移动端。在实际开发过程中,这些接口还要提供给开发测试进行相关的白盒测试,那么势必存在如何在多人协作中共享和及时更新API开发接口文档的问题。
假如你已经对传统的wiki文档共享方式所带来的弊端深恶痛绝,那么尝试一下Swagger2 方式,一定会让你有不一样的开发体验:

功能丰富 :支持多种注解,自动生成接口文档界面,支持在界面测试API接口功能;
及时更新 :开发过程中花一点写注释的时间,就可以及时的更新API文档,省心省力;
整合简单 :通过添加pom依赖和简单配置,内嵌于应用中就可同时发布API接口文档界面,不需要部署独立服务。
根据自身的接口和以及自身需求
首先新建一个Spring项目于

<dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.6.1</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.6.1</version>
        </dependency><dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

加入上面所要导入的包,然后再启动类里面直接进行设置,首先配置启动类:

package com.example.swagger;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;

import com.google.common.base.Predicate;

import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
import static com.google.common.base.Predicates.*;

@SpringBootApplication
@EnableSwagger2 //启用swagger
public class SwaggerApplication {
    public static void main(String[] args) {
        SpringApplication.run(SwaggerApplication.class, args);
    }

    /**
     * 这里是可以分组定义多个Docket,我这里举例定义了两个,一个是业务文档类型,一个是财务文档类型。
     * 定义了多个分组后,在页面上提供了一个下拉来选择组,具体运行起来看看就知道了。
     * 我这个是参照官方的代码改了改,有的删了,具体的大家看官方文档吧,
     * 地址:http://springfox.github.io/springfox/docs/current/#plugins-available-for-extensibility
     *
     */

    /**业务文档*/
    @Bean
    public Docket businessDocket() {
        return new Docket(DocumentationType.SWAGGER_2)
                .groupName("业务文档") //分组名称
                .select()
                .paths(businessPaths()) //指定路径处理PathSelectors.any()代表所有的
                .build()
                .apiInfo(apiInfo());
    }
    @SuppressWarnings("unchecked")
    private Predicate<String> businessPaths() {
        return or(PathSelectors.regex("/user.*"));//这里是正则表达式
    }


    /**财务文档*/
    @Bean
    public Docket financeDocket() {
        return new Docket(DocumentationType.SWAGGER_2)
                .groupName("财务文档")//分组名称
                .select()
                .paths(financePaths())//指定路径处理PathSelectors.any()代表所有的
                .build()
                .apiInfo(apiInfo());
    }
    @SuppressWarnings("unchecked")
    private Predicate<String> financePaths() {
        return or(PathSelectors.regex("/finance.*"));//这里是正则表达式
    }


    /**指定了页面显示的信息,标题、描述*/
    private ApiInfo apiInfo() {
        return new ApiInfoBuilder().title("使用Spring Boot 集成 swagger")
                .description("玩转Spring Boot 博客地址:http://blog.csdn.net/cl_andywin").build();
    }

}

具体里面的功能已经通过注解写的比较清楚了,但是在我根据教程搭建的时候只是搭建了user/里面的方法。
首先要创建一个实体类,然后将参数进行配置

package com.example.swagger.bean;

/**
 * Copyright (c),2016-2018,北京金地安华有限公司成都分公司
 * ClassName   :  User
 * Author      : MaMingze
 * Date        : 2018/12/26 10:33
 * Description : TODO
 * Version 1.0
 **/


public class User {
    private Long id;
    private String name;
    private String sex;
    private Integer age;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "User [id=" + id + ", name=" + name + ", sex=" + sex + ", age=" + age + "]";
    }

}

然后在contol里面进行配置 ,然后就可以在网页上直接进行测试了,

package com.example.swagger.controller;

import com.example.swagger.bean.User;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * Copyright (c),2016-2018,北京金地安华有限公司成都分公司
 * ClassName   :  UserController
 * Author      : MaMingze
 * Date        : 2018/12/26 10:46
 * Description : TODO
 * Version 1.0
 **/


@RestController
@RequestMapping("/user")
@Api(tags = "user")
public class UserController {
    public List<User> getUserList() {
        return null;
    }

    /*
     * 这里就写两个例子啊,其余的都一样了,就不在写了。
     *
     */

    /**
     * 增加的时候,我通过用参数的方式来增加
     *
     * @param user
     * @return
     */
    @ApiOperation("增加用户信息")
    @ApiImplicitParams({
            @ApiImplicitParam(paramType = "query", name = "name", dataType = "String", required = true, value = "姓名", defaultValue = "成立"),
            @ApiImplicitParam(paramType = "query", name = "sex", dataType = "String", required = true, value = "性别", defaultValue = "男"),
            @ApiImplicitParam(paramType = "query", name = "age", dataType = "int", required = false, value = "年龄", defaultValue = "18") })
    @RequestMapping(method = RequestMethod.POST)
    public User save(User user) {
        // 这里为了方便直接将输入内容返回
        return user;
    }

    /**
     * 修改的时候,我通过使用JSON的方式来修改
     *
     * @param id
     * @param user
     * @return
     */
    @ApiOperation(value = "修改用户信息", notes = "根据ID修改用户信息")
    @ApiImplicitParams({
            @ApiImplicitParam(paramType = "path", name = "id", value = "用户ID", required = true, dataType = "Long"),
            @ApiImplicitParam(paramType = "body", name = "user", value = "用户实体", required = true, dataType = "User") })
    @RequestMapping(value = "/{id}", method = RequestMethod.PUT)
    public User update(@PathVariable Long id, @RequestBody User user) {
        // 这里为了方便直接将输入内容返回
        return user;
    }
}


最后新建一个model类对返回的信息的处理

package com.reset.model;
 
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
 
/**
 * Created by chendai on 2018/3/21.
 */
@ApiModel(description = "返回响应数据")
public class RestMessgae {
 
    @ApiModelProperty(value = "错误信息")
    private String message;
    @ApiModelProperty(value = "状态码")
    private String code;
    @ApiModelProperty(value = "返回的数据")
    private Object data;
 
    public String getMessage() {
        return message;
    }
 
    public void setMessage(String message) {
        this.message = message;
    }
 
    public String getCode() {
        return code;
    }
 
    public void setCode(String code) {
        this.code = code;
    }
 
    public Object getData() {
        return data;
    }
 
    public void setData(Object data) {
        this.data = data;
    }
}

Swagger里面常用注解介绍

@Api():作用于类上,表示这个类是swagger的资源。
tags = ”说明该类的作用“
@ApiOperation():用在请求的方法上,说明的方法的用户和作用
value=“说明方法的用途、作用”
notes="方法的备注说明“
@ApiImplicitParams():用在请求的方法上,表示一组参数说明,可以包含多个@ApiImplicitParam()
@ApiImplicitParam():指定一个请求参数的各个方面
name:参数名
value:参数的汉字说明
required:参数是否必须传
dataType:参数类型
defaultValue:参数的默认值
@ApiResponses():用在请求的方法上,表示一组响应。可以包含多个@ApiResponse()
@ApiResponse():用于表示一个错误的响应信息
code:数字
message:信息
response:抛出异常的类

大概就是这样需要下来大量的练习
之前没有写上 访问地址 现在把普遍使用的地址写上
在这里插入图片描述
根据不同的路径书写地址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值