掌桥专利:专业的专利平台
掌桥专利
首页

微服务框架的接口文档生成方法、电子设备及存储介质

文献发布时间:2023-06-19 10:57:17


微服务框架的接口文档生成方法、电子设备及存储介质

技术领域

本发明涉及前后端分离开发的模式,具体的说是一种基于微服务框架的接口文档生成方法、电子装置及存储介质。

背景技术

在Spring Cloud微服务体系下,服务采用MVC分层架构,在控制层即Controller层,需要编写代码调用业务层接口,给开发人员带来了额外的开发工作量,为此如何避免开发人员编写Controller层代码,减少开发工作量,提高开发效率成为本领域亟待解决的技术问题。

发明内容

为了改善相关技术中的不足,本发明第一方面致力于提供一种微服务框架的接口文档生成方法,所述方法基于Spring Cloud微服务框架,该方法包括:

扫描带有业务层组件注解的类,获取所述带有业务层组件注解的类中的预定方法信息;

依据所述预定方法信息构建控制层处理请求的URL;

为所述预定方法创建控制层中的接口方法,并为所述接口方法的各个参数添加注解;

根据所述控制层处理请求的URL及所述接口方法的各个参数添加的注解生成所述接口文档。

进一步的,根据所述控制层处理请求的URL及所述接口方法的各个参数添加的注解生成所述接口文档包括:为所述预设方法添加MVC请求注解,其中请求类型均为POST类型。

其中,所述预定方法信息包括方法名和方法参数。

其中当所述接口方法的参数类型为基本类型和包装类时,配置@RequestParams注解;当所述接口方法的参数为对象类型时,配置@RequestBody注解。

具体的,依据所述预定方法信息构建控制层处理请求的URL规则为:/接口名/接口方法名_参数类型1_参数类型2。

具体的,所述预定方法为公有方法。

具体的,所述接口文档为Restful接口文档。

具体的,利用反射机制获取所述带有业务层组件注解的类中的预定方法信息。

本发明的另一方面提供一种电子设备,包括:

一个或多个处理器;

存储器;

一个或多个应用程序,其中所述一个或多个应用程序被存储在所述存储器中并被配置为由所述一个或多个处理器执行,所述一个或多个程序配置用于:执行上述任一项所述的微服务框架的接口文档生成方法。

本发明的第三个方面提供一种计算机可读存储介质,所述计算机存储介质用于存储计算机指令,当其在计算机上运行时,使得计算机可以执行上述任一项所述的微服务框架的接口文档生成方法。

根据本发明提供的所述的微服务框架的接口文档生成方法、电子设备和计算机可读存储介质,通过根据业务层代码自动生成Controller层代码,开发人员无需编写Controller层代码,可以减少开发工作量,提高开发效率。

附图说明

图1为本发明基于Spring Cloud微服务框架的接口文档生成方法示意图

图2为本发明Spring Cloud微服务框架的接口文档生成电子设备的结构示意图。

具体实施方式

下面详细描述本申请的实施例,各实施例的示例在附图中示出,其中自始至终相同或类似的标号表示相同或类似的元件或具有相同或类似功能的元件。下面通过参考附图描述的实施例是示例性的,仅用于解释本申请,而不能解释为对本申请的限制。

本技术领域技术人员可以理解,除非特意声明,这里使用的单数形式“一”、“一个”和“该”也可包括复数形式。应该进一步理解的是,本申请的说明书中使用的措辞“包括”是指存在特征、整数、步骤、操作、元件和/或组件,但是并不排除存在或添加一个或多个其他特征、整数、步骤、操作、元件、组件和/或它们的组。这里使用的措辞“和/或”包括一个或更多个相关联的列出项的全部或任一单元和全部组合。

为使本申请的目的、技术方案和优点更加清楚,下面将结合附图对本申请实施方式作进一步地详细描述。

下面以具体地实施例对本申请的技术方案以及本申请的技术方案如何解决上述技术问题进行详细说明。下面这几个具体的实施例可以相互结合,对于相同或相似的概念或过程可能在某些实施例中不再赘述。下面将结合附图,对本申请的实施例进行描述。

本申请实施例提供一种微服务框架的接口文档生成方法,所述方法基于SpringCloud微服务框架,本文涉及的Spring Cloud微服务框架是一系列可配置的服务和组件,它利用Spring Boot的便利性,简化了分布式系统基础设施的开发,如配置中心、服务注册发现、负载均衡、熔断器、调用链追踪、消息总线等,可以快速构建遵循微服务架构的系统或服务。

该方法包括:扫描带有业务层组件注解的类,获取所述带有业务层组件注解的类中的预定方法信息;

扫描带有业务层组件注解的类,其中业务层在代码中使用@Service来表达,获得@Service注解的类中全部预定方法信息,预定方法信息本实施中优选带有@Service注解的类中的公有方法信息,公有方法信息可以包括方法名称和方法参数类型。

依据所述预定方法信息构建控制层处理请求的URL;其中URL(uniform resourcelocator)为统一资源定位系统是因特网的万维网服务程序上用于指定信息位置的表示方法,依据预定方法信息中的预定方法名及方法参数构建统一资源定位符URL。

为所述预定方法创建控制层中的接口方法,并为所述接口方法的各个参数添加注解;

根据所述控制层处理请求的URL及所述接口方法的各个参数添加的注解生成所述接口文档。

进一步的,根据所述控制层处理请求的URL及所述接口方法的各个参数添加的注解生成所述接口文档包括:为所述预设方法添加MVC请求注解,其中请求类型均为POST类型。

