YDoc使用图文攻略(基于YDoc1.0.3)

YDoc使用图文攻略

1.0.3版本可能会在swagger上嵌套显示不全的问题已经修复并重新发布预计6.5号以后恢复正常(着急可以点个Star,clone工程到本地install下即可,https://github.com/NoBugBoy/YDoc)

通用步骤

  1. 创建一个springboot的web工程
    在这里插入图片描述
  2. 创建一个controller和一个pojo对象
//省略了get set 。。。
public class User {
   private Long id;
   private String name;
   private List<Order> us;
   private UserType type;
   public static class Order {
       private String     name;
       private BigDecimal price;
   }
}
// user Type是一个枚举类型
public enum UserType {
   ADMIN(0,"管理员"), SUPERMAN(1,"超人");
   UserType(int code,String description){
       this.code = code;
       this.description =description;

   };
   private int code;
   private String description;

}

控制器代码

@RestController
public class TestController {
   @GetMapping(value = "/get/{id}")
   public User test(@PathVariable(value = "id",name = "id") String id){
       User u = new User();
       return u;
   }
   @GetMapping(value = "/last")
   public User test(User user){
       return user;
   }
   @PostMapping(value = "/post")
   public User test1(@RequestBody User user){
       System.out.println(user);
       return user;
   }
   }
  
 

依赖maven库

      <dependency>
           <groupId>com.github.nobugboy</groupId>
           <artifactId>ydoc-spring-boot-starter</artifactId>
           <version>1.0.3</version>
       </dependency>

application.properties添加一条配置

    ydoc.enable=true

以上就是通用的基础环境,在平时的开发工程上只需额外依赖maven库和加一条配置即可

1. SwaggerUi方式
  1. 如果使用 SwaggerUi方式,需在启动类或配置类上加@EnableSwagger2
  2. 没了。就多了上面这一个操作
开始使用
  1. 启动工程,看到如下提示证明启动成功
    在这里插入图片描述
  2. 访问http://localhost:8080/doc.html(如果修改了端口对应改一下)

在这里插入图片描述

  1. 此时接口文档已经生成,只是不太友好,我们来进行一下简单的改造(yapi的改造和该方式一致,下面就不重复该步骤)
@RestController(value = "用户相关接口")
public class TestController {
    @GetMapping(value = "/get/{id}",name = "根据id获取用户")
    public User test(@PathVariable(value = "id",name = "id") String id){
        User u = new User();
        return u;
    }
    @GetMapping(value = "/last",name = "get请求测试参数描述")
    public User test(User user){
        return user;
    }
    @PostMapping(value = "/post",name = "post请求测试参数描述")
    public User test1(@RequestBody User user){
        System.out.println(user);
        return user;
    }
}

public class User {
    @ParamDesc("用户主键id")
    private Long id;
    @ParamDesc("用户名称")
    private String name;
    @ParamDesc("订单集合")
    private List<Order> us;
    @ParamDesc("用户类型")
    private UserType type;

    public static class Order {
        @ParamDesc("订单名称")
        private String     name;
        @ParamDesc("价格")
        private BigDecimal price;
    }
}
//枚举类型重写了toString方法
public enum UserType {
    ADMIN(0,"管理员"), SUPERMAN(1,"超人");
    UserType(int code,String description){
        this.code = code;
        this.description =description;

    };
    private int code;
    private String description;
    @Override
    public String toString() {
        return Arrays.stream(values())
            .map(v -> v.code +"=" + v.description)
            .collect(Collectors.joining(","));
    }

}
  1. 重写启动程序,此时已经变成了非常友好的显示

在这里插入图片描述
发送一次请求试试
在这里插入图片描述

2. YApi方式
  1. 安装YAPI
  2. 配置项目token和YApi url即可

在YApi创建好项目,然后获取项目token,url就是访问YApi页面的路径即可
在这里插入图片描述

  1. 在配置文件加入两行配置
ydoc.enable=true
ydoc.host=http://localhost:3000
ydoc.token=265edcb30a90a9e3eaf2209c5ac04a7cfcf290ce36ef7218101f4ddfec321964
  1. 没了。就多了上面这一个操作
开始使用
  1. 启动工程,访问yapi页面,接口已经有了
    在这里插入图片描述
    此时所有文档已经生成完毕,点击mock地址可以发送随机mock参数。
    在这里插入图片描述
    发送一次请求试试(警告可以忽略,原因是枚举默认是数值类型)
    在这里插入图片描述

如果发现YApi请求不到多半是路径不对,远程的YApi也支持访问本地的localhost的server,添加多个环境即可

在这里插入图片描述

Swagger原生模式(本质是为了兼容已经使用了Swagger配置的工程)

对于已经使用了swagger的工程来讲引入依赖,并开启native模式

ydoc.swagger-native=true

如果想要在程序启动时同步导入到YApi直接加入下面配置即可

ydoc.host=http://localhost:3000
ydoc.token=265edcb30a90a9e3eaf2209c5ac04a7cfcf290ce36ef7218101f4ddfec321964
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
ModuleNotFoundError: No module named 'jupyter_server_ydoc' 这个错误是由于没有找到名为'jupyter_server_ydoc的模块导致的。 根据提供的引用,可以看到您尝试安装了一个名为'jupyter_nbextensions_configurator'的服务器扩展,但是未能成功加载该扩展。可能是因为您的系统中没有安装这个扩展导致的。 要解决这个问题,您可以尝试以下方法: 1. 使用命令`python -m pip install jupyter_nbextensions_configurator`来安装'jupyter_nbextensions_configurator'模块。 2. 确保您的pip可以正常连接到互联网,可以尝试使用清华大学镜像源安装jupyter_server模块,可以使用命令`pip install jupyter_server -i https://pypi.tuna.tsinghua.edu.cn/simple`来安装。 请确保在执行这些命令之前,您已经正确安装了Python和Jupyter Notebook,并且使用了正确的命令提示符。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [启动jupyter 时报错](https://blog.csdn.net/Candylx/article/details/127547915)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [ModuleNotFoundError: No module named ‘jupyter_server](https://blog.csdn.net/weixin_46713695/article/details/126332886)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值