搭建SpringBoot + Gradle + MyBatisP

2020-08-16  本文已影响0人  爱学习的蹭蹭

1、简要说明

2、核心功能

在线文档http://doc.xiaominfo.com/
该UI增强包主要包括两大核心功能:文档说明在线调试

3、UI增强

同时,swagger-bootstrap-ui在满足以上功能的同时,还提供了文档的增强功能,这些功能是官方swagger-ui所没有的,每一个增强的功能都是贴合实际,考虑到开发者的实际开发需要,是比不可少的功能,主要包括:

4、UI特点

5、 Maven与Gradle配置中引入Jar包

<dependency>
 <groupId>io.springfox</groupId>
 <artifactId>springfox-swagger2</artifactId>
 <version>2.9.2</version>
</dependency>
 compile "io.springfox:springfox-swagger2:${swagger2_version}"
<dependency>
  <groupId>com.github.xiaoymin</groupId>
  <artifactId>swagger-bootstrap-ui</artifactId>
  <version>${lastVersion}</version>
</dependency>
compile "com.github.xiaoymin:swagger-bootstrap-ui:${swagger_bsi_version}"

6、代码实现

@Configuration
@EnableSwagger2
@EnableSwaggerBootstrapUI
public class SwaggerConfiguration {

    private final String BASE_PACKAGE = "com.flong.springboot";

    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                //此组名可以通过数据库查出来加载里面,通过模块路径进行扫描不同微服务名的包路径。
                .groupName("用户管理")
                .select()
                .apis(RequestHandlerSelectors.basePackage(BASE_PACKAGE))
                .paths(PathSelectors.any())
                .build();
    }

    /**
     * api信息
     * @return
     */
    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("Swagger RESTful APIs")
                .description("Swagger RESTful APIs")
                .termsOfServiceUrl("http://github.com/jilongliang/")
                .contact("liangjl")
                .version("1.0")
                .build();
    }
}

@ApiModel("用户实体")
public class User extends Model<User> implements Serializable {

    @TableId(type = IdType.ID_WORKER)
    @ApiModelProperty(value = "用户Id")
    private Long userId;

    /**
     * 用户名
     */
    @ApiModelProperty(value = "用户名")
    private String userName;
    /**
     * 密码
     */
    @ApiModelProperty(value = "密码")
    private String passWord;
    /**
     * 逻辑删除(0-未删除,1-已删除)
     */
    @TableLogic
    @ApiModelProperty(value = "逻辑删除(0-未删除,1-已删除)")
    private String delFlag;

    /**
     * 创建时间,允许为空,让数据库自动生成即可
     */
    @ApiModelProperty(value = "创建时间")
    private Date createTime;
}


@Api(tags = "用户管理")
@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserMapper userMapper;

    @Autowired
    private UserService userService;

    /**
     * 添加
     */
    @PutMapping("/add")
    @ApiOperation(value = "添加用户",notes = "添加用户")
    public void add() {
        userMapper.insert(User.builder().userName("周伯通").passWord("123456").build());
    }

    /**
     * 修改
     * @param user
     */
    @PutMapping("/updateById")
    @ApiOperation(value = "修改用户",notes = "通过用户Id进行修改用户信息")
    public void updateById(@RequestBody User user) {
        userMapper.updateById(user);
    }
    /**
     * 删除通过多个主键Id进行删除
     * @param ids
     */
    @DeleteMapping("/deleteByIds")
    @ApiOperation(value = "修改删除",notes = "支持多个用户Id进行删除用户")
    public void deleteByIds(@RequestBody List<String> ids) {
        userMapper.deleteBatchIds(ids);
    }

    /**
     * 通过指定Id进行查询
     *
     * @param userId
     */
    @GetMapping("/getOne/{userId}")
    @ApiOperation(value = "查询一个用户信息",notes = "通过指定Id进行查询")
    public User getOne(@PathVariable("userId") Long userId) {
        User user = userMapper.selectById(userId);
        System.out.println(JSON.toJSON(user));
        return user ;
    }

    /**
     * 用户分页,参数有多个使用下标索引进行处理.如果有两个参数(如用户名和地址):conditionList[0].fieldName=userName、 conditionList[0].fieldName=address
     * 未转码请求分页地址: http://localhost:7011/user/page?current=1&size=20&conditionList[0].fieldName=userName&conditionList[0].operation=LIKE&conditionList[0].value=周
     * 已转码请求分页地址: http://localhost:7011/user/page?current=1&size=20&conditionList[0].fieldName=userName&conditionList[0].operation=LIKE&conditionList[0].value=%E5%91%A8
     * @param page
     * @param conditions 条件
     * @return
     */
    @GetMapping("/page")
    @ApiOperation(value = "用户分页查询",notes = "通过多个条件进行查询用户信息")
    public IPage<User> page(Page page, Conditions conditions) {
        QueryWrapper<User> build = BuildConditionWrapper.build(conditions.getConditionList(), User.class);
        build.lambda().orderByDesc(User::getCreateTime);
        return userService.page(page, build);
    }


}

7、访问路径

http://localhost:7011/doc.html

8、代码工程结构与运行结构

代码实现API 代码实现API

9、工程源代码

上一篇 下一篇

猜你喜欢

热点阅读