优选的,本文采用客户服务(customer-service)调用账户服务(account-service)为例阐述本发明,本实施例中账户服务的业务层包括有AccountService接口及其AccountServiceImpl实现类。

标注注解的账户服务AccountServic类中预定方法包括有通过客户ID查询账户、更新某个账户、更新多个账户,各方法具体实现代码分别如下:

(1)通过客户ID查询账户方法的代码:

ListgetAccountByCustomerId(Integer customerId)

(2)更新某个账户方法的实现代码:

public void updateAccount(Account account)

(3)更新多个账户方法的代码:

updateAccountList(Account[]account)

具体以生成接口文档为RESTful接口文档为例说明,其中RESTful架构是对MVC架构改进后所形成的一种架构,通过使用事先定义好的接口与不同的服务联系起来。在RESTful架构中,客户端使用POST,DELETE,PUT和GET四种请求方式分别对指定的URL资源进行增删改查操作,实现对资源的管理及访问。

S1:扫描带有注解@Service的类,如AccountServiceImpl。

S2、利用反射机制获取账户服务类中的3个方法,依据所述预定方法信息构建控制层处理请求的URL规则为:/接口名/接口方法名_参数类型1_参数类型2。

具体的分别生成每个方法的URL规则实现如下:

(1)生成通过客户ID查询账户方法的URL规则为:

/AccountService/getAccountByCustomerId_Integer

(2)生成更新某个账户方法的URL规则为:

/AccountService/updateAccount_Account

(3)生成更新多个账户方法的URL规则为:

/AccountService/updateAccountList_AccountXX

S3、为每个方法生成参数列表,并添加方法参数的注解。以方法(1)为例:

List getAccountByCustomerId(@RequestParam(name="customerId")IntegercustomerId){}

其中当所述接口方法的参数类型为基本类型和包装类时,配置@RequestParams注解;当所述接口方法的参数为对象类型时,配置@RequestBody注解。

S4、为每个方法添加MVC请求注解,其中请求类型均为POST类型,完成Controller层RESTful接口文档的生成。

本发明的另一方面提供一种电子设备,包括:一个或多个处理器;存储器;一个或多个应用程序,其中所述一个或多个应用程序被存储在所述存储器中并被配置为由所述一个或多个处理器执行,所述一个或多个程序配置用于:执行上述任一项所述的微服务框架的接口文档生成方法。

本发明的第三个方面提供一种计算机可读存储介质,所述计算机存储介质用于存储计算机指令,当其在计算机上运行时,使得计算机可以执行上述任一项所述的微服务框架的接口文档生成方法。

根据本发明提供的所述的微服务框架的接口文档生成方法、电子设备和计算机可读存储介质,通过根据业务层代码自动生成Controller层代码,开发人员无需编写Controller层代码,可以减少开发工作量,提高开发效率。

本申请实施例提供了一种电子设备,如图2所示,图2所示的电子设备30包括:处理器301和存储器303。其中,处理器301和存储器303相连,如通过总线302相连。进一步地,电子设备30还可以包括收发器304。需要说明的是,实际应用中收发器304不限于一个,该电子设备30的结构并不构成对本申请实施例的限定。其中,处理器301应用于本申请实施例中,用于生成接口文档的功能。收发器304包括接收机和发射机。

处理器301可以是CPU,通用处理器,DSP,ASIC,FPGA或者其他可编程逻辑器件、晶体管逻辑器件、硬件部件或者其任意组合。其可以实现或执行结合本申请公开内容所描述的各种示例性的逻辑方框,模块和电路。处理器301也可以是实现计算功能的组合,例如包含一个或多个微处理器组合,DSP和微处理器的组合等。

总线302可包括一通路,在上述组件之间传送信息。总线302可以是PCI总线或EISA总线等。总线302可以分为地址总线、数据总线、控制总线等。为便于表示,图2中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。

存储器303可以是ROM或可存储静态信息和指令的其他类型的静态存储设备,RAM或者可存储信息和指令的其他类型的动态存储设备,也可以是EEPROM、CD-ROM或其他光盘存储、光碟存储(包括压缩光碟、激光碟、光碟、数字通用光碟、蓝光光碟等)、磁盘存储介质或者其他磁存储设备、或者能够用于携带或存储具有指令或数据结构形式的期望的程序代码并能够由计算机存取的任何其他介质,但不限于此。

存储器303用于存储执行本申请方案的应用程序代码,并由处理器301来控制执行。处理器301用于执行存储器303中存储的应用程序代码,以实现实施例提供的微服务框架的接口文档生成方法的功能。

本申请实施例提供了一种电子设备,与相关技术相比,通过本发明根据业务层代码自动生成Controller层代码,开发人员无需编写Controller层代码,可以减少开发工作量,提高开发效率。

本申请实施例提供了一种电子设备适用于上述方法实施例。在此不再赘述。

本申请实施例提供了一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,该程序被处理器执行时实现上述实施例中所示的方法。

本申请实施例提供了一种计算机可读存储介质,与相关技术相比,通过本发明根据业务层代码自动生成Controller层代码,开发人员无需编写Controller层代码,可以减少开发工作量,提高开发效率。

应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。

以上仅是本申请的部分实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本申请原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视为本申请的保护范围。

相关技术
  • 微服务框架的接口文档生成方法、电子设备及存储介质
  • 微服务框架的接口文件生成方法、电子设备及存储介质
技术分类

06120112741028