栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Springboot 整合 knife4j openApi文档

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Springboot 整合 knife4j openApi文档


依赖
这里我们直接使用springboot内部集成的版本

 
     com.github.xiaoymin
     knife4j-spring-boot-starter
 

添加配置类

@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 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 logout() {
        StpUtil.logout();
        return success();
    }

    @ApiOperation(value = "获取用户信息")
    @GetMapping(value = "/info")
    public BizResult 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 isLogin() {
        return success("当前会话是否登录:" + StpUtil.isLogin());
    }

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

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

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

    }

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


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


转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号