CN115098186A - 项目处理方法、装置、计算机设备及存储介质 - Google Patents
项目处理方法、装置、计算机设备及存储介质 Download PDFInfo
- Publication number
- CN115098186A CN115098186A CN202210699250.3A CN202210699250A CN115098186A CN 115098186 A CN115098186 A CN 115098186A CN 202210699250 A CN202210699250 A CN 202210699250A CN 115098186 A CN115098186 A CN 115098186A
- Authority
- CN
- China
- Prior art keywords
- target
- configuration
- project
- authority
- file
- 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
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44505—Configuring for program initiating, e.g. using registry, configuration files
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/31—Programming languages or programming paradigms
- G06F8/315—Object-oriented languages
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- 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)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Computing Systems (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本申请实施例属于数据处理领域,涉及一种项目处理方法,包括:基于脚手架工具对vite开发服务器的启动命令进行封装;读取目标项目的配置文件;获取与vite开发服务器对应的配置数据并传入配置文件;将配置文件内的所有配置对象转换成与vite开发服务器对应的目标配置对象;读取目标项目的指定目录下的主页面文件,并加入指定标签引用,生成与vite开发服务器对应的目标入口文件;将目标配置对象导出至目标入口文件内,并执行启动命令以启动目标项目。本申请还提供一种项目处理装置、计算机设备及存储介质。此外,本申请还涉及区块链技术,目标配置对象可存储于区块链中。通过本申请的项目升级方式可以减少开发人员的开发工作量,提升项目升级的处理效率。
Description
技术领域
本申请涉及数据处理技术领域,尤其涉及项目处理方法、装置、计算机设备及存储介质。
背景技术
目前业界主流的前端开发工具主要以Webpack为主,前端项目的本地运行一般采用webpack-dev-server的方式,它会在项目启动的时候一次性将源代码和第三方依赖编译处理打包到一起。随着项目体积的增大,这种方式的启动耗时会显著增加,开发过程中热更新所需的时间也会增加,这大大影响了开发人员的效率。针对这个问题,社区开始逐渐向esbuild、swc等工具探索unbundle的打包方式。当前最火热的莫过于vite开发服务器,vite采用浏览器原生支持的ESM文件,无需打包,文件只在使用的时候编译和引入,大大的缩短了开发编译的时间,vite开发服务器可以做到秒启动。然而,现有的利用vite开发服务器对已有项目进行升级的处理方式,需要引入新的入口文件和大量的配置,对项目进行的改造较大,开发人员的开发工作量大,处理效率低。
发明内容
本申请实施例的目的在于提出一种项目处理方法、装置、计算机设备及存储介质,以解决现有的利用vite开发服务器对已有项目进行升级的处理方式,需要引入新的入口文件和大量的配置,对项目进行的改造较大,开发人员的开发工作量大,处理效率低的问题。
为了解决上述技术问题,本申请实施例提供一种项目处理方法,采用了如下所述的技术方案:
基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理;
读取目标项目的配置文件;
获取与所述vite开发服务器对应的预设的配置数据,并将所述配置数据传入所述配置文件内;
将所述配置文件内包含的所有配置对象转换成与所述vite开发服务器对应的目标配置对象;
读取所述目标项目的指定目录下的主页面文件,并对所述主页面文件加入指定标签引用,生成与所述vite开发服务器对应的目标入口文件;
将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目。
进一步的,在所述将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目的步骤之后,还包括:
获取所述目标项目的标识信息;
基于预设的权限数据表确定出与所述标识信息对应的目标权限配置信息;
获取所述目标项目的路由信息;
从所述路由信息中确定出与所述目标权限配置信息对应的目标路由;
基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目。
进一步的,所述基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目的步骤,具体包括:
获取所述权限配置组件以及所述权限配置代码;
将所述权限配置组件添加至所述目标项目的所述目标路由内,得到第一目标项目;
将所述权限配置代码注入至所述第一目标项目内,得到第二目标项目;
将所述第二目标项目作为所述权限目标项目。
进一步的,所述获取所述目标项目的路由信息的步骤,具体包括:
获取所述目标项目的框架类型;
基于所述框架类型获取所述目标项目的路由文件;
基于所述路由文件获取所述目标项目的路由信息。
进一步的,所述基于预设的权限数据表确定出与所述标识信息对应的目标权限配置信息的步骤,具体包括:
调用所述权限数据表;
基于预设的并行比较指令,分别将所述标识信息与所述权限数据表中的每一个标识进行匹配处理,从所述权限数据表中筛选出与所述标识信息相同的目标标识;
从所述权限数据表中提取出与所述目标标识对应的权限配置信息;
将所述权限配置信息作为所述目标权限配置信息。
进一步的,在所述基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目的步骤之后,还包括:
获取所述目标项目的重要度信息;
确定与所述重要度信息对应的存储方式;
基于所述存储方式对所述权限目标项目进行存储处理。
进一步的,所述基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理的步骤,具体包括:
调用所述脚手架工具;
获取预设的封装命令;
通过所述脚手架工具运行所述封装命令,以对所述vite开发服务器的启动命令进行封装处理。
为了解决上述技术问题,本申请实施例还提供一种项目处理装置,采用了如下所述的技术方案:
封装模块,用于基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理;
读取模块,用于读取目标项目的配置文件;
第一获取模块,用于获取与所述vite开发服务器对应的预设的配置数据,并将所述配置数据传入所述配置文件内;
转换模块,用于将所述配置文件内包含的所有配置对象转换成与所述vite开发服务器对应的目标配置对象;
生成模块,用于读取所述目标项目的指定目录下的主页面文件,并对所述主页面文件加入指定标签引用,生成与所述vite开发服务器对应的目标入口文件;
启动模块,用于将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目。
为了解决上述技术问题,本申请实施例还提供一种计算机设备,采用了如下所述的技术方案:
基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理;
读取目标项目的配置文件;
获取与所述vite开发服务器对应的预设的配置数据,并将所述配置数据传入所述配置文件内;
将所述配置文件内包含的所有配置对象转换成与所述vite开发服务器对应的目标配置对象;
读取所述目标项目的指定目录下的主页面文件,并对所述主页面文件加入指定标签引用,生成与所述vite开发服务器对应的目标入口文件;
将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目。
为了解决上述技术问题,本申请实施例还提供一种计算机可读存储介质,采用了如下所述的技术方案:
基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理;
读取目标项目的配置文件;
获取与所述vite开发服务器对应的预设的配置数据,并将所述配置数据传入所述配置文件内;
将所述配置文件内包含的所有配置对象转换成与所述vite开发服务器对应的目标配置对象;
读取所述目标项目的指定目录下的主页面文件,并对所述主页面文件加入指定标签引用,生成与所述vite开发服务器对应的目标入口文件;
将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例在基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理后,会先读取目标项目的配置文件以及获取与vite开发服务器对应的预设的配置数据,并将配置数据传入配置文件内,然后将配置文件内包含的所有配置对象转换成与vite开发服务器对应的目标配置对象,之后读取目标项目的指定目录下的主页面文件,并对主页面文件加入指定标签引用,生成与vite开发服务器对应的目标入口文件,最后将目标配置对象导出至目标入口文件内,并执行启动命令以启动目标项目,以完成在目标项目中集成vite开发服务的升级过程。通过采用本申请实施例的项目升级方式对目标项目进行升级处理,可以避免在目标项目的根目录新建入口文件和配置文件,实现了在目标项目集成vite开发服务的升级过程中零新增零配置的目的,有效地减少了开发人员的开发工作量,降低了项目维护的成本,提高了项目升级的处理效率。
附图说明
为了更清楚地说明本申请中的方案,下面将对本申请实施例描述中所需要使用的附图作一个简单介绍,显而易见地,下面描述中的附图是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请可以应用于其中的示例性***架构图;
图2根据本申请的项目处理方法的一个实施例的流程图;
图3是根据本申请的项目处理装置的一个实施例的结构示意图;
图4是根据本申请的计算机设备的一个实施例的结构示意图。
具体实施方式
除非另有定义,本文所使用的所有的技术和科学术语与属于本申请的技术领域的技术人员通常理解的含义相同;本文中在申请的说明书中所使用的术语只是为了描述具体的实施例的目的,不是旨在于限制本申请;本申请的说明书和权利要求书及上述附图说明中的术语“包括”和“具有”以及它们的任何变形,意图在于覆盖不排他的包含。本申请的说明书和权利要求书或上述附图中的术语“第一”、“第二”等是用于区别不同对象,而不是用于描述特定顺序。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其它实施例相结合。
为了使本技术领域的人员更好地理解本申请方案,下面将结合附图,对本申请实施例中的技术方案进行清楚、完整地描述。
如图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上显示的页面提供支持的后台服务器。
需要说明的是,本申请实施例所提供的项目处理方法一般由服务器/终端设备执行,相应地,项目处理装置一般设置于服务器/终端设备中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了根据本申请的项目处理方法的一个实施例的流程图。所述的项目处理方法,包括以下步骤:
步骤S201,基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理。
在本实施例中,项目处理方法运行于其上的电子设备(例如图1所示的服务器/终端设备)。需要指出的是,上述无线连接方式可以包括但不限于3G/4G/5G连接、WiFi连接、蓝牙连接、WiMAX连接、Zigbee连接、UWB(ultra wideband)连接、以及其他现在已知或将来开发的无线连接方式。
在本实施例中,Vite是Vue的作者尤雨溪开发的Web开发构建工具,它是一个基于浏览器原生ES模块导入的开发服务器,在开发环境下,利用浏览器去解析import,在服务器端按需编译返回,完全跳过了打包这个概念,服务器随启随用。同时不仅对Vue文件提供了支持,还支持热更新,而且热更新的速度不会随着模块增多而变慢。在生产环境下使用Rollup打包。上述脚手架工具为预先创建的用于封装vite开发服务器启动项目的能力的vue-cli工具。具体的,可通过脚手架工具运行预设的封装命令,以实现对vite开发服务器的启动命令进行封装处理。其中,上述封装命令具体为pafe-cli-service vite命令。Vue-cli-service是vue-cli工具常用的服务命令,pafe为目标项目的项目名称。
步骤S202,读取目标项目的配置文件。
在本实施例中,目标项目的配置文件具体为pafe.config.js文件,pafe.config.js文件是目标项目的统一配置入口。其中,目标项目的框架类型可包括Vue框架或React框架,即目标项目属于Vue项目或React项目。
步骤S203,获取与所述vite开发服务器对应的预设的配置数据,并将所述配置数据传入所述配置文件内。
在本实施例中,上述配置数据为vite开发服务器所需的配置,可根据实际的使用需求预设创建生成。通过将vite开发服务器的配置数据集成在目标项目的配置文件内传入,从而可以实现自动分析配置文件内的入口、别名、css、代理服务器、loader等webpack常用的配置。具体的,上述配置数据可为vitePlugin属性,通过在目标项目的配置文件中新增vitePlugin属性,从而能将vite开发服务器的插件传入,进而可以扩展目标项目的能力。
步骤S204,将所述配置文件内包含的所有配置对象转换成与所述vite开发服务器对应的目标配置对象。
在本实施例中,可通过插件的形式将配置文件内包含的所有配置对象转换成与vite开发服务器对应的目标配置对象。具体的,可将配置文件内包含的所有配置对象以vite-plugin-xxx的方式命名即可,举例地,经过转换后生成的目标配置对象可包括vite-plugin-env-compatible、vite-plugin-importer等。通过采用插件的方式将vite开发服务器一键集成到目标项目内,升级非常简单,并可实现对已有项目代码的零改动。
步骤S205,读取所述目标项目的指定目录下的主页面文件,并对所述主页面文件加入指定标签引用,生成与所述vite开发服务器对应的目标入口文件。
在本实施例中,上述指定目录为public目录,上述主页面文件为index.html文件,上述指定标签为script标签。其中,通过在index.html中加入script标签引用,进而后续vite开发服务器可以通过解析该script标签来找到相应的目标入口文件。现有的Vite官方文档介绍的使用方式是在项目根目录下创建入口文件和vite.config.js配置文件等,但这种方式需要引入新的文件和大量配置,还需要对项目进行比较大的改造,对已有项目进行升级很不友好。本实施例通过采用复用public目录下的传统入口文件,动态地读取入口的html文件,并为index.html文件加入script标签引用来生成vite开发服务器所需的目标入口文件,从而可以避免在目标项目的根目录新建入口文件,实现了在目标项目集成vite开发服务的升级过程中零新增零配置的目的,有利于降低项目维护的成本。
步骤S206,将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目。
在本实施例中,通过将经过转换后得到的目标配置对象导出至目标入口文件内,从而可以完成在目标项目集成vite开发服务的升级过程。另外,通过执行启动命令可以启动升级后的目标项目,且升级后的目标项目在运行过程中可以启用vite开发服务器的服务功能,即目标项目能够享受vite开发服务器带来的开发体验的提升。
本申请在基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理后,会先读取目标项目的配置文件以及获取与vite开发服务器对应的预设的配置数据,并将配置数据传入配置文件内,然后将配置文件内包含的所有配置对象转换成与vite开发服务器对应的目标配置对象,之后读取目标项目的指定目录下的主页面文件,并对主页面文件加入指定标签引用,生成与vite开发服务器对应的目标入口文件,最后将目标配置对象导出至目标入口文件内,并执行启动命令以启动目标项目,以完成在目标项目中集成vite开发服务的升级过程。通过采用本申请的项目升级方式对目标项目进行升级处理,可以避免在目标项目的根目录新建入口文件和配置文件,实现了在目标项目集成vite开发服务的升级过程中零新增零配置的目的,有效地减少了开发人员的开发工作量,降低了项目维护的成本,提高了项目升级的处理效率。
在一些可选的实现方式中,在步骤S206之后,上述电子设备还可以执行以下步骤:
获取所述目标项目的标识信息。
在本实施例中,所述标识信息可包括目标项目的项目名称。
基于预设的权限数据表确定出与所述标识信息对应的目标权限配置信息。
在本实施例中,所述权限数据表为根据实际需求预先创建的用于对项目的权限信息进行统计的数据表,该权限数据表内存储有多个项目的项目名称信息,以及与每一个项目名称信息分别对应的权限配置信息。其中,所述权限配置信息为用户预先自定义确定的对于各个项目中的哪些具体权限进行管理的信息。
获取所述目标项目的路由信息。
在本实施例中,获取目标项目的路由信息的过程可包括:先获取所述目标项目的框架类型;再基于所述框架类型获取所述目标项目的路由文件;后续基于所述路由文件获取所述目标项目的路由信息。
从所述路由信息中确定出与所述目标权限配置信息对应的目标路由。
在本实施例中,所述目标路由对应着路由信息中需要进行权限管理的相关路由。
基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目。
在本实施例中,所述权限配置组件可为用于专门对项目进行权限管理的组件,该权限配置组件可以存储于预先生成的权限配置文件内。通过将高阶组件添加到需要添加权限的路由内部,此时便可以对整个项目的路由进行权限的管理。其中,所述权限配置代码可为根据实际需求添加的自定义权限代码,通过在目标项目中添加该权限配置代码可以获得自定义的控制权限。对于基础的前端项目,通过自动对该目标项目添加权限,从而可以得到带有权限管理功能的目标项目,使得用户可以添加自定义注入的权限配置代码,从而得到相应的权限目标项目。
本申请在完成对目标项目的升级后,还可智能便捷地对目标项目进行权限管理处理,通过在目标项目中使用路由信息添加权限管理,自动生成相关权限,使得用户可以自定义权限配置代码,实现较复杂的权限管理功能,可有效节省项目开发的人力成本,提高了对目标项目的权限管理的处理效率,提高了对目标项目的权限管理的智能性。
在本实施例的一些可选的实现方式中,上述基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目,包括以下步骤:
获取所述权限配置组件以及所述权限配置代码。
在本实施例中,在获取到目标项目的路由信息后,会预先构建一个权限配置文件,然后在该权限管理文件内部自动构建用于进行对于项目进行权限管理的权限配置组件。其中,在创建生成权限配置组件后会对该权限配置组件进行存储,以便后续可以基于相应的获取指令来获取权限配置组件。同理,在编写生成权限配置代码后会对该权限配置代码进行存储,以便后续可以基于相应的获取指令来获取权限配置代码。
将所述权限配置组件添加至所述目标项目的所述目标路由内,得到第一目标项目。
在本实施例中,上述权限配置组件具体可为高阶组件,高阶组件(high-ordercomponent)类似于高阶函数,用于接收React组件作为输入,输出一个新的React组件,高阶组件让代码更具有复用性、逻辑性与抽象特征,可以对render方法作劫持,也可以控制props与state,高阶函数的实现原理包括如果一个函数操作其他函数,即将其他函数作为参数或将函数作为返回值。具体地,可新建一个文件将高阶组件进行封装,再设定路由组件和预设字段,通过该预设字段对该路由组件进行验证,进而实现权限管理,从而得到相应的第一目标项目。
将所述权限配置代码注入至所述第一目标项目内,得到第二目标项目。
在本实施例中,上述权限配置代码可为根据实际的权限管理需求预先编写生成的代码数据,可以采用自定义注入的方式将该权限配置代码注入至第一目标项目内,从而最终得到权限目标项目。
将所述第二目标项目作为所述权限目标项目。
本申请通过使用权限配置组件以及权限配置代码在目标项目中添加权限管理,从而自动生成相关权限,实现较复杂的权限管理功能,可有效节省项目开发的人力成本,提高了对目标项目的权限管理的智能性。
在一些可选的实现方式中,上述获取所述目标项目的路由信息,包括以下步骤:
获取所述目标项目的框架类型。
在本实施例中,所述框架类型可包括React框架或Vue框架。
基于所述框架类型获取所述目标项目的路由文件。
在本实施例中,需要判断当前使用的是vue框架还是React框架,进而可以根据不同的框架特点来查找出目标项目中是否存在路由文件,假如此时查询到的目标项目的框架类型为React框架,则会根据路由文件得到路由信息,再把路由信息进行保存。
基于所述路由文件获取所述目标项目的路由信息。
本申请通过基于目标项目的框架类型来获取到目标项目的路由文件,进而可以根据路由文件快速地得到相应的路由信息,有利于后续可以根据得到的路由信息来快速准确地确定出目标路由。
在一些可选的实现方式中,上述基于预设的权限数据表确定出与所述标识信息对应的目标权限配置信息,包括以下步骤:
调用所述权限数据表。
在本实施例中,在创建生成权限数据表后会对该权限数据表进行存储,以便后续可以基于相应的调用指令来调用出该权限数据表。
基于预设的并行比较指令,分别将所述标识信息与所述权限数据表中的每一个标识进行匹配处理,从所述权限数据表中筛选出与所述标识信息相同的目标标识。
在本实施例中,上述并行比较指令具体可为单指令流多数据流(singleinstruction multiple data,SIMD)指令。
从所述权限数据表中提取出与所述目标标识对应的权限配置信息。
在本实施例中,在匹配得到与标识信息相同的目标标识后,可进一步根据该目标标识从权限数据表中提取出相对应的权限配置信息以作为与目标项目对应的目标权限配置信息。
将所述权限配置信息作为所述目标权限配置信息。
本申请通过利用并行比较指令的并行计算能力,来同时对标识信息与权限数据表中的每一个标识进行一一对应的数据比较处理来得到相应的多个数据比较信息,进而能够根据该数据比较信息来查找出与标识信息相同的目标标识,有效地提高了标识信息之间的比对处理速率,进而可以快速地查找出与目标标识对应的权限配置信息,有效提高了目标权限配置信息的生成速率。
在本实施例的一些可选的实现方式中,在所述基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目的步骤之后,上述电子设备还可以执行以下步骤:
获取所述目标项目的重要度信息。
在本实施例中,可以通过查询预设的重要度数据表来获取到目标项目的重要度信息。其中,可预先生成有一个重要度数据表,该重要度数据表内存储有每一个项目的重要度信息。重要度信息可包括重要性高,重要性中,重要性低。另外,对于不同的重要度信息,重要度数据表还可预先设置有与各种重要度信息分别对应的数据存储方式。具体的重要性高对应的存储方式可为区块链存储,重要性中的存储方式可为本地存储,重要性低的存储方式为无需存储。
确定与所述重要度信息对应的存储方式。
在本实施例中,在到了目标项目的重要度信息,可进一步基于该目标项目的重要度信息从重要度数据表中查询出对应的存储方式。
基于所述存储方式对所述权限目标项目进行存储处理。
本申请通过获取目标项目的重要度信息,进而会对不同重要度信息的项目进行相对应的数据存储,有效的提高了数据存储的智能性,也保证了生成的重要度较高的项目的数据安全性。
在本实施例的一些可选的实现方式中,步骤S201包括以下步骤:
调用所述脚手架工具。
在本实施例中,上述脚手架工具为预先创建的用于封装vite开发服务器启动项目的能力的vue-cli工具。
获取预设的封装命令。
在本实施例中,上述封装命令具体为pafe-cli-service vite命令。Vue-cli-service是vue-cli工具常用的服务命令,pafe为目标项目的项目名称。
通过所述脚手架工具运行所述封装命令,以对所述vite开发服务器的启动命令进行封装处理。
在本实施例中,通过使用脚手架工具运行封装命令,也即把官方的vite开发服务器的启动命令通过脚手架工具进行封装,可以在不引入新的依赖的情况下引入vite开发服务器的能力,也方便后续目标项目的更新升级的执行。
本申请通过利用脚手架工具运行预设的封装命令,以对vite开发服务器的启动命令进行封装处理,从而可以在不引入新的依赖的情况下引入vite开发服务器的能力,有利于后续目标项目的更新升级的快速执行。
需要强调的是,为进一步保证上述目标项目的私密和安全性,上述目标项目还可以存储于一区块链的节点中。
本申请所指区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链(Blockchain),本质上是一个去中心化的数据库,是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一批次网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
本申请实施例可以基于人工智能技术对相关的数据进行获取和处理。其中,人工智能(Artificial Intelligence,AI)是利用数字计算机或者数字计算机控制的机器模拟、延伸和扩展人的智能,感知环境、获取知识并使用知识获得最佳结果的理论、方法、技术及应用***。
人工智能基础技术一般包括如传感器、专用人工智能芯片、云计算、分布式存储、大数据处理技术、操作/交互***、机电一体化等技术。人工智能软件技术主要包括计算机视觉技术、机器人技术、生物识别技术、语音处理技术、自然语言处理技术以及机器学习/深度学习等几大方向。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机可读指令来指令相关的硬件来完成,该计算机可读指令可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,前述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)等非易失性存储介质,或随机存储记忆体(Random Access Memory,RAM)等。
应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
进一步参考图3,作为对上述图2所示方法的实现,本申请提供了一种项目处理装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图3所示,本实施例所述的项目处理装置300包括:封装模块301、读取模块302、第一获取模块303、转换模块304、生成模块305以及启动模块306。其中:
封装模块301,用于基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理;
读取模块302,用于读取目标项目的配置文件;
第一获取模块303,用于获取与所述vite开发服务器对应的预设的配置数据,并将所述配置数据传入所述配置文件内;
转换模块304,用于将所述配置文件内包含的所有配置对象转换成与所述vite开发服务器对应的目标配置对象;
生成模块305,用于读取所述目标项目的指定目录下的主页面文件,并对所述主页面文件加入指定标签引用,生成与所述vite开发服务器对应的目标入口文件;
启动模块306,用于将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目。
在本实施例中,上述模块或单元分别用于执行的操作与前述实施方式的项目处理方法的步骤一一对应,在此不再赘述。
在本实施例的一些可选的实现方式中,项目处理装置还包括:
第二获取模块,用于获取所述目标项目的标识信息;
第一确定模块,用于基于预设的权限数据表确定出与所述标识信息对应的目标权限配置信息;
第三获取模块,用于获取所述目标项目的路由信息;
第二确定模块,用于从所述路由信息中确定出与所述目标权限配置信息对应的目标路由;
配置模块,用于基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目。
在本实施例中,上述模块或单元分别用于执行的操作与前述实施方式的项目处理方法的步骤一一对应,在此不再赘述。
在本实施例的一些可选的实现方式中,配置模块包括:
第一获取子模块,用于获取所述权限配置组件以及所述权限配置代码;
添加子模块,用于将所述权限配置组件添加至所述目标项目的所述目标路由内,得到第一目标项目;
注入子模块,用于将所述权限配置代码注入至所述第一目标项目内,得到第二目标项目;
第一确定子模块,用于将所述第二目标项目作为所述权限目标项目。
本实施例中,上述模块或单元分别用于执行的操作与前述实施方式的项目处理方法的步骤一一对应,在此不再赘述。
在本实施例的一些可选的实现方式中,第二确定模块包括:
第二获取子模块,用于获取所述目标项目的框架类型;
第三获取子模块,用于基于所述框架类型获取所述目标项目的路由文件;
第四获取子模块,用于基于所述路由文件获取所述目标项目的路由信息。
在本实施例中,上述模块或单元分别用于执行的操作与前述实施方式的项目处理方法的步骤一一对应,在此不再赘述。
在本实施例的一些可选的实现方式中,第一确定模块包括:
第一调用子模块,用于调用所述权限数据表;
匹配子模块,用于基于预设的并行比较指令,分别将所述标识信息与所述权限数据表中的每一个标识进行匹配处理,从所述权限数据表中筛选出与所述标识信息相同的目标标识;
提取子模块,用于从所述权限数据表中提取出与所述目标标识对应的权限配置信息;
第二确定子模块,用于将所述权限配置信息作为所述目标权限配置信息。
在本实施例中,上述模块或单元分别用于执行的操作与前述实施方式的项目处理方法的步骤一一对应,在此不再赘述。
在本实施例的一些可选的实现方式中,项目处理装置还包括:
第四获取模块,用于获取所述目标项目的重要度信息;
第三确定模块,用于确定与所述重要度信息对应的存储方式;
存储模块,用于基于所述存储方式对所述权限目标项目进行存储处理。
在本实施例中,上述模块或单元分别用于执行的操作与前述实施方式的项目处理方法的步骤一一对应,在此不再赘述。
在本实施例的一些可选的实现方式中,封装模块301,包括:
第二调用子模块,用于调用所述脚手架工具;
第五获取子模块,用于调获取预设的封装命令;
封装子模块,用于所述脚手架工具运行所述封装命令,以对所述vite开发服务器的启动命令进行封装处理。
在本实施例中,上述模块或单元分别用于执行的操作与前述实施方式的项目处理方法的步骤一一对应,在此不再赘述。
为解决上述技术问题,本申请实施例还提供计算机设备。具体请参阅图4,图4为本实施例计算机设备基本结构框图。
所述计算机设备4包括通过***总线相互通信连接存储器41、处理器42、网络接口43。需要指出的是,图中仅示出了具有组件41-43的计算机设备4,但是应理解的是,并不要求实施所有示出的组件,可以替代的实施更多或者更少的组件。其中,本技术领域技术人员可以理解,这里的计算机设备是一种能够按照事先设定或存储的指令,自动进行数值计算和/或信息处理的设备,其硬件包括但不限于微处理器、专用集成电路(ApplicationSpecific Integrated Circuit,ASIC)、可编程门阵列(Field-Programmable GateArray,FPGA)、数字处理器(Digital Signal Processor,DSP)、嵌入式设备等。
所述计算机设备可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述计算机设备可以与用户通过键盘、鼠标、遥控器、触摸板或声控设备等方式进行人机交互。
所述存储器41至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等。在一些实施例中,所述存储器41可以是所述计算机设备4的内部存储单元,例如该计算机设备4的硬盘或内存。在另一些实施例中,所述存储器41也可以是所述计算机设备4的外部存储设备,例如该计算机设备4上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(FlashCard)等。当然,所述存储器41还可以既包括所述计算机设备4的内部存储单元也包括其外部存储设备。本实施例中,所述存储器41通常用于存储安装于所述计算机设备4的操作***和各类应用软件,例如项目处理方法的计算机可读指令等。此外,所述存储器41还可以用于暂时地存储已经输出或者将要输出的各类数据。
所述处理器42在一些实施例中可以是中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器、或其他数据处理芯片。该处理器42通常用于控制所述计算机设备4的总体操作。本实施例中,所述处理器42用于运行所述存储器41中存储的计算机可读指令或者处理数据,例如运行所述项目处理方法的计算机可读指令。
所述网络接口43可包括无线网络接口或有线网络接口,该网络接口43通常用于在所述计算机设备4与其他电子设备之间建立通信连接。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例中,在基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理后,会先读取目标项目的配置文件以及获取与vite开发服务器对应的预设的配置数据,并将配置数据传入配置文件内,然后将配置文件内包含的所有配置对象转换成与vite开发服务器对应的目标配置对象,之后读取目标项目的指定目录下的主页面文件,并对主页面文件加入指定标签引用,生成与vite开发服务器对应的目标入口文件,最后将目标配置对象导出至目标入口文件内,并执行启动命令以启动目标项目,以完成在目标项目中集成vite开发服务的升级过程。通过采用本申请实施例的项目升级方式对目标项目进行升级处理,可以避免在目标项目的根目录新建入口文件和配置文件,实现了在目标项目集成vite开发服务的升级过程中零新增零配置的目的,有效地减少了开发人员的开发工作量,降低了项目维护的成本,提高了项目升级的处理效率。
本申请还提供了另一种实施方式,即提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可读指令,所述计算机可读指令可被至少一个处理器执行,以使所述至少一个处理器执行如上述的项目处理方法的步骤。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例中,在基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理后,会先读取目标项目的配置文件以及获取与vite开发服务器对应的预设的配置数据,并将配置数据传入配置文件内,然后将配置文件内包含的所有配置对象转换成与vite开发服务器对应的目标配置对象,之后读取目标项目的指定目录下的主页面文件,并对主页面文件加入指定标签引用,生成与vite开发服务器对应的目标入口文件,最后将目标配置对象导出至目标入口文件内,并执行启动命令以启动目标项目,以完成在目标项目中集成vite开发服务的升级过程。通过采用本申请实施例的项目升级方式对目标项目进行升级处理,可以避免在目标项目的根目录新建入口文件和配置文件,实现了在目标项目集成vite开发服务的升级过程中零新增零配置的目的,有效地减少了开发人员的开发工作量,降低了项目维护的成本,提高了项目升级的处理效率。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本申请各个实施例所述的方法。
显然,以上所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例,附图中给出了本申请的较佳实施例,但并不限制本申请的专利范围。本申请可以以许多不同的形式来实现,相反地,提供这些实施例的目的是使对本申请的公开内容的理解更加透彻全面。尽管参照前述实施例对本申请进行了详细的说明,对于本领域的技术人员来而言,其依然可以对前述各具体实施方式所记载的技术方案进行修改,或者对其中部分技术特征进行等效替换。凡是利用本申请说明书及附图内容所做的等效结构,直接或间接运用在其他相关的技术领域,均同理在本申请专利保护范围之内。
Claims (10)
1.一种项目处理方法,其特征在于,包括下述步骤:
基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理;
读取目标项目的配置文件;
获取与所述vite开发服务器对应的预设的配置数据,并将所述配置数据传入所述配置文件内;
将所述配置文件内包含的所有配置对象转换成与所述vite开发服务器对应的目标配置对象;
读取所述目标项目的指定目录下的主页面文件,并对所述主页面文件加入指定标签引用,生成与所述vite开发服务器对应的目标入口文件;
将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目。
2.根据权利要求1所述的项目处理方法,其特征在于,在所述将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目的步骤之后,还包括:
获取所述目标项目的标识信息;
基于预设的权限数据表确定出与所述标识信息对应的目标权限配置信息;
获取所述目标项目的路由信息;
从所述路由信息中确定出与所述目标权限配置信息对应的目标路由;
基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目。
3.根据权利要求2所述的项目处理方法,其特征在于,所述基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目的步骤,具体包括:
获取所述权限配置组件以及所述权限配置代码;
将所述权限配置组件添加至所述目标项目的所述目标路由内,得到第一目标项目;
将所述权限配置代码注入至所述第一目标项目内,得到第二目标项目;
将所述第二目标项目作为所述权限目标项目。
4.根据权利要求2所述的项目处理方法,其特征在于,所述获取所述目标项目的路由信息的步骤,具体包括:
获取所述目标项目的框架类型;
基于所述框架类型获取所述目标项目的路由文件;
基于所述路由文件获取所述目标项目的路由信息。
5.根据权利要求2所述的项目处理方法,其特征在于,所述基于预设的权限数据表确定出与所述标识信息对应的目标权限配置信息的步骤,具体包括:
调用所述权限数据表;
基于预设的并行比较指令,分别将所述标识信息与所述权限数据表中的每一个标识进行匹配处理,从所述权限数据表中筛选出与所述标识信息相同的目标标识;
从所述权限数据表中提取出与所述目标标识对应的权限配置信息;
将所述权限配置信息作为所述目标权限配置信息。
6.根据权利要求2所述的项目处理方法,其特征在于,在所述基于预设的权限配置组件与预设的权限配置代码对所述目标项目进行权限配置处理,得到相应的权限目标项目的步骤之后,还包括:
获取所述目标项目的重要度信息;
确定与所述重要度信息对应的存储方式;
基于所述存储方式对所述权限目标项目进行存储处理。
7.根据权利要求1所述的项目处理方法,其特征在于,所述基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理的步骤,具体包括:
调用所述脚手架工具;
获取预设的封装命令;
通过所述脚手架工具运行所述封装命令,以对所述vite开发服务器的启动命令进行封装处理。
8.一种项目处理装置,其特征在于,包括:
封装模块,用于基于预设的脚手架工具对vite开发服务器的启动命令进行封装处理;
读取模块,用于读取目标项目的配置文件;
第一获取模块,用于获取与所述vite开发服务器对应的预设的配置数据,并将所述配置数据传入所述配置文件内;
转换模块,用于将所述配置文件内包含的所有配置对象转换成与所述vite开发服务器对应的目标配置对象;
生成模块,用于读取所述目标项目的指定目录下的主页面文件,并对所述主页面文件加入指定标签引用,生成与所述vite开发服务器对应的目标入口文件;
启动模块,用于将所述目标配置对象导出至所述目标入口文件内,并执行所述启动命令以启动所述目标项目。
9.一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机可读指令,所述处理器执行所述计算机可读指令时实现如权利要求1至7中任一项所述的项目处理方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机可读指令,所述计算机可读指令被处理器执行时实现如权利要求1至7中任一项所述的项目处理方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210699250.3A CN115098186A (zh) | 2022-06-20 | 2022-06-20 | 项目处理方法、装置、计算机设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210699250.3A CN115098186A (zh) | 2022-06-20 | 2022-06-20 | 项目处理方法、装置、计算机设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115098186A true CN115098186A (zh) | 2022-09-23 |
Family
ID=83291910
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210699250.3A Pending CN115098186A (zh) | 2022-06-20 | 2022-06-20 | 项目处理方法、装置、计算机设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115098186A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116069325A (zh) * | 2023-01-28 | 2023-05-05 | 深圳市明源云采购科技有限公司 | 前端项目构建方法、装置、设备及计算机可读存储介质 |
CN116149760A (zh) * | 2023-04-21 | 2023-05-23 | 广州三晶电气股份有限公司 | 基于Vue框架的前端项目打包方法及装置 |
CN117055949A (zh) * | 2023-10-11 | 2023-11-14 | 中博信息技术研究院有限公司 | 一种自动生成vite配置的方法和*** |
-
2022
- 2022-06-20 CN CN202210699250.3A patent/CN115098186A/zh active Pending
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116069325A (zh) * | 2023-01-28 | 2023-05-05 | 深圳市明源云采购科技有限公司 | 前端项目构建方法、装置、设备及计算机可读存储介质 |
CN116069325B (zh) * | 2023-01-28 | 2023-08-04 | 深圳市明源云采购科技有限公司 | 前端项目构建方法、装置、设备及计算机可读存储介质 |
CN116149760A (zh) * | 2023-04-21 | 2023-05-23 | 广州三晶电气股份有限公司 | 基于Vue框架的前端项目打包方法及装置 |
CN116149760B (zh) * | 2023-04-21 | 2023-07-14 | 广州三晶电气股份有限公司 | 基于Vue框架的前端项目打包方法及装置 |
CN117055949A (zh) * | 2023-10-11 | 2023-11-14 | 中博信息技术研究院有限公司 | 一种自动生成vite配置的方法和*** |
CN117055949B (zh) * | 2023-10-11 | 2024-02-09 | 中博信息技术研究院有限公司 | 一种自动生成vite配置的方法和*** |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN115098186A (zh) | 项目处理方法、装置、计算机设备及存储介质 | |
CN112416458A (zh) | 基于ReactNative的预加载方法、装置、计算机设备及存储介质 | |
CN106406844B (zh) | 实现通讯交互平台公众号菜单的方法和装置 | |
CN110532165B (zh) | 应用程序安装包特性检测方法、装置、设备及存储介质 | |
CN113536185B (zh) | 应用页面的加载方法、存储介质、及其相关设备 | |
CN114996619A (zh) | 一种页面显示的方法、装置、计算机设备及存储介质 | |
CN112631924A (zh) | 自动化测试方法、装置、计算机设备及存储介质 | |
CN112650905A (zh) | 基于标签的反爬虫方法、装置、计算机设备及存储介质 | |
CN112965721B (zh) | 基于Android的项目编译方法、装置、计算机设备及存储介质 | |
CN110765610B (zh) | Pdm集成方法、装置、计算机设备及存储介质 | |
CN111552663A (zh) | 文件一致性验证方法、装置、计算机设备及存储介质 | |
CN116382718A (zh) | 代码离线部署方法、装置、计算机设备及存储介质 | |
CN113656044B (zh) | 安卓安装包压缩方法、装置、计算机设备及存储介质 | |
CN115203674A (zh) | 一种应用程序自动登录方法、***、装置及存储介质 | |
CN114565316A (zh) | 基于微服务架构的任务发布方法、及相关设备 | |
CN114625372A (zh) | 组件自动编译方法、装置、计算机设备及存储介质 | |
CN114090066A (zh) | 用户界面卡片视图生成方法、装置、计算机设备及介质 | |
CN115344265A (zh) | 代码生成方法、装置、计算机设备及存储介质 | |
CN116595285B (zh) | 一种路由生成方法、装置、计算机设备及存储介质 | |
CN114371886A (zh) | 前端框架组件转换方法、装置、计算机设备及存储介质 | |
CN116302847B (zh) | 异常信息的动态采集方法、装置、计算机设备及介质 | |
CN116466945A (zh) | 数据展示方法、装置、计算机设备及存储介质 | |
CN114996616A (zh) | 基于浏览器的信息生成方法、装置、设备及存储介质 | |
CN115712441A (zh) | 模型部署方法、装置、计算机设备及存储介质 | |
CN114675813A (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 |