CN115686475A - 标准化服务sdk自动化生成方法及其相关设备 - Google Patents
标准化服务sdk自动化生成方法及其相关设备 Download PDFInfo
- Publication number
- CN115686475A CN115686475A CN202211429884.3A CN202211429884A CN115686475A CN 115686475 A CN115686475 A CN 115686475A CN 202211429884 A CN202211429884 A CN 202211429884A CN 115686475 A CN115686475 A CN 115686475A
- Authority
- CN
- China
- Prior art keywords
- preset
- annotation
- packaging
- software development
- generating
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Landscapes
- Stored Programmes (AREA)
Abstract
本申请实施例属于研发领域,应用于服务SDK协同开发领域中,涉及一种标准化服务SDK自动化生成方法及其相关设备,包括获取API源码中的注解信息;从中筛选出方法注解描述,将方法注解描述生成唯一标记的数据;并以描述对象存储到预设数据库;将描述对象打包并展示到预设开发协同界面;根据目标描述对象生成对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。本申请通过一个中间对象即描述对象,实现多开发者间的开发协调管理,避免了对程序源代码的多次上传和下载操作,使得开发协同界面的API文档始终处于第一版本状态,为不同平台提供一个统一标准的服务SDK自动化生成方法,保证API文档版本的统一性和易维护性。
Description
技术领域
本申请涉及服务SDK协同开发技术领域,尤其涉及一种标准化服务SDK自动化生成方法及其相关设备。
背景技术
现在大多数混合式开发的客户端APP有很多的对外服务接口,例如金融场景中有关保险业务的开发,由于保险险种和业务项目的繁杂性,需要开发很多对外服务接口,目前的开发情况是这样的,客户端提供了大量的对外方法,但对外服务的方法没有统一,也没有任何注释表明方法的作用,很多情况下每重复注册一遍,就需要重复发布一遍,但很多对外方法却仅限于几个人知道,靠口口相传,或者维护一个公共的API文档进行对外方法维护。
API文档若是独立于运行的代码之外,无论是采用Word、Excel,网页直输等脱离代码的方式,容易出现API文档版本众多,维护和发布困难,代码变更后文档说明与代码功能不一致等问题,并且极易出现因人工书写错误,可靠性低,这对对接方和二次开发者及其不友好,因此,目前服务SDK开发过程中存在API文档版本不统一,经不同开发人员进行多次更改后,易造成维护困难、发布困难的问题。
发明内容
本申请实施例的目的在于提出一种标准化服务SDK自动化生成方法及其相关设备,以便于为不同平台提供一个统一标准的服务SDK自动化生成方法,保证API文档版本的统一性和易维护性。
为了解决上述技术问题,本申请实施例提供一种标准化服务SDK自动化生成方法,采用了如下所述的技术方案:
一种标准化服务SDK自动化生成方法,包括下述步骤:
根据预设注解处理器,获取API源码中的注解信息,其中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本;
从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;
将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;
接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;
根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;
基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。
进一步的,所述从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据的步骤,具体包括:
获取筛选出的所述API源码中所有的方法注解描述;
将所述所有的方法注解描述作为一个整体对象,进行序列化处理,获取序列化处理结果;
将所述序列化处理结果作为输入流进行MD5值处理,获取MD5值,将所述MD5值作为所述唯一标记的数据,为所述MD5值设置唯一标识作为所述描述对象。
进一步的,所述将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库的步骤,具体包括:
将所述MD5值作为哈希值,将所述描述对象作为与所述哈希值相匹配的哈希对象,成对缓存入所述预设数据库,其中,所述描述对象可以按照开发时的包名、类名、方法名、返回值进行逐级拼接命名。
进一步的,在所述将所述MD5值作为哈希值,将所述描述对象作为与所述哈希值相匹配的哈希对象,成对缓存入所述预设数据库的步骤之后,所述方法还包括:
在所述预设数据库中生成一个和所述MD5值相对应的自增式版本号信息;
为所述MD5值、所述描述对象和所述版本号信息建立关联关系,并为所述MD5值、所述描述对象和所述版本号信息分别设置对应的入库时间戳。
进一步的,所述为生成目标服务对应的软件开发工具包而发出的打包指令中包括所述软件开发工具包的打包路径,所述接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果的步骤,具体包括:
在接收到所述打包指令之后,对所述打包指令进行解析,获取所述打包路径。
进一步的,所述根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面的步骤,具体包括:
根据所述打包路径和所述不同打包条件,将所述MD5值对应的所述自增式版本号信息展示到所述开发协同界面,其中,所述不同打包条件指打包时所使用的不同压缩工具。
进一步的,所述根据预设代码生成器生成所述软件开发工具包所对应的代码程序的步骤,具体包括:
预先定义所述代码生成器的通用方法协议;
获取目标描述对象对应的方法调用数组,其中,所述方法调用数组中包括:方法名、调用参数和返回值;
对所述方法调用数组进行解析,获取方法名、调用参数和返回值;
将所述方法名、调用参数和返回值作为所述通用方法协议的入参参数,调用所述代码生成器,生成所述软件开发工具包所对应的代码程序。
为了解决上述技术问题,本申请实施例还提供一种标准化服务SDK自动化生成装置,采用了如下所述的技术方案:
一种标准化服务SDK自动化生成装置,包括:
注解信息获取模块,用于根据预设注解处理器,获取API源码中的注解信息,其中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本;
方法注解转码模块,用于从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;
中间对象存储模块,用于将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;
打包指令解析模块,用于接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;
打包处理模块,用于根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;
服务SDK生成模块,用于基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。
为了解决上述技术问题,本申请实施例还提供一种计算机设备,采用了如下所述的技术方案:
一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机可读指令,所述处理器执行所述计算机可读指令时实现上述所述的标准化服务SDK自动化生成方法的步骤。
为了解决上述技术问题,本申请实施例还提供一种计算机可读存储介质,采用了如下所述的技术方案:
一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机可读指令,所述计算机可读指令被处理器执行时实现如上述所述的标准化服务SDK自动化生成方法的步骤。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例所述标准化服务SDK自动化生成方法,根据预设注解处理器,获取API源码中的注解信息,其中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本;从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。本申请通过一个中间对象即描述对象,实现多开发者间的开发协调管理,避免了对程序源代码的多次上传和下载操作,使得二次开发者在开发时不会操作到API文档,保证整个开发平台的API文档版本的统一性和易维护性。
附图说明
为了更清楚地说明本申请中的方案,下面将对本申请实施例描述中所需要使用的附图作一个简单介绍,显而易见地,下面描述中的附图是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请可以应用于其中的示例性***架构图;
图2根据本申请的标准化服务SDK自动化生成方法的一个实施例的流程图;
图3是图2所示步骤202的一种具体实施方式的流程图;
图4是图2所示步骤206的一种具体实施方式的流程图;
图5根据本申请的标准化服务SDK自动化生成装置的一个实施例的结构示意图;
图6根据本申请的计算机设备的一个实施例的结构示意图。
具体实施方式
除非另有定义,本文所使用的所有的技术和科学术语与属于本申请的技术领域的技术人员通常理解的含义相同;本文中在申请的说明书中所使用的术语只是为了描述具体的实施例的目的,不是旨在于限制本申请;本申请的说明书和权利要求书及上述附图说明中的术语“包括”和“具有”以及它们的任何变形,意图在于覆盖不排他的包含。本申请的说明书和权利要求书或上述附图中的术语“第一”、“第二”等是用于区别不同对象,而不是用于描述特定顺序。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其它实施例相结合。
为了使本技术领域的人员更好地理解本申请方案,下面将结合附图,对本申请实施例中的技术方案进行清楚、完整地描述。
如图1所示,***架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如网页浏览器应用、购物类应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving PictureExpertsGroup Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(MovingPictureExperts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103上显示的页面提供支持的后台服务器。
需要说明的是,本申请实施例所提供的标准化服务SDK自动化生成方法一般由服务器/终端设备执行,相应地,标准化服务SDK自动化生成装置一般设置于服务器/终端设备中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了根据本申请的标准化服务SDK自动化生成方法的一个实施例的流程图。所述的标准化服务SDK自动化生成方法,包括以下步骤:
步骤201,根据预设注解处理器,获取API源码中的注解信息。
本实施例中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本。
本实施例中,所述软件开发工具包可以理解为服务的源码程序,开发者方可通过二次开发该服务的源码程序进行服务程序更新、补丁更新,客户端方可通过下载该服务的源码程序进行服务程序安装使用。
本实施例中,所述根据预设注解处理器,获取API源码中的注解信息的步骤中,所述预设注解处理器包括:用于处理JAVA源代码中注解内容的工具,或/和Gradle支持的Annotation Processing Tool(APT)源码处理器。
本实施例中,注解处理器使用JAVA源代码中注解内容的工具,或/和Gradle支持的Annotation Processing Tool(APT)源码处理器,其优点主要为充分发挥了java编译语言的特性,支持在目前主要操作***如Windows、Linux、Android和IOS上进行注解编译及处理;Gradle工具,仅需要安装Java JDK 8.0以上版本,也支持在目前主要操作***如Windows、Linux、Android和IOS上进行注解编译及处理,保证了注解处理器的多操作***兼容性。
步骤202,从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据。
本实施例中,所述从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据的步骤,具体包括:获取筛选出的所述API源码中所有的方法注解描述;将所述所有的方法注解描述作为一个整体对象,进行序列化处理,获取序列化处理结果;将所述序列化处理结果作为输入流进行MD5值处理,获取MD5值,将所述MD5值作为所述唯一标记的数据,为所述MD5值设置唯一标识作为所述描述对象。
通过将所有的方法注解描述转码为一个整体对象,并对该整体对象进行序列化处理,再进行MD5处理,使得方法注解描述整合到一个对象内,便于直接通过该对象进行方法注解获取,该方式相比于现有对每个方法注解描述分别进行处理,第一,减少了注解对象的生成个数,在处理器进行对象生成时,相比节省了多对象创建时的资源消耗,第二,将同一个服务程序的方法注解描述整合到一个对象内,做到只根据该对象即可获得所述服务程序的完整方法注解描述,保持了注解获取的整体性和完整性。
继续参考图3,图3是图2所示步骤202的一种具体实施方式的流程图,包括:
步骤301,获取筛选出的所述API源码中所有的方法注解描述;
本实施例中,所述获取筛选出的所述API源码中所有的方法注解描述的具体实现方式为:根据预设注解说明符号,获取所述API源码中所有的方法注解描述,其中,所述注解说明符号为所述API源码中所使用的注解说明符号。例如,API源码中使用了注解说明符号/**...*/,则将所述注解说明符号/**...*/作为所述预设注解说明符号中的一个注解说明符号。
步骤302,将所述所有的方法注解描述作为一个整体对象,进行序列化处理,获取序列化处理结果;
本实施例中,所述将所述所有的方法注解描述作为一个整体对象,进行序列化处理,获取序列化处理结果的具体实现方式为:将获取到的所述所有的方法注解描述以字节流的形式输出到一个目标文件内;并按照每个方法注解描述所对应的方法的不同,在所述字节流中设置区别间隔符,即完成序列化处理;获取所述目标文件内的字节流对应的一维序列,即获取序列化处理结果。
通过在序列化处理时,根据方法注解描述对应的方法的不同,在所述字节流中设置区别间隔符,保证了每个方法注解描述在所述整体对象中的相对独立性。
步骤303,将所述序列化处理结果作为输入流进行MD5值处理,获取MD5值,将所述MD5值作为所述唯一标记的数据,为所述MD5值设置唯一标识作为所述描述对象。
本实施例中,所述将所述序列化处理结果作为输入流进行MD5值处理,获取MD5值的具体实现方式为:将所述序列化处理结果以输入流的形式,输入到MD5值生成器中,以所述序列化处理结果为待处理数据,生成所述序列化处理结果对应的MD5值,即所述方法注解描述对应的唯一标记的数据。
通过MD5值生成的方式,保证了方法注解描述对应的标记数据的唯一性。
步骤203,将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库。
本实施例中,所述将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库的步骤,具体包括:将所述MD5值作为哈希值,将所述描述对象作为与所述哈希值相匹配的哈希对象,成对缓存入所述预设数据库,其中,所述描述对象可以按照开发时的包名、类名、方法名、返回值进行逐级拼接命名。
本实施例中,将所述MD5值对应的描述对象按照开发时的包名、类名、方法名、返回值进行逐级拼接命名,实质上是直接将源程序的开发路径及对应返回值作为描述对象,不再暴露方法注解描述,仅暴露程序调用路径及对应返回值,便于后期开发者进行更新和客户端进行下载安装时,直接通过调用路径及对应返回值获取服务程序,无需再关注方法注解描述。
本实施例中,在所述将所述MD5值作为哈希值,将所述描述对象作为与所述哈希值相匹配的哈希对象,成对缓存入所述预设数据库的步骤之后,所述方法还包括:在所述预设数据库中生成一个和所述MD5值相对应的自增式版本号信息;为所述MD5值、所述描述对象和所述版本号信息建立关联关系,并为所述MD5值、所述描述对象和所述版本号信息分别设置对应的入库时间戳。
本实施例中,所述自增式版本号信息的生成方式,具体为:采用累加的方式,在每当有二次开发者进行版本更新并再次上传API源码之后,重复执行步骤201至步骤203,进行版本号累加更新,例如,本次二次开发之前API源码对应的版本号为2.0.0,则本次二次开发之后API源码对应的版本号可以采用末尾数字累加1的形式进行更新,将所述版本号2.0.0更新为2.0.1。
通过设置入库时间戳和自增式版本号信息,便于二次开发者在程序更新开发时直接获取最新API源码,保证了多开发者对同一API源码同时开发时,每个最新开发者都能获取到最新API源码,便于进行线上开发管理。
步骤204,接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果。
本实施例中,所述为生成目标服务对应的软件开发工具包而发出的打包指令中包括所述软件开发工具包的打包路径,所述接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果的步骤,具体包括:在接收到所述打包指令之后,对所述打包指令进行解析,获取所述打包路径。
步骤205,根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面。
本实施例中,所述根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面的步骤,具体包括:根据所述打包路径和所述不同打包条件,将所述MD5值对应的所述自增式版本号信息展示到所述开发协同界面,其中,所述不同打包条件指打包时所使用的不同压缩工具。
通过所述打包路径将最新API源码对应的服务SDK以自增式版本号信息的形式发布到预设的开发协同界面,便于多开发者对同一API源码同时开发时,每个最新开发者都能获取到最新的服务程序版本,便于进行线上开发管理。
本实施例中,所述打包时所使用的不同压缩工具实质为打包为不同编译语言所使用的打包压缩工具,例如打包为Java语言所使用的jar打包工具、打包为JS和RN语言所使用的webpack打包工具等,其目的是为了在开发协同界面生成适配多种开发语言的程序开发包,便于协调多编译语言进行程序二次开发,避免了单编译语言开发时导致的编译局限性。
步骤206,基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。
本实施例中,所述根据预设代码生成器生成所述软件开发工具包所对应的代码程序的步骤,具体包括:预先定义所述代码生成器的通用方法协议;获取目标描述对象对应的方法调用数组,其中,所述方法调用数组中包括:方法名、调用参数和返回值;对所述方法调用数组进行解析,获取方法名、调用参数和返回值;将所述方法名、调用参数和返回值作为所述通用方法协议的入参参数,调用所述代码生成器,生成所述软件开发工具包所对应的代码程序。
通过所述代码生成器的通用方法协议和目标描述对象对应的方法调用数组生成所述软件开发工具包所对应的代码程序,使得二次开发者在进行开发时,无需盲目的整体下载所有源程序代码,仅需要根据开发更新需求,获取待更新部分对应方法所对应的描述对象,即可生成该待更新部分的最新源码程序,一定程度上减少了开发者的源码下载量。
继续参考图4,图4是图2所示步骤206的一种具体实施方式的流程图,包括:
步骤401,预先定义所述代码生成器的通用方法协议;
步骤402,获取目标描述对象对应的方法调用数组,其中,所述方法调用数组中包括:方法名、调用参数和返回值;
步骤403,对所述方法调用数组进行解析,获取方法名、调用参数和返回值;
步骤404,将所述方法名、调用参数和返回值作为所述通用方法协议的入参参数,调用所述代码生成器,生成所述软件开发工具包所对应的代码程序。
本申请根据预设注解处理器,获取API源码中的注解信息,其中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本;从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;将所述软件开发工具包打包并展示到预设开发协同界面,将所述描述对象打包并展示到预设开发协同界面;基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。本申请通过一个中间对象即描述对象,实现多开发者间的开发协调管理,避免了对程序源代码的多次上传和下载操作,使得二次开发者在开发时不会操作到API文档,保证整个开发平台的API文档版本的统一性和易维护性。
本申请实施例可以基于人工智能技术对相关的数据进行获取和处理。其中,人工智能(Artificial Intelligence,AI)是利用数字计算机或者数字计算机控制的机器模拟、延伸和扩展人的智能,感知环境、获取知识并使用知识获得最佳结果的理论、方法、技术及应用***。
人工智能基础技术一般包括如传感器、专用人工智能芯片、云计算、分布式存储、大数据处理技术、操作/交互***、机电一体化等技术。人工智能软件技术主要包括计算机视觉技术、机器人技术、生物识别技术、语音处理技术、自然语言处理技术以及机器学习/深度学习等几大方向。
本申请实施例中,可利用智能托管模型的方式托管本实施中所述的标准化服务SDK自动化生成方法,在服务SDK程序更新时,自动化使用该智能托管模型进行描述对象更新和服务SDK版本号更新,减少了人为更新时的工作量,更加智能化和自动化。
进一步参考图5,作为对上述图2所示方法的实现,本申请提供了一种标准化服务SDK自动化生成装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图5所示,本实施例所述的标准化服务SDK自动化生成装置500包括:注解信息获取模块501、方法注解转码模块502、中间对象存储模块503、打包指令解析模块504、打包处理模块505和服务SDK生成模块506。
其中:
注解信息获取模块501,用于根据预设注解处理器,获取API源码中的注解信息,其中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本;
方法注解转码模块502,用于从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;
中间对象存储模块503,用于将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;
打包指令解析模块504,用于接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;
打包处理模块505,用于根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;
服务SDK生成模块506,用于基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。
本申请根据预设注解处理器,获取API源码中的注解信息,其中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本;从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。本申请通过一个中间对象即描述对象,实现多开发者间的开发协调管理,避免了对程序源代码的多次上传和下载操作,使得二次开发者在开发时不会操作到API文档,保证整个开发平台的API文档版本的统一性和易维护性。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机可读指令来指令相关的硬件来完成,该计算机可读指令可存储于计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,前述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)等非易失性存储介质,或随机存储记忆体(Random Access Memory,RAM)等。
应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
为解决上述技术问题,本申请实施例还提供计算机设备。具体请参阅图6,图6为本实施例计算机设备基本结构框图。
所述计算机设备6包括通过***总线相互通信连接存储器61、处理器62、网络接口63。需要指出的是,图中仅示出了具有组件61-63的计算机设备6,但是应理解的是,并不要求实施所有示出的组件,可以替代的实施更多或者更少的组件。其中,本技术领域技术人员可以理解,这里的计算机设备是一种能够按照事先设定或存储的指令,自动进行数值计算和/或信息处理的设备,其硬件包括但不限于微处理器、专用集成电路(ApplicationSpecific Integrated Circuit,ASIC)、可编程门阵列(Field-Programmable GateArray,FPGA)、数字处理器(Digital Signal Processor,DSP)、嵌入式设备等。
所述计算机设备可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述计算机设备可以与用户通过键盘、鼠标、遥控器、触摸板或声控设备等方式进行人机交互。
所述存储器61至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等。在一些实施例中,所述存储器61可以是所述计算机设备6的内部存储单元,例如该计算机设备6的硬盘或内存。在另一些实施例中,所述存储器61也可以是所述计算机设备6的外部存储设备,例如该计算机设备6上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(FlashCard)等。当然,所述存储器61还可以既包括所述计算机设备6的内部存储单元也包括其外部存储设备。本实施例中,所述存储器61通常用于存储安装于所述计算机设备6的操作***和各类应用软件,例如标准化服务SDK自动化生成方法的计算机可读指令等。此外,所述存储器61还可以用于暂时地存储已经输出或者将要输出的各类数据。
所述处理器62在一些实施例中可以是中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器、或其他数据处理芯片。该处理器62通常用于控制所述计算机设备6的总体操作。本实施例中,所述处理器62用于运行所述存储器61中存储的计算机可读指令或者处理数据,例如运行所述标准化服务SDK自动化生成方法的计算机可读指令。
所述网络接口63可包括无线网络接口或有线网络接口,该网络接口63通常用于在所述计算机设备6与其他电子设备之间建立通信连接。
本实施例提出的计算机设备,属于服务SDK协同开发技术领域。本申请根据预设注解处理器,获取API源码中的注解信息,其中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本;从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。本申请通过一个中间对象即描述对象,实现多开发者间的开发协调管理,避免了对程序源代码的多次上传和下载操作,使得二次开发者在开发时不会操作到API文档,保证整个开发平台的API文档版本的统一性和易维护性
本申请还提供了另一种实施方式,即提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可读指令,所述计算机可读指令可被处理器执行,以使所述处理器执行如上述的标准化服务SDK自动化生成方法的步骤。
本实施例提出的计算机可读存储介质,属于服务SDK协同开发技术领域。本申请根据预设注解处理器,获取API源码中的注解信息,其中,所述注解信息指为实现所述API源码自动化部署和生成软件开发工具包而预先编写的注解文本;从所述注解信息中筛选出所述API源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。本申请通过一个中间对象即描述对象,实现多开发者间的开发协调管理,避免了对程序源代码的多次上传和下载操作,使得二次开发者在开发时不会操作到API文档,保证整个开发平台的API文档版本的统一性和易维护性。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本申请各个实施例所述的方法。
显然,以上所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例,附图中给出了本申请的较佳实施例,但并不限制本申请的专利范围。本申请可以以许多不同的形式来实现,相反地,提供这些实施例的目的是使对本申请的公开内容的理解更加透彻全面。尽管参照前述实施例对本申请进行了详细的说明,对于本领域的技术人员来而言,其依然可以对前述各具体实施方式所记载的技术方案进行修改,或者对其中部分技术特征进行等效替换。凡是利用本申请说明书及附图内容所做的等效结构,直接或间接运用在其他相关的技术领域,均同理在本申请专利保护范围之内。
Claims (10)
1.一种标准化服务SDK自动化生成方法,其特征在于,包括下述步骤:
根据预设注解处理器,获取AP I源码中的注解信息,其中,所述注解信息指为实现所述AP I源码自动化部署和生成软件开发工具包而预先编写的注解文本;
从所述注解信息中筛选出所述AP I源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;
将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;
接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;
根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;
基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。
2.根据权利要求1所述的标准化服务SDK自动化生成方法,其特征在于,所述从所述注解信息中筛选出所述AP I源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据的步骤,具体包括:
获取筛选出的所述AP I源码中所有的方法注解描述;
将所述所有的方法注解描述作为一个整体对象,进行序列化处理,获取序列化处理结果;
将所述序列化处理结果作为输入流进行MD5值处理,获取MD5值,将所述MD5值作为所述唯一标记的数据,为所述MD5值设置唯一标识作为所述描述对象。
3.根据权利要求2所述的标准化服务SDK自动化生成方法,其特征在于,所述将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库的步骤,具体包括:
将所述MD5值作为哈希值,将所述描述对象作为与所述哈希值相匹配的哈希对象,成对缓存入所述预设数据库,其中,所述描述对象可以按照开发时的包名、类名、方法名、返回值进行逐级拼接命名。
4.根据权利要求3所述的标准化服务SDK自动化生成方法,其特征在于,在所述将所述MD5值作为哈希值,将所述描述对象作为与所述哈希值相匹配的哈希对象,成对缓存入所述预设数据库的步骤之后,所述方法还包括:
在所述预设数据库中生成一个和所述MD5值相对应的自增式版本号信息;
为所述MD5值、所述描述对象和所述版本号信息建立关联关系,并为所述MD5值、所述描述对象和所述版本号信息分别设置对应的入库时间戳。
5.根据权利要求4所述的标准化服务SDK自动化生成方法,其特征在于,所述为生成目标服务对应的软件开发工具包而发出的打包指令中包括所述软件开发工具包的打包路径,所述接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果的步骤,具体包括:
在接收到所述打包指令之后,对所述打包指令进行解析,获取所述打包路径。
6.根据权利要求5所述的标准化服务SDK自动化生成方法,其特征在于,所述根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面的步骤,具体包括:
根据所述打包路径和所述不同打包条件,将所述MD5值对应的所述自增式版本号信息展示到所述开发协同界面,其中,所述不同打包条件指打包时所使用的不同压缩工具。
7.根据权利要求1至6任一所述的标准化服务SDK自动化生成方法,其特征在于,所述根据预设代码生成器生成所述软件开发工具包所对应的代码程序的步骤,具体包括:
预先定义所述代码生成器的通用方法协议;
获取目标描述对象对应的方法调用数组,其中,所述方法调用数组中包括:方法名、调用参数和返回值;
对所述方法调用数组进行解析,获取方法名、调用参数和返回值;
将所述方法名、调用参数和返回值作为所述通用方法协议的入参参数,调用所述代码生成器,生成所述软件开发工具包所对应的代码程序。
8.一种标准化服务SDK自动化生成装置,其特征在于,包括:
注解信息获取模块,用于根据预设注解处理器,获取AP I源码中的注解信息,其中,所述注解信息指为实现所述AP I源码自动化部署和生成软件开发工具包而预先编写的注解文本;
方法注解转码模块,用于从所述注解信息中筛选出所述AP I源码中的方法注解描述,并根据预设转码规则,将所述方法注解描述生成唯一标记的数据;
中间对象存储模块,用于将所述唯一标记的数据和所述唯一标记的数据对应的描述对象存储到预设数据库;
打包指令解析模块,用于接收为生成目标服务对应的软件开发工具包而发出的打包指令,对所述打包指令进行解析,获得解析结果;
打包处理模块,用于根据预设不同打包条件和所述解析结果,将所述软件开发工具包打包并展示到预设开发协同界面;
服务SDK生成模块,用于基于预设监测组件,监测到所述开发协同界面中为获取所述目标服务对应的软件开发工具包而发出的提取指令后,根据预设代码生成器生成所述软件开发工具包所对应的代码程序,并将所述代码程序上传至预设位置,供二次开发者下载使用。
9.一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机可读指令,所述处理器执行所述计算机可读指令时实现如权利要求1至7中任一项所述的标准化服务SDK自动化生成方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机可读指令,所述计算机可读指令被处理器执行时实现如权利要求1至7中任一项所述的标准化服务SDK自动化生成方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211429884.3A CN115686475A (zh) | 2022-11-15 | 2022-11-15 | 标准化服务sdk自动化生成方法及其相关设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211429884.3A CN115686475A (zh) | 2022-11-15 | 2022-11-15 | 标准化服务sdk自动化生成方法及其相关设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115686475A true CN115686475A (zh) | 2023-02-03 |
Family
ID=85051896
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211429884.3A Pending CN115686475A (zh) | 2022-11-15 | 2022-11-15 | 标准化服务sdk自动化生成方法及其相关设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115686475A (zh) |
-
2022
- 2022-11-15 CN CN202211429884.3A patent/CN115686475A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3399721B1 (en) | Interface data displaying method and device | |
CN112015430A (zh) | JavaScript代码翻译方法、装置、计算机设备及存储介质 | |
CN111176629A (zh) | 一种应用开发的方法和装置 | |
CN112416458A (zh) | 基于ReactNative的预加载方法、装置、计算机设备及存储介质 | |
US20160314107A1 (en) | Collating and intelligently sequencing installation documentation | |
CN115098186A (zh) | 项目处理方法、装置、计算机设备及存储介质 | |
CN112346976A (zh) | 基于网页的接口文档生成方法、装置、***及计算机设备 | |
CN112835568A (zh) | 一种项目构建方法和装置 | |
CN113434175A (zh) | 数据处理方法、装置、存储介质及设备 | |
CN115712422A (zh) | 表单页面的生成方法、装置、计算机设备及存储介质 | |
CN113157523B (zh) | 服务监控方法、装置、计算机设备及存储介质 | |
CN110765610B (zh) | Pdm集成方法、装置、计算机设备及存储介质 | |
CN116432624A (zh) | 一种微服务api文档生成方法、装置、设备、存储介质 | |
CN114626352B (zh) | 报表自动化生成方法、装置、计算机设备及存储介质 | |
CN115686475A (zh) | 标准化服务sdk自动化生成方法及其相关设备 | |
CN114090066A (zh) | 用户界面卡片视图生成方法、装置、计算机设备及介质 | |
CN114637672A (zh) | 自动化数据测试方法、装置、计算机设备及存储介质 | |
CN113239670A (zh) | 一种业务模板上传的方法、装置、计算机设备及存储介质 | |
CN114115855A (zh) | 代码复用方法及装置、计算机可读存储介质、电子设备 | |
CN110196803B (zh) | 一种软件缺陷培训方法和*** | |
CN115865898B (zh) | 多个业务***间数据信息的处理方法、装置、设备及介质 | |
CN104780148A (zh) | 服务器、终端、文档在线操作的***和方法 | |
CN116108814B (zh) | 甘特图处理方法、装置、计算机设备及存储介质 | |
CN115756640A (zh) | 自动化生成作业调度配置的方法及其相关设备 | |
CN117290019A (zh) | 一种接口调用方法、装置、计算机设备和存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |