.Net6 API Swagger 点击展开报错子层级实体不显示

在这里插入图片描述

报错
Could not resolve reference: Could not resolve pointer: /components/schemas/Model.RequsetModels.BPC+Details does not exist in document
我的实体类结构是如下:嵌套子层级

  public class BPC
  {
        public string BP { get; set; }
        public List<Details> Detail { get; set; }
        public class Details
        {
            public string ML { get; set; }
            public string BP { get; set; }
        }
  }

经排查生成Swagger Json 的时候 层级相关联的默认用的是加号 ,从而得知 Model.RequsetModels.BPC+Details 的 “+” 加号是出错,我尝试更新swagger 最新版本仍未解决

最终处理方式 加号替换成点 解决

services.AddSwaggerGen(c =>
{
c.CustomSchemaIds(s => s.FullName?.Replace(“+”, “.”));
}

参考 链接: https://stackoverflow.com/questions/73571160/could-not-resolve-pointer-components-schemas-when-nested-model-and-custom-sche
参考 链接: https://github.com/swagger-api/swagger-ui/issues/7911

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
如果你在使用 Swagger 2.4.0 时遇到了实体类不显示的问题,可能是因为你的实体类没有添加正确的注解或者路径配置不正确。 首先,确保你已经在实体类上添加了 `@ApiModel` 注解,该注解用于指定实体类的名称和描述,例如: ```java @ApiModel(value = "User", description = "用户信息") public class User { ... } ``` 其次,你需要在实际使用该实体类的 API 方法上添加 `@ApiOperation` 注解,并指定请求参数的路径和参数类型,例如: ```java @ApiOperation(value = "添加用户", notes = "根据 User 对象添加用户") @ApiImplicitParam(name = "user", value = "用户实体类", required = true, dataType = "User") @RequestMapping(value = "/addUser", method = RequestMethod.POST) public String addUser(@RequestBody User user) { ... } ``` 注意,这里的 `dataType` 属性应该与实体类的名称保持一致,否则 Swagger 将无法正确识别该实体类。 最后,你需要确保 Swagger 的配置文件中包含了正确的路径,例如: ```java @Configuration @EnableSwagger2 public class SwaggerConfig { @Bean public Docket api() { return new Docket(DocumentationType.SWAGGER_2) .select() .apis(RequestHandlerSelectors.basePackage("com.example.demo")) .paths(PathSelectors.any()) .build(); } } ``` 其中,`RequestHandlerSelectors.basePackage` 方法指定了需要扫描的 API 包路径,而 `PathSelectors.any()` 方法则表示扫描所有路径。如果你的实体类路径没有被正确扫描到,Swagger 将无法显示实体类。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值