Springboot 整合 knife4j openApi文档

在这里插入图片描述
依赖
这里我们直接使用springboot内部集成的版本

 <dependency>
     <groupId>com.github.xiaoymin</groupId>
     <artifactId>knife4j-spring-boot-starter</artifactId>
 </dependency>

添加配置类

@Configuration
@EnableSwagger2
@EnableKnife4j
public class Knife4jConfig {

    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .useDefaultResponseMessages(false)
                .apiInfo(apiInfo())
                .select()
                // 配置api扫包范围
                .apis(RequestHandlerSelectors.basePackage("com.doria.saToken"))
                .paths(PathSelectors.any())
                .build();

    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                // 配置文档简介
                .description("SaToken-Demo Document")
                // 配置作者信息
                .contact(new Contact("哈哈哈", "https://github.com.lenve", "1916008067@qq.com"))
                // 版本号
                .version("v1.1.0")
                // 标题
                .title("API测试文档")
                .build();
    }
}

使用

// 描述实体类
@ApiModel(value = "用户信息")
public class SysUser {

	// 描述属性
    @ApiModelProperty(value = "id")
    private Long id;
    @ApiModelProperty(value = "名称")
    private String name;
    @ApiModelProperty(value = "性别")
    private String gender;
    @ApiModelProperty(value = "年龄")
    private Integer age;

    public SysUser(Long id, String name) {
        this.id = id;
        this.name = name;
    }
}
// 描述Controller
@Api(tags = "测试文档")
@RestController
@RequestMapping(value = "/test")
public class TestController {

    // 描述接口
    @ApiOperation(value = "登录")
    @PostMapping(value = "/login")
    public BizResult<SysUser> login(@RequestBody @Valid LoginDto loginDto) {
        if (!loginDto.getUsername().equals(UserConfig.username)) {
            return fail();
        }
        if (!loginDto.getPassword().equals(UserConfig.password)) {
            return fail();
        }
        StpUtil.login(556L);
        SysUser user = new SysUser(556L, "法外狂徒张三", "man", 18);
        return success(user);
    }

    @ApiOperation(value = "退出登录")
    @PutMapping(value = "/logout")
    public BizResult<String> logout() {
        StpUtil.logout();
        return success();
    }

    @ApiOperation(value = "获取用户信息")
    @GetMapping(value = "/info")
    public BizResult<UserInfo> info() {
        if (!StpUtil.isLogin())
            throw new NotLoginException("没登陆", "user not login", "un login");
        return success(new UserInfo(556L, "法外狂徒张三", "woman", 19));
    }

    @ApiOperation(value = "查询当前会话是否登录")
    @GetMapping(value = "/isLogin")
    public BizResult<String> isLogin() {
        return success("当前会话是否登录:" + StpUtil.isLogin());
    }

    @ApiOperation(value = "获取当前用户userId")
    @GetMapping(value = "/getUserId")
    public BizResult<String> getUserId() {
        return success("用户id为" + StpUtil.getLoginIdAsLong());
    }

    @ApiOperation(value = "获取当前用户权限")
    @GetMapping(value = "getPermission")
    public BizResult<Object> getUserPermission() {
        return success(StpUtil.getPermissionList());
    }

    @ApiOperation(value = "获取当前用户角色")
    @GetMapping(value = "getUserRole")
    public BizResult<Object> getUserRole() {
        return success(StpUtil.getRoleList());

    }

    @ApiOperation(value = "检查当前用户是否拥有角色")
    @PostMapping(value = "/checkRole")
    // 描述参数
    @ApiImplicitParam(value = "角色",name = "role",required = true)
    public BizResult<Object> checkRole(@RequestParam String role) {
        StpUtil.checkRole(role);
        return success(StpUtil.hasRole(role));
    }

    @ApiOperation(value = "检查当前用户是否拥有权限")
    @PostMapping(value = "/checkPermission")
    @ApiImplicitParam(value = "权限",name = "permission",required = true)
    public BizResult<Object> checkPermission(@RequestParam String permission) {
        StpUtil.checkPermission(permission);
        return success(StpUtil.hasPermission(permission));
    }


    @ApiOperation(value = "将指定用户踢下线")
    @PutMapping(value = "/kickoutUser")
    public BizResult<Object> kickoutUser(@RequestParam Long userId){
        StpUtil.checkRole("admin");
        SaTokenInfo tokenInfo = StpUtil.getTokenInfo();
        System.out.println(tokenInfo);
        StpUtil.kickout(userId);
        return success();
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值