CN111562940B - 项目数据构建方法以及装置 - Google Patents
项目数据构建方法以及装置 Download PDFInfo
- Publication number
- CN111562940B CN111562940B CN202010338543.XA CN202010338543A CN111562940B CN 111562940 B CN111562940 B CN 111562940B CN 202010338543 A CN202010338543 A CN 202010338543A CN 111562940 B CN111562940 B CN 111562940B
- Authority
- CN
- China
- Prior art keywords
- data
- project
- construction
- file
- data construction
- 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.)
- Active
Links
- 238000010276 construction Methods 0.000 title claims abstract description 242
- 238000000034 method Methods 0.000 claims abstract description 43
- 238000004422 calculation algorithm Methods 0.000 claims abstract description 38
- 238000012545 processing Methods 0.000 claims abstract description 33
- 238000013144 data compression Methods 0.000 claims description 11
- 238000004364 calculation method Methods 0.000 claims description 4
- 238000004590 computer program Methods 0.000 claims description 4
- 238000004806 packaging method and process Methods 0.000 claims description 3
- 230000008569 process Effects 0.000 description 9
- 238000010586 diagram Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 230000003287 optical effect Effects 0.000 description 3
- 230000006978 adaptation Effects 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 238000012886 linear function Methods 0.000 description 2
- 239000000463 material Substances 0.000 description 2
- 239000013307 optical fiber Substances 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 238000013459 approach Methods 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 238000010252 digital analysis Methods 0.000 description 1
- 230000002708 enhancing effect Effects 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000011112 process operation Methods 0.000 description 1
- 230000003252 repetitive effect Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 230000002123 temporal effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
- G06F8/71—Version control; Configuration management
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本公开是关于一种项目数据构建方法、装置、电子设备以及存储介质。其中,该方法包括:响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;如果存在对应的项目数据构建记录,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据;并将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。本公开可有效提升项目构建速度,减少项目构建时间成本。
Description
技术领域
本公开涉及互联网领域,具体而言,涉及一种项目数据构建方法、装置、电子设备以及计算机可读存储介质。
背景技术
在编程应用实践中,当本地开发完成后,需要将项目打包部署到服务器中。项目中前端代码数据等项目数据,一般都会经过各种构建操作。然而,现有技术中对于项目数据的构建操作多是采用全量编译,即对项目数据直接全部进行构建操作。如果项目数据过多,对项目数据的构建会消耗很多时间,影响整体部署效率。
因此,需要一种或多种方法解决上述问题。
需要说明的是,在上述背景技术部分公开的信息仅用于加强对本公开的背景的理解,因此可以包括不构成对本领域普通技术人员已知的现有技术的信息。
发明内容
本公开的目的在于提供一种项目数据构建方法、装置、电子设备以及计算机可读存储介质,进而至少在一定程度上克服由于相关技术的限制和缺陷而导致的一个或者多个问题。
根据本公开的一个方面,提供一种项目数据构建方法,包括:
响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;
如果存在与所述指定项目对应的项目数据构建记录,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据;
将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;
如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。
在本公开的一种示例性实施例中,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录后,方法还包括:
如果不存在与所述指定项目对应的项目数据构建记录,将所述指定项目对应的数据文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。
在本公开的一种示例性实施例中,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据,包括:
根据所述预设算法计算所述项目文件的特征值,将所述特征值作为所述待匹配数据。
在本公开的一种示例性实施例中,所述项目数据构建记录的构建数据中存储有各个项目文件的特征值,将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配,包括:
将所述指定项目的项目文件的特征值与所述项目数据构建记录中预存的与所述指定项目对应的构建数据中的特征值进行匹配,若一致,确定所述待匹配数据与项目数据构建记录中的构建数据匹配,若不一致,确定所述待匹配数据与项目数据构建记录中的构建数据不匹配。
在本公开的一种示例性实施例中,根据预设算法计算所述项目文件的特征值之前,包括:
调取所述指定项目中的项目指令对应的指令文件;
将所述指令文件合并于所述项目文件中的对应位置,得到合并后的所述项目文件;
对所述合并后的项目文件按照预设算法进行计算,得到与所述合并后的项目文件对应的特征值,并存储至所述项目数据构建记录中的指定位置。
在本公开的一种示例性实施例中,对数据构建队列中的项目文件进行数据构建处理,包括:依次对数据构建队列中的项目文件进行数据压缩混淆处理,得到构建完成数据。
在本公开的一种示例性实施例中,对数据构建队列中的项目文件进行数据压缩混淆处理,包括以下任意一项或多项处理:
对数据构建队列中的项目文件进行冗余数据压缩处理;
合并所述待构建数据中的冗余数据;
使用随机字符替换所述项目文件中的关键数据。
在本公开的一种示例性实施例中,方法还包括:
将所述构建完成数据进行打包处理,并部署至服务器端,以通过所述服务器端启动所述构建完成数据,完成所述指定项目对应服务的发布。
在本公开的一个方面,提供一种项目数据构建装置,包括:
数据判断模块,用于响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;
数据计算模块,用于如果存在与所述指定项目对应的项目数据构建记录时,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据;
数据匹配模块,用于将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;
数据构建模块,用于如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。
在本公开的一个方面,提供一种电子设备,包括:
处理器;以及
存储器,所述存储器上存储有计算机可读指令,所述计算机可读指令被所述处理器执行时实现根据上述任意一项所述的方法。
在本公开的一个方面,提供一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现根据上述任意一项所述的方法。
本公开的示例性实施例中的项目数据构建方法,通过响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;如果存在对应的项目数据构建记录,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据;并将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。本公开通过过滤项目数据构建记录中已存在的项目文件,并仅对未完成构建的部分项目文件进行针对性构建处理,可有效提升项目构建速度,减少项目构建时间成本。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
通过参照附图来详细描述其示例实施例,本公开的上述和其它特征及优点将变得更加明显。
图1示出了根据本公开一示例性实施例的项目数据构建方法的流程图;
图2示出了根据本公开一示例性实施例的项目数据构建装置的示意框图;
图3示意性示出了根据本公开一示例性实施例的电子设备的框图;以及
图4示意性示出了根据本公开一示例性实施例的计算机可读存储介质的示意图。
具体实施方式
现在将参考附图更全面地描述示例实施例。然而,示例实施例能够以多种形式实施,且不应被理解为限于在此阐述的实施例;相反,提供这些实施例使得本公开将全面和完整,并将示例实施例的构思全面地传达给本领域的技术人员。在图中相同的附图标记表示相同或类似的部分,因而将省略对它们的重复描述。
此外,所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施例中。在下面的描述中,提供许多具体细节从而给出对本公开的实施例的充分理解。然而,本领域技术人员将意识到,可以实践本公开的技术方案而没有所述特定细节中的一个或更多,或者可以采用其它的方法、组元、材料、装置、步骤等。在其它情况下,不详细示出或描述公知结构、方法、装置、实现、材料或者操作以避免模糊本公开的各方面。
附图中所示的方框图仅仅是功能实体,不一定必须与物理上独立的实体相对应。即,可以采用软件形式来实现这些功能实体,或在一个或多个软件硬化的模块中实现这些功能实体或功能实体的一部分,或在不同网络和/或处理器装置和/或微控制器装置中实现这些功能实体。
在本示例实施例中,首先提供了一种项目数据构建方法;参考图1中所示,该项目数据构建方法可以包括以下步骤:
步骤S110,响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;
步骤S120,如果存在与所述指定项目对应的项目数据构建记录,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据;
步骤S130,将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;
步骤S140,如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。
本公开的示例性实施例中的项目数据构建方法,通过响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;如果存在对应的项目数据构建记录,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据;并将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。本公开通过过滤项目数据构建记录中已存在的项目文件,并仅对未完成构建的部分项目文件进行针对性构建处理,可有效提升项目构建速度,减少项目构建时间成本。
下面,将对本示例实施例中的项目数据构建方法进行进一步的说明。
在步骤S110中,可以响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录。
在基于javascript等嵌入式软件的项目开发过程中,对项目文件编程完成后,用户需要对完成的指定项目进行数据构建时,可基于Ant、Maven、Gradle等软件实现对编程数据项目的构建,用户执行启动软件的构建以触发该数据构建指令。在触发对指定项目进行数据构建的数据构建指令后,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录。当前构建环境可以是存储构建项目的数据库、存储器等环境,其中存储有已构建项目的项目数据构建记录,项目数据构建记录中包括已构建项目的标识信息,当触发对指定项目进行数据构建的数据构建指令后,可以获取该数据构建指令中携带的该指定项目的项目标识信息,并在项目数据构建记录中查询是否有对应的已构建项目,若有,确定当前构建环境中具有与所述指定项目对应的项目数据构建记录,可以执行步骤S120;否则,确定当前构建环境中无与所述指定项目对应的项目数据构建记录,可以参考步骤S140中执行将所述指定项目对应的项目文件添加至数据构建队列进行数据构建处理的流程。
在步骤S120中,可以在如果存在与所述指定项目对应的项目数据构建记录时,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据。
其中,该预设算法可以是哈希算法,也可以是具有同等功能的其他加密算法或者映射算法,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据,包括:根据所述预设算法计算所述项目文件的特征值,将所述特征值作为所述待匹配数据。当所述预设算法为哈希算法时,则可以根据哈希算法计算所述项目文件的哈希值,将该哈希值作为所述待匹配数据。
以预设算法为基于直接寻址法的哈希算法为例,通过哈希算法将指定项目对应的项目文件取关键字或关键字的某个线性函数值为散列地址得到哈希值;或基于通过数字分析法的哈希算法将指定项目对应的项目文件的构造冲突几率较低的散列地址得到哈希值;又或基于通过平方取中法的哈希算法对指定项目对应的项目文件取关键字平方后的中间几位作为散列地址得到哈希值。哈希值为指定项目中每个文件唯一对应的加密值,当项目文件发生修改变动时,哈希值也随之发生改变,因此可以将所述哈希值作为待匹配数据,以保证数据准确性。
在步骤S130中,可以将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配。
一般的线性表、树中,记录在结构中的相对位置是随机的,即和记录的关键字之间不存在确定的关系,在查找记录时需进行一系列和关键字的比较,因此可以在记录的存储位置和它的关键字之间建立一个确定的对应关系,使每个关键字和结构中一个唯一的存储位置相对应。由哈希函数计算数据的哈希值的方式,使指定项目中的每个文件都有唯一的哈希值,并储存在配置文件中。因此,在本公开的一种示例性实施例中,完成数据构建的项目会在项目数据构建记录中保存有该项目的所有项目文件所对应的哈希值。
将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配,包括:将所述指定项目的项目文件的哈希值与所述项目数据构建记录中预存的与所述指定项目对应的构建数据中的哈希值进行匹配,若一致,确定所述待匹配数据与项目数据构建记录中的构建数据匹配,说明哈希值未发生变化,文件没有改动,则无需再次进行项目构建的全过程操作;若不一致,说明文件发生变动,确定所述待匹配数据与项目数据构建记录中的构建数据不匹配,则执行步骤S140。
在步骤S140中,如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。
在本公开的一种示例性实施例中,根据预设算法计算所述项目文件的特征值之前,包括:调取所述指定项目中的项目指令对应的指令文件;将所述指令文件合并于所述项目文件中的对应位置,得到合并后的所述项目文件;对所述合并后的项目文件按照哈希算法进行计算,得到与所述合并后的项目文件对应的哈希值,并存储至所述项目数据构建记录中的指定位置;对数据构建队列中的项目文件进行数据构建处理,包括:依次对数据构建队列中的项目文件进行数据压缩混淆处理,得到构建完成数据。
其中,调取所述指定项目中的项目指令对应的指令文件;将所述指令文件合并于所述项目文件中的对应位置,得到合并后的所述项目文件,具体而言:
以javascript项目为例,javascript项目的js文件中包含项目指令,即调用信息。当接收到指定项目的数据构建指令时,对于javascript项目中的js文件,需要根据每个js文件的调用信息,将js文件的待调用内容完成调用,并集成至js文件的根目录下,合并为.json格式的js文件,以完成项目文件的合并。
其中,对所述合并后的项目文件按照预设算法进行计算,得到与所述合并后的项目文件对应的特征值,并存储至所述项目数据构建记录中的指定位置,具体而言:
在本示例的实施例中,将指定项目中哈希值发生变动的每个项目文件都生成哈希值后并储存后,就可以将哈希值作为后续查询文件是否发生改动来判断是否需要重新构建的依据。
其中,依次对数据构建队列中的项目文件进行数据压缩混淆处理,具体可以根据以下任意一项或多项处理,以得到构建完成数据:
对数据构建队列中的项目文件进行冗余数据压缩处理;
合并所述待构建数据中的冗余数据;
使用随机字符替换所述项目文件中的关键数据。
具体而言,可以包括删除项目文件中无用回车换行与空格等,以减少代码数据体积,之后通过对数据构建队列中的待构建数据进行冗余数据压缩,可以在不丢失有用信息的前提下,缩减数据量以减少存储空间,提高其传输、存储和处理效率,或按照一定的算法对数据进行重新组织,减少数据的冗余和存储的空间。另外,为提升项目的安全性及可靠性,防止项目被反编译,可以需要对项目文件进行冗余数据压缩处理及数据混淆,通过将计算机程序的代码数据转换成一种功能上等价,但是难于阅读和理解的形式的行为。数据混淆可以用于程序源代码数据,也可以用于程序编译而成的中间代码数据,如可以使用代码混淆器执行代码数据混淆的程序。在软件代码数据混淆处理中主要包括:布局混淆、软件控制流混淆、数据混淆、地址随机化等。数据混淆就是对发布出去的程序进行重新组织和处理,使得处理后的数据与处理前数据完成相同的功能,而混淆后的数据很难被反编译,即使反编译成功也很难得出程序的真正语义。
在通过数据压缩及数据混淆后,将项目的构建记录在配置文件中记录更新,以便再次构建时查找并调用更新后的文件。
在本公开的一种示例性实施例中,在生成构建完成数据后,可以将所述构建完成数据进行打包处理,并部署至服务器端,以通过所述服务器端启动所述构建完成数据,完成所述指定项目对应服务的发布。具体而言,将项目的构建记录在配置文件中记录更新并替代同名历史文件后,将更新后的文件储存在buffer文件夹中,当项目需要部署时,可以将buffer文件夹与项目其他数据打包,复制到服务器中部署。部署时直接在服务端解压刚才的打包,然后在解压后的文件夹中启动服务端即可完成上线。
在本公开的一种示例性实施例中,若在步骤S110中判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录后,确定不存在与所述指定项目对应的项目数据构建记录,那么可以参考步骤S140中将所述指定项目对应的数据文件添加至数据构建队列进行数据构建处理。
需要说明的是,尽管在附图中以特定顺序描述了本公开中方法的各个步骤,但是,这并非要求或者暗示必须按照该特定顺序来执行这些步骤,或是必须执行全部所示的步骤才能实现期望的结果。附加的或备选的,可以省略某些步骤,将多个步骤合并为一个步骤执行,以及/或者将一个步骤分解为多个步骤执行等。
此外,在本示例实施例中,还提供了一种项目数据构建装置。参照图2所示,该项目数据构建装置200可以包括:数据判断模块210、数据计算模块220、数据匹配模块230以及数据构建模块240。其中:
数据判断模块210,用于响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;
数据计算模块220,用于如果存在与所述指定项目对应的项目数据构建记录,根据预设算法对所述指定项目对应的项目文件进行计算,得到待匹配数据;
数据匹配模块230,用于将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;
数据构建模块240,用于如果不存在与所述指定项目对应的项目数据构建记录,将所述指定项目对应的数据文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。
上述中各项目数据构建装置模块的具体细节已经在对应的项目数据构建方法中进行了详细的描述,因此此处不再赘述。
应当注意,尽管在上文详细描述中提及了项目数据构建装置200的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本公开的实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。
此外,在本公开的示例性实施例中,还提供了一种能够实现上述方法的电子设备。
所属技术领域的技术人员能够理解,本发明的各个方面可以实现为系统、方法或程序产品。因此,本发明的各个方面可以具体实现为以下形式,即:完全的硬件实施例、完全的软件实施例(包括固件、微代码等),或硬件和软件方面结合的实施例,这里可以统称为“电路”、“模块”或“系统”。
下面参照图3来描述根据本发明的这种实施例的电子设备300。图3显示的电子设备300仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图3所示,电子设备300以通用计算设备的形式表现。电子设备300的组件可以包括但不限于:上述至少一个处理单元310、上述至少一个存储单元320、连接不同系统组件(包括存储单元320和处理单元310)的总线330、显示单元340。
其中,所述存储单元存储有程序代码,所述程序代码可以被所述处理单元310执行,使得所述处理单元310执行本说明书上述“示例性方法”部分中描述的根据本发明各种示例性实施例的步骤。例如,所述处理单元310可以执行如图1中所示的步骤S110至步骤S130。
存储单元320可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(RAM)3201和/或高速缓存存储单元3202,还可以进一步包括只读存储单元(ROM)3203。
存储单元320还可以包括具有一组(至少一个)程序模块3205的程序/实用工具3204,这样的程序模块3205包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
总线330可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理单元或者使用多种总线结构中的任意总线结构的局域总线。
电子设备300也可以与一个或多个外部设备370(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该电子设备300交互的设备通信,和/或与使得该电子设备300能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口350进行。并且,电子设备300还可以通过网络适配器360与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器360通过总线330与电子设备300的其它模块通信。应当明白,尽管图中未示出,可以结合电子设备300使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
通过以上的实施例的描述,本领域的技术人员易于理解,这里描述的示例实施例可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本公开实施例的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、终端装置、或者网络设备等)执行根据本公开实施例的方法。
在本公开的示例性实施例中,还提供了一种计算机可读存储介质,其上存储有能够实现本说明书上述方法的程序产品。在一些可能的实施例中,本发明的各个方面还可以实现为一种程序产品的形式,其包括程序代码,当所述程序产品在终端设备上运行时,所述程序代码用于使所述终端设备执行本说明书上述“示例性方法”部分中描述的根据本发明各种示例性实施例的步骤。
参考图4所示,描述了根据本发明的实施例的用于实现上述方法的程序产品400,其可以采用便携式紧凑盘只读存储器(CD-ROM)并包括程序代码,并可以在终端设备,例如个人电脑上运行。然而,本发明的程序产品不限于此,在本文件中,可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
所述程序产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以为但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。可读信号介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、有线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言的任意组合来编写用于执行本发明操作的程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、C++等,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(LAN)或广域网(WAN),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
此外,上述附图仅是根据本发明示例性实施例的方法所包括的处理的示意性说明,而不是限制目的。易于理解,上述附图所示的处理并不表明或限制这些处理的时间顺序。另外,也易于理解,这些处理可以是例如在多个模块中同步或异步执行的。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其他实施例。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限。
Claims (9)
1.一种项目数据构建方法,其特征在于,所述方法包括:
响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;
如果存在与所述指定项目对应的项目数据构建记录,根据所述预设算法计算所述项目文件的特征值,将所述特征值作为所述待匹配数据;
将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;
如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理;
根据所述预设算法计算所述项目文件的特征值之前,还包括:
调取所述指定项目文件中的项目指令对应的指令文件;
将所述指令文件合并于所述项目文件中的对应位置,得到合并后的所述项目文件;
根据所述预设算法计算所述项目文件的特征值,包括:
对所述合并后的项目文件按照预设算法进行计算,得到与所述合并后的项目文件对应的特征值,并存储至所述项目数据构建记录中的指定位置。
2.根据权利要求1所述的方法,其特征在于,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录后,所述方法还包括:
如果不存在与所述指定项目对应的项目数据构建记录,将所述指定项目对应的数据文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理。
3.根据权利要求1所述的方法,其特征在于,所述项目数据构建记录的构建数据中存储有各个项目文件的特征值,将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配,包括:
将所述指定项目的项目文件的特征值与所述项目数据构建记录中预存的与所述指定项目对应的构建数据中的特征值进行匹配,若一致,确定所述待匹配数据与项目数据构建记录中的构建数据匹配,若不一致,确定所述待匹配数据与项目数据构建记录中的构建数据不匹配。
4.根据权利要求1或2任意一项所述的方法,其特征在于,对数据构建队列中的项目文件进行数据构建处理,包括:
依次对数据构建队列中的项目文件进行数据压缩混淆处理,得到构建完成数据。
5.根据权利要求4所述的方法,其特征在于,对数据构建队列中的项目文件进行数据压缩混淆处理,包括以下任意一项或多项处理:
对数据构建队列中的项目文件进行冗余数据压缩处理;
合并待构建数据中的冗余数据;
使用随机字符替换所述项目文件中的关键数据。
6.根据权利要求4所述的方法,其特征在于,所述方法还包括:
将所述构建完成数据进行打包处理,并部署至服务器端,以通过所述服务器端启动所述构建完成数据,完成所述指定项目对应服务的发布。
7.一种项目数据构建装置,其特征在于,所述装置包括:
文件数据判断模块,用于响应于对指定项目进行数据构建的数据构建指令,判断当前构建环境中是否具有与所述指定项目对应的项目数据构建记录;
数据计算模块,用于如果存在与所述指定项目对应的项目数据构建记录,根据所述预设算法计算所述项目文件的特征值,将所述特征值作为所述待匹配数据;
数据匹配模块,用于将所述待匹配数据与所述项目数据构建记录中所述指定项目对应的构建数据进行匹配;
数据构建模块,用于如果存在不匹配的项目文件,将不匹配的项目文件添加至数据构建队列,对数据构建队列中的项目文件进行数据构建处理;
根据所述预设算法计算所述项目文件的特征值之前,还包括:
调取所述指定项目文件中的项目指令对应的指令文件;
将所述指令文件合并于所述项目文件中的对应位置,得到合并后的所述项目文件;
根据所述预设算法计算所述项目文件的特征值,包括:
对所述合并后的项目文件按照预设算法进行计算,得到与所述合并后的项目文件对应的特征值,并存储至所述项目数据构建记录中的指定位置。
8.一种计算机设备,其特征在于,包括处理器和存储器;
其中,所述处理器通过读取所述存储器中存储的可执行程序代码来运行与所述可执行程序代码对应的程序,以用于实现如权利要求1-6中任一所述的方法。
9.一种计算机可读存储介质,其上存储有计算机程序,其特征在于所述计算机程序被处理器执行时实现如权利要求1-6中任一所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010338543.XA CN111562940B (zh) | 2020-04-26 | 2020-04-26 | 项目数据构建方法以及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010338543.XA CN111562940B (zh) | 2020-04-26 | 2020-04-26 | 项目数据构建方法以及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111562940A CN111562940A (zh) | 2020-08-21 |
CN111562940B true CN111562940B (zh) | 2024-02-27 |
Family
ID=72074394
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010338543.XA Active CN111562940B (zh) | 2020-04-26 | 2020-04-26 | 项目数据构建方法以及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111562940B (zh) |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013109860A1 (en) * | 2012-01-18 | 2013-07-25 | Smart Online, Inc. | Software builder |
CN108848108A (zh) * | 2018-07-25 | 2018-11-20 | 贵州电网有限责任公司 | 基于移动互联网+的创新项目pdca过程管理平台 |
CN109739478A (zh) * | 2018-12-24 | 2019-05-10 | 网易(杭州)网络有限公司 | 前端项目自动化构建方法、装置、存储介质及电子设备 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10691449B2 (en) * | 2017-04-27 | 2020-06-23 | Microsoft Technology Licensing, Llc | Intelligent automatic merging of source control queue items |
-
2020
- 2020-04-26 CN CN202010338543.XA patent/CN111562940B/zh active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013109860A1 (en) * | 2012-01-18 | 2013-07-25 | Smart Online, Inc. | Software builder |
CN108848108A (zh) * | 2018-07-25 | 2018-11-20 | 贵州电网有限责任公司 | 基于移动互联网+的创新项目pdca过程管理平台 |
CN109739478A (zh) * | 2018-12-24 | 2019-05-10 | 网易(杭州)网络有限公司 | 前端项目自动化构建方法、装置、存储介质及电子设备 |
Non-Patent Citations (1)
Title |
---|
方延风 ; .基于Elastic Stack构建科技项目垂直检索系统.情报探索.2018,(01),全文. * |
Also Published As
Publication number | Publication date |
---|---|
CN111562940A (zh) | 2020-08-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102200911B (zh) | 变量闭包 | |
CN109471851B (zh) | 数据处理方法、装置、服务器和存储介质 | |
CN105095367A (zh) | 一种客户端数据的采集方法和装置 | |
CN115562992A (zh) | 一种文件检测方法、装置、电子设备及存储介质 | |
CN110990346A (zh) | 基于区块链的文件数据处理方法、装置、设备及存储介质 | |
CN110618999A (zh) | 数据的查询方法及装置、计算机存储介质、电子设备 | |
CN110659210A (zh) | 一种信息获取方法、装置、电子设备及存储介质 | |
CN112416710A (zh) | 用户操作的记录方法、装置、电子设备及存储介质 | |
CN113918437A (zh) | 用户行为数据分析方法、装置、计算机设备和存储介质 | |
CN112882717A (zh) | 一种标签名查重方法、装置、电子设备及存储介质 | |
CN111562940B (zh) | 项目数据构建方法以及装置 | |
CN112258295A (zh) | 记录处理方法、装置及设备 | |
CN109684207B (zh) | 操作序列封装的方法、装置、电子设备及存储介质 | |
CN116010461A (zh) | 数据血缘关系解析方法及装置、存储介质及电子设备 | |
CN114090514A (zh) | 分布式系统的日志检索方法及装置 | |
CN112800006B (zh) | 用于网络设备的日志存储方法及装置 | |
CN115080154A (zh) | 页面显示方法、装置、存储介质及电子设备 | |
CN114625372A (zh) | 组件自动编译方法、装置、计算机设备及存储介质 | |
CN108874625B (zh) | 信息处理方法及装置、电子设备、存储介质 | |
CN111538651A (zh) | 接口测试方法、装置、服务器及存储介质 | |
CN117521152B (zh) | 数据更新方法、匿踪查询方法、电子设备及介质 | |
CN112463214B (zh) | 数据处理方法及装置、计算机可读存储介质以及电子设备 | |
CN113590088B (zh) | 一种自动分析组件使用情况的方法、装置和电子设备 | |
CN110781188B (zh) | 表单信息处理方法、装置、电子设备及存储介质 | |
CN113900895B (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |