CN107341003B - 定制系统实现方法、计算机设备和存储介质 - Google Patents
定制系统实现方法、计算机设备和存储介质 Download PDFInfo
- Publication number
- CN107341003B CN107341003B CN201710453248.7A CN201710453248A CN107341003B CN 107341003 B CN107341003 B CN 107341003B CN 201710453248 A CN201710453248 A CN 201710453248A CN 107341003 B CN107341003 B CN 107341003B
- Authority
- CN
- China
- Prior art keywords
- system firmware
- customized
- partition
- configuration information
- code
- 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
Images
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/76—Adapting program code to run in a different environment; Porting
-
- 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
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本发明涉及一种定制系统实现方法、计算机设备和存储介质,所述方法包括:运行系统固件分区中的通用系统固件;通过运行的通用系统固件读取定制资源分区中的配置信息;获取所述配置信息中的定制属性标识;根据获取的定制属性标识确定代码执行路径;按照所述代码执行路径,从所述通用系统固件中选择系统代码并执行;通过执行的所述系统代码,从所述定制资源分区中加载定制资源。本申请提供的方案提高了定制系统的发布效率。
Description
技术领域
本发明涉及计算机技术领域,特别是涉及一种定制系统实现方法、计算机设备和存储介质。
背景技术
对于同一个产品,可能有不同的客户,而不同的客户可能有不同需求,为满足不同客户的不同需求,往往需要发布不同客户的定制系统。比如,同一个POS机(Point of Sale销售终端)产品,可能有来自中国银行、中国建设银行或中国农业银行等不同客户的定制,定制内容比如有开机动画,系统菜单定制,或安装内置app(Application计算机应用程序)等等。传统的解决方式是当需要根据不同客户的不同需求而定制系统时,需针对不同客户的不同需求发布不同版本系统固件的系统以满足客户需求。
然而基于传统的针对不同客户的不同需求发布不同版本系统固件的系统的方法,使得每个不同版本的系统固件都需要从头到尾的开发,从而导致定制系统发布效率低。
发明内容
基于此,有必要针对定制系统发布效率低的问题,提供一种定制系统实现方法、计算机设备和存储介质。
一种定制系统实现方法,所述方法包括:
运行系统固件分区中的通用系统固件;
通过运行的通用系统固件读取定制资源分区中的配置信息;
获取所述配置信息中的定制属性标识;
根据获取的定制属性标识确定代码执行路径;
按照所述代码执行路径,从所述通用系统固件中选择系统代码并执行;
通过执行的所述系统代码,从所述定制资源分区中加载定制资源。
一种计算机设备,包括存储器和处理器,所述存储器包括系统固件分区和定制资源分区,所述存储器存储有计算机可读指令,所述计算机可读指令被所述处理器执行时,使得所述处理器执行如下步骤。
运行系统固件分区中的通用系统固件;
通过运行的通用系统固件读取定制资源分区中的配置信息;
获取所述配置信息中的定制属性标识;
根据获取的定制属性标识确定代码执行路径;
按照所述代码执行路径,从所述通用系统固件中选择系统代码并执行;
通过执行的所述系统代码,从所述定制资源分区中加载定制资源。
一种计算机可读存储介质,存储有计算机可读指令,所述计算机可读指令被处理器执行时,使得所述处理器执行所述定制系统实现方法的步骤。
上述定制系统实现方法、计算机设备和存储介质,通过运行通用系统固件时读取定制资源分区中的配置信息来执行对应系统代码并加载定制资源,实现系统的定制。由于不同客户的定制系统都是由通用系统固件和对应客户需求的定制资源包共同完成的。通用系统固件开发完成后可反复使用,使得在针对不同客户的不同需求的定制系统开发中,只需再开发出对应客户需求的定制资源包即可完成定制系统,而一个定制资源包的开发效率远高于一个系统固件的开发效率,从而提高了定制系统的发布效率。
附图说明
图1为一个实施例中定制系统实现方法应用环境图;
图2为一个实施例中终端的内部结构示意图;
图3为一个实施例中定制系统实现方法的流程示意图;
图4为一个实施例中定制系统配置步骤的流程示意图;
图5为另一个实施例中定制系统配置步骤的流程示意图;
图6为一个实施例中通用系统固件测试步骤的流程示意图;
图7为一个实施例中定制资源包测试步骤的流程示意图;
图8为另一个实施例中定制系统实现方法的流程示意图。
具体实施方式
为了使本发明的技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
图1为一个实施例中定制系统实现方法的应用环境图。如图1所示,该应用环境包括终端110和服务器120。其中,终端可以是POS机、移动手机、平板电脑等;服务器可以是独立的物理服务器,也可以是多个物理服务器构成的服务器集群。终端110可以执行定制系统实现方法,利用系统固件分区中的通用系统固件,结合定制资源分区中的配置信息及相应的定制资源,实现定制系统。终端110可从服务器120获取通用系统固件并写入到系统固件分区中。终端110可从服务器120获取定制资源包,并将定制资源包中的定制资源及相应的配置信息写入到定制资源分区中。本领域技术人员可以理解,图1中示出的应用环境,仅仅是与本申请方案相关的部分场景,并不构成对本申请方案应用环境的限定。
图2为一个实施例中终端的内部结构示意图。如图2所示,该终端包括通过系统总线连接的处理器、非易失性存储介质、内存储器、摄像头、显示屏、USB接口和网络接口。其中,服务器的非易失性存储介质包括系统固件分区和定制资源分区,可存储有计算机可读指令,该计算机可读指令被处理器执行时,可使得处理器实现定制系统实现方法。该处理器用于提供计算和控制能力,支撑整个终端的运行。该内存储器中也可储存有计算机可读指令,该计算机可读指令被所述处理器执行时,可使得所述处理器执行定制系统实现方法。本领域技术人员可以理解,图2中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的终端的限定,具体的终端可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
如图3所示,在一个实施例中,提供了一种定制系统实现方法。本实施例主要以该方法应用于上述图2中的终端来举例说明。参照图3,该定制系统实现方法具体包括如下步骤:
S302,运行系统固件分区中的通用系统固件。
其中,系统固件分区是终端的存储器中用于存储通用系统固件的分区。系统固件是实现操作系统功能的固件。通用系统固件是实现不同的定制系统所公用的系统固件。通用系统固件可以是通用的Android系统固件。通用系统固件具有操作系统基础功能,如摄像头扫描功能、网络连接功能、触控驱动功能、打印功能和读卡功能等。通用系统固件具备可选则的定制功能,如应用程序安装校验功能或者客户权限判定功能等。终端可在启动过程中自动从系统固件分区加载通用系统固件到内存储器中运行。
S304,通过运行的通用系统固件读取定制资源分区中的配置信息。
其中,定制资源分区是终端的存储器中用于存储配置信息和定制资源的分区。定制资源分区可以与系统固件分区处于相同或者不同的存储介质中。配置信息是基于通用系统固件实现定制系统的功能所需配置的信息。
在一个实施例中,当运行通用系统固件时,终端可通过通用系统固件中的代码指令从定制资源分区的文件中读取定制资源分区中的配置信息。
S306,获取配置信息中的定制属性标识。
其中,定制属性是基于通用系统固件实现定制系统时可定制的属性。基于不同的定制属性,可以从通用系统固件中选择不同的系统代码执行,以实现不同的定制功能。定制属性标识用于唯一标识相应的定制属性。定制属性标识可以是客户名称或客户名称编码。客户名称比如“ccb”,是中国建设银行的英文缩写。配置信息中包含有定制属性标识。
举例说明,定制资源分区中的配置信息包括“ro.customer.name=ccb”,其中“ro.customer.name”表示定制属性字段,“ccb”则是定制属性的值,表示定制属性标识。终端可通过读取定制资源分区中定制属性字段“ro.customer.name=ccb”的值“ccb”来获取定制属性标识。
308,根据获取的定制属性标识确定代码执行路径。
其中,代码执行路径是通用系统固件中实现定制功能的系统代码所执行的路径。不同的代码执行路径可实现不同的定制功能。通用系统固件集成了实现各种定制系统所需的系统代码,通过不同的代码执行路径可以选择不同的系统代码并执行,以实现不同的定制功能。
具体地,终端可在运行通用系统固件时,在运行到路径判断条件时,读取定制资源分区中的配置信息,获取配置信息中的定制属性标识,将获取的定制属性标识输入路径判断条件进行判断,从而确定与获取的定制属性标识对应的代码执行路径。举例说明,比如该终端获取的定制属性标识为“ccb”,则该终端选择判断条件与定制属性标识“ccb”相符的对应的代码执行路径。
S310,按照代码执行路径,从通用系统固件中选择系统代码并执行。
其中,系统代码是能实现具体功能的代码。具体地,终端根据已选择的确定的代码执行路径,从通用系统固件中选择对应的系统代码并按代码执行路径的逻辑执行代码。
S312,通过执行的系统代码,从定制资源分区中加载定制资源。
其中,定制资源是定制系统中能实现定制功能的资源,比如定制的开机动画、定制的背景图片或者定制的应用程序等。定制的应用程序可以配置为默认开机启动。
具体地,终端通过执行通用系统固件中选择的与代码执行路径相对应的系统代码,加载定制资源分区中的定制资源,实现定制系统的定制功能。
上述定制系统实现方法,通过运行通用系统固件时读取定制资源分区中的配置信息来执行对应系统代码并加载定制资源,实现系统的定制。由于不同客户的定制系统都是由通用系统固件和对应客户需求的定制资源包共同完成的。通用系统固件开发完成后可反复使用,使得在针对不同客户的不同需求的定制系统开发中,只需再开发出对应客户需求的定制资源包即可完成定制系统,而一个定制资源包的开发效率远高于一个系统固件的开发效率,从而提高了定制系统的发布效率。
如图4所示,在一个实施例中,在步骤S302之前,该定制系统实现方法还包括定制系统配置步骤,定制系统配置步骤具体包括:
S402,获取通用系统固件。
在一个实施例中,终端可以通过USB接口连接或网络连接等通信方式从服务器获取通用系统固件。
S404,将获取的通用系统固件写入系统固件分区。
在一个实施例中,终端可将获取的通用系统固件通过烧录工具直接烧录到系统固件分区上。
在另一个实施例中,终端可将获取到的通用系统固件通过硬件接口和相关软件传输到终端的内存储器中,再用U-boot(Universal Boot Loader,即系统启动的入口点)的命令将通用系统固件写入到系统固件分区。
S406,获取定制资源包。
在一个实施例中,终端可以通过USB接口连接或网络连接等通信方式从服务器获取定制资源包。
S408,将定制资源包中的配置信息和相应的定制资源写入到定制资源分区。
在一个实施例中,终端可从定制资源包中解析出配置信息和定制资源,从而将配置信息和定制资源通过烧录工具直接烧录到定制资源分区。
S410,重启该终端。
具体地,可通过断开该终端电源,再重新供给电源后复位该终端硬件设备并初始化该终端操作系统。
在本实施例中,通过获取和写入通用系统固件到系统固件分区,获取定制资源包并将定制资源包中的配置信息和定制资源写入到定制资源分区,完成定制系统的配置,为定制系统实现方法的实施提供了物理基础。
如图5所示,在一个实施例中,定制系统配置步骤还包括:
S502,获取通用系统固件。
S504,将获取的通用系统固件写入系统固件分区。
S506,获取定制资源包。
S508,获取定制资源包中的数字签名和公钥。
其中,数字签名是进行信息鉴别的数据。信息鉴别具体可以是对定制资源包的来源和完整性的鉴别。数字签名可通过私钥加密方式生成,其中私钥是私用密钥。公钥是与私钥相对应的公开的密匙。
在一个实施例中,服务器可对定制资源包的摘要信息用私钥加密得到数字签名。终端通过获取定制资源包,从定制资源包中获取数字签名和与私钥对应的公钥。
S510,根据公钥解密数字签名后进行校验。
其中,对数字签名进行校验,是对数字签名的合法性进行检验。校验通过说明定制资源包的信息完整未被篡改。
在一个实施例中,终端使用公钥解密被加密的定制资源包的摘要信息,然后用哈希函数对收到的定制资源包产生一个摘要信息,将收到的定制资源包的摘要信息与通过公钥解密的摘要信息比对,如果相同,则说明对定制资源包的数字签名校验通过;如果不相同,则说明对定制资源包的数字签名校验不通过。
S512,当校验通过、且公钥与生成通用系统固件中数字签名的公钥一致时,将定制资源包中的配置信息和相应的定制资源写入到定制资源分区。其中,当对定制资源包校验通过后,说明定制资源包的信息完整未被篡改,当定制资源包中的公钥与通用系统固件中的公钥一致时说明定制资源包与通用系统固件来源一致。
S514,重启该终端。
在本实施例中,通过校验定制资源包的数字签名保证了定制资源包的信息完整未被篡改,当定制资源包中的公钥与通用系统固件中的公钥一致时说明定制资源包与通用系统固件来源一致,从而保证了定制系统的安全。
在一个实施例中,在步骤S304之后,该定制系统实现方法还包括:当定制资源分区中不存在配置信息时,从通用系统固件中获取默认代码执行路径;按照默认代码执行路径,从通用系统固件中选择系统代码并执行。
其中,默认代码执行路径是当系统没有定制功能时通用系统固件中系统代码所执行的路径。具体地,当运行通用系统固件时,通过通用系统固件中的代码指令从定制资源分区的文件中未读取到配置信息时,则满足通用系统固件中默认代码执行路径的选择条件,则该终端从通用系统固件中选择系统代码并按默认代码执行路径的逻辑执行该代码。
在本实施例中,当定制资源分区中不存在配置信息时,选择默认代码路径并加载系统代码,可实现普通系统功能,完成非定制系统的实现。
在一个实施例中,步骤S304之后,该定制系统实现方法还包括通用系统固件测试步骤,通用系统固件测试步骤具体包括:在系统固件分区中写入通用系统固件,并保持定制资源分区为空;当定制资源分区中不存在配置信息时,从通用系统固件中获取默认代码执行路径;按照默认代码执行路径,从通用系统固件中选择系统代码并执行。
在一个实施例中,通用系统固件测试步骤还具体包括:
S602,获取通用系统固件。
S604,将获取的通用系统固件写入系统固件分区。
S606,运行系统固件分区中的通用系统固件。
S608,通过运行的通用系统固件读取定制资源分区中的配置信息。
S610,当定制资源分区中不存在配置信息时,从通用系统固件中获取默认代码执行路径。
S612,按照默认代码执行路径,从通用系统固件中选择系统代码并执行。
在本实施例中,通过保持定制资源为空,运行通用系统固件时从通用系统固件中获取默认代码执行路径并执行系统代码可以实现对通用系统固件的测试。
如图7所述,在一个实施例中,步骤S304之后,该定制系统实现方法还包括定制资源包测试步骤,定制资源包测试步骤具体包括:
S702,获取通用系统固件。
S704,将获取的通用系统固件写入系统固件分区。
S706,获取多个定制资源包。
S708,在定制资源分区中,写入多个定制资源包中其中一个定制资源包中的配置信息和相应的定制资源。
S710,通过运行的通用系统固件读取定制资源分区中的配置信息。
S712,获取配置信息中的定制属性标识。
S714,根据获取的定制属性标识确定代码执行路径。
S716,按照代码执行路径,从通用系统固件中选择系统代码并执行。
S718,通过执行的系统代码,从定制资源分区中加载定制资源。
S720,判断所有定制资源包是否均被轮次写入,若是,则执行步骤S722,若否,则跳转步骤S708。
S722,结束定制资源包测试。
在一个实施例中,终端可获取多个定制资源包,在定制资源分区中,轮次写入不同的定制资源包中的配置信息和相应的定制资源,通过运行通用系统固件读取定制资源分区中的配置信息,获取配置信息中的定制属性标识,根据获取的定制属性标识确定代码执行路径,按照代码执行路径,从通用系统固件中选择系统代码并执行,通过执行的系统代码,从定制资源分区中加载定制资源的步骤分别对轮次写入的定制资源包进行测试。其中,不同定制资源包中的配置信息和定制资源的写入顺序可以和获取定制资源包的顺序一致,也可以是随机写入。
在本实施例中通过轮次写入定制资源包并轮次测试定制资源包,以完成对定制系统的定制功能的测试。
如图8所示,在一个具体实施例中,定制系统实现方法包括以下步骤:
S802,获取通用系统固件。
S804,将获取的通用系统固件写入系统固件分区。
S806,获取定制资源包。
S808,获取定制资源包中的数字签名和公钥。
S810,根据公钥解密数字签名后进行校验。
S812,当校验通过、且公钥与生成通用系统固件中数字签名的公钥一致时,将定制资源包中的配置信息和相应的定制资源写入到定制资源分区。
S814,重启后,运行系统固件分区中的通用系统固件。
S816,通过运行的通用系统固件读取定制资源分区中的配置信息,当定制资源分区中的配置信息不为空时,执行步骤S818;当定制资源分区中的配置信息不存在时,执行步骤S826。
S818,获取配置信息中的定制属性标识。
S820,根据获取的定制属性标识确定代码执行路径。
S822,按照代码执行路径,从通用系统固件中选择系统代码并执行。
S824,通过执行的系统代码,从定制资源分区中加载定制资源。
S826,从通用系统固件中获取默认代码执行路径。
S828,按照默认代码执行路径,从通用系统固件中选择系统代码并执行。
在本实施例中,定制系统实现方法,通过获取并校验定制资源包,保障了定制系统的安全性。运行通用系统固件时读取定制资源分区中的配置信息来执行对应系统代码并加载定制资源,实现系统的定制。当定制资源分区中不存在配置信息时,选择默认代码路径并加载系统代码,可实现普通系统功能,实现非定制系统发布。由于不同客户的定制系统都是由通用系统固件和对应客户需求的定制资源包共同完成的。通用系统固件开发和测试完成后可反复使用,使得在针对不同客户的不同需求的定制系统开发中,只需再开发和测试对应客户需求的定制资源包即可完成定制系统,而一个定制资源包的开发和测试效率远高于一个系统固件的开发和测试效率,从而提高了定制系统的发布效率。
一种计算机设备,包括存储器和处理器,存储器包括系统固件分区和定制资源分区,存储器存储有计算机可读指令;计算机可读指令被处理器执行时,使得处理器执行如下步骤:
运行系统固件分区中的通用系统固件;通过运行的通用系统固件读取定制资源分区中的配置信息;获取配置信息中的定制属性标识;根据获取的定制属性标识确定代码执行路径;按照代码执行路径,从通用系统固件中选择系统代码并执行;通过执行的系统代码,从定制资源分区中加载定制资源。
上述定制系统实现计算机设备,通过运行通用系统固件时读取定制资源分区中的配置信息来执行对应系统代码并加载定制资源,实现系统的定制。由于不同客户的定制系统都是由通用系统固件和对应客户需求的定制资源包共同完成的。通用系统固件开发完成后可反复使用,使得在针对不同客户的不同需求的定制系统开发中,只需再开发出对应客户需求的定制资源包即可完成定制系统,而一个定制资源包的开发效率远高于一个系统固件的开发效率,从而提高了定制系统的发布效率。
在一个实施例中,计算机可读指令使得处理器在执行运行系统固件分区中的通用系统固件之前,还执行以下步骤:获取通用系统固件;将获取的通用系统固件写入系统固件分区;获取定制资源包;将定制资源包中的配置信息和相应的定制资源写入到定制资源分区;重启该计算机设备。
在一个实施例中,计算机可读指令使得处理器在执行将定制资源包中的配置信息和相应的定制资源写入到定制资源分区之前,还执行以下步骤:获取定制资源包中的数字签名和公钥;根据公钥解密数字签名后进行校验;当校验通过、且公钥与生成通用系统固件中数字签名的公钥一致时,将定制资源包中的配置信息和相应的定制资源写入到定制资源分区。
在一个实施例中,计算机可读指令使得处理器在执行通过运行的通用系统固件读取定制资源分区中的配置信息之后,还执行以下步骤:当定制资源分区中不存在配置信息时,从通用系统固件中获取默认代码执行路径;按照默认代码执行路径,从通用系统固件中选择系统代码并执行。
在一个实施例中,计算机可读指令被处理器执行时,使得处理器还执行如下通用系统固件测试步骤:在系统固件分区中写入通用系统固件,并保持定制资源分区为空;运行系统固件分区中的通用系统固件;通过运行的通用系统固件读取定制资源分区中的配置信息;当定制资源分区中不存在配置信息时,从通用系统固件中获取默认代码执行路径;按照默认代码执行路径,从通用系统固件中选择系统代码并执行。
在一个实施例中,计算机可读指令被处理器执行时,使得处理器还执行如下步骤轮次对定制资源包进行测试:在定制资源分区中,轮次写入不同的定制资源包中的配置信息和相应的定制资源,通过运行通用系统固件读取定制资源分区中的配置信息,获取配置信息中的定制属性标识,根据获取的定制属性标识确定代码执行路径,按照代码执行路径,从通用系统固件中选择系统代码并执行,通过执行的系统代码,从定制资源分区中加载定制资源的步骤分别对轮次写入的定制资源包进行测试。
一种计算机可读存储介质,其上存储有计算机可读指令,该计算机可读指令被处理器执行时实现以下步骤:
运行系统固件分区中的通用系统固件;通过运行的通用系统固件读取定制资源分区中的配置信息;获取配置信息中的定制属性标识;根据获取的定制属性标识确定代码执行路径;按照代码执行路径,从通用系统固件中选择系统代码并执行;通过执行的系统代码,从定制资源分区中加载定制资源。
在一个实施例中,计算机可读指令使得处理器在执行运行系统固件分区中的通用系统固件之前,还执行以下步骤:获取通用系统固件;将获取的通用系统固件写入系统固件分区;获取定制资源包;将定制资源包中的配置信息和相应的定制资源写入到定制资源分区;重启该计算机设备。
在一个实施例中,计算机可读指令使得处理器在执行将定制资源包中的配置信息和相应的定制资源写入到定制资源分区之前,还执行以下步骤:获取定制资源包中的数字签名和公钥;根据公钥解密数字签名后进行校验;当校验通过、且公钥与生成通用系统固件中数字签名的公钥一致时,将定制资源包中的配置信息和相应的定制资源写入到定制资源分区。
在一个实施例中,计算机可读指令使得处理器在执行通过运行的通用系统固件读取定制资源分区中的配置信息之后,还执行以下步骤:当定制资源分区中不存在配置信息时,从通用系统固件中获取默认代码执行路径;按照默认代码执行路径,从通用系统固件中选择系统代码并执行。
在一个实施例中,计算机可读指令被处理器执行时,使得处理器还执行如下通用系统固件测试步骤:在系统固件分区中写入通用系统固件,并保持定制资源分区为空;运行系统固件分区中的通用系统固件;通过运行的通用系统固件读取定制资源分区中的配置信息;当定制资源分区中不存在配置信息时,从通用系统固件中获取默认代码执行路径;按照默认代码执行路径,从通用系统固件中选择系统代码并执行。
在一个实施例中,计算机可读指令被处理器执行时,使得处理器还执行如下步骤轮次对定制资源包进行测试:在定制资源分区中,轮次写入不同的定制资源包中的配置信息和相应的定制资源,通过运行通用系统固件读取定制资源分区中的配置信息,获取配置信息中的定制属性标识,根据获取的定制属性标识确定代码执行路径,按照代码执行路径,从通用系统固件中选择系统代码并执行,通过执行的系统代码,从定制资源分区中加载定制资源的步骤分别对轮次写入的定制资源包进行测试。
上述计算机可读存储介质,通过运行通用系统固件时读取定制资源分区中的配置信息来执行对应系统代码并加载定制资源,实现系统的定制。由于不同客户的定制系统都是由通用系统固件和对应客户需求的定制资源包共同完成的。通用系统固件开发完成后可反复使用,使得在针对不同客户的不同需求的定制系统开发中,只需再开发出对应客户需求的定制资源包即可完成定制系统,而一个定制资源包的开发效率远高于一个系统固件的开发效率,从而提高了定制系统的发布效率。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的程序可存储于一非易失性计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,所述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)等。
以上所述实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
以上所述实施例仅表达了本发明的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干变形和改进,这些都属于本发明的保护范围。因此,本发明专利的保护范围应以所附权利要求为准。
Claims (10)
1.一种定制系统实现方法,由终端执行,所述方法包括:
运行系统固件分区中的通用系统固件;所述系统固件分区是所述终端的存储器中用于存储所述通用系统固件的分区,所述通用系统固件是实现不同的定制系统所公用的系统固件;
通过运行的通用系统固件读取定制资源分区中的配置信息;所述定制资源分区是所述终端的存储器中用于存储所述配置信息和定制资源的分区;
获取所述配置信息中的定制属性标识;
根据获取的定制属性标识确定代码执行路径;
按照所述代码执行路径,从所述通用系统固件中选择系统代码并执行;
通过执行的所述系统代码,从所述定制资源分区中加载定制资源。
2.根据权利要求1所述的方法,其特征在于,所述运行系统固件分区中的通用系统固件之前,所述方法还包括:
获取通用系统固件;
将获取的通用系统固件写入系统固件分区;
获取定制资源包;
将所述定制资源包中的配置信息和相应的定制资源写入到定制资源分区;
重启后,执行所述运行系统固件分区中的通用系统固件的步骤。
3.根据权利要求2所述的方法,其特征在于,所述将所述定制资源包中的配置信息和相应的定制资源写入到定制资源分区之前,所述方法还包括:
获取定制资源包中的数字签名和公钥;
根据所述公钥解密所述数字签名后进行校验;
当校验通过、且所述公钥与生成通用系统固件中数字签名的公钥一致时,执行所述将所述定制资源包中的配置信息和相应的定制资源写入到定制资源分区的步骤。
4.根据权利要求1所述的方法,其特征在于,所述通过运行的通用系统固件读取定制资源分区中的配置信息之后,所述方法还包括:
当所述定制资源分区中不存在所述配置信息时,从所述通用系统固件中获取默认代码执行路径;
按照所述默认代码执行路径,从所述通用系统固件中选择系统代码并执行。
5.根据权利要求4所述的方法,其特征在于,所述方法还包括:
在系统固件分区中写入通用系统固件,并保持定制资源分区为空,当所述定制资源分区中不存在所述配置信息时,从所述通用系统固件中获取默认代码执行路径;按照所述默认代码执行路径,从所述通用系统固件中选择系统代码并执行,以对通用系统固件进行测试;
在所述定制资源分区中,轮次写入不同的定制资源包中的配置信息和相应的定制资源,通过运行的通用系统固件读取定制资源分区中的配置信息;获取所述配置信息中的定制属性标识;根据获取的定制属性标识确定代码执行路径;按照所述代码执行路径,从所述通用系统固件中选择系统代码并执行;通过执行的所述系统代码,从所述定制资源分区中加载定制资源,以分别对轮次写入的定制资源包进行测试。
6.一种计算机设备,包括存储器和处理器,所述存储器包括系统固件分区和定制资源分区,所述存储器存储有计算机可读指令;所述计算机可读指令被所述处理器执行时,使得所述处理器执行如下步骤:
运行系统固件分区中的通用系统固件;所述系统固件分区是终端的存储器中用于存储所述通用系统固件的分区,所述通用系统固件是实现不同的定制系统所公用的系统固件;
通过运行的通用系统固件读取定制资源分区中的配置信息;所述定制资源分区是终端的存储器中用于存储所述配置信息和定制资源的分区;
获取所述配置信息中的定制属性标识;
根据获取的定制属性标识确定代码执行路径;
按照所述代码执行路径,从所述通用系统固件中选择系统代码并执行;
通过执行的所述系统代码,从所述定制资源分区中加载定制资源。
7.根据权利要求6所述的计算机设备,其特征在于,在所述运行系统固件分区中的通用系统固件之前,所述计算机可读指令还使得所述处理器执行:
获取通用系统固件;
将获取的通用系统固件写入系统固件分区;
获取定制资源包;
将所述定制资源包中的配置信息和相应的定制资源写入到定制资源分区;
重启后,执行所述运行系统固件分区中的通用系统固件的步骤。
8.根据权利要求6所述的计算机设备,其特征在于,在所述通过运行的通用系统固件读取定制资源分区中的配置信息之后,所述计算机可读指令还使得所述处理器执行:
当所述定制资源分区中不存在所述配置信息时,从所述通用系统固件中获取默认代码执行路径;
按照所述默认代码执行路径,从所述通用系统固件中选择系统代码并执行。
9.根据权利要求8所述的计算机设备,其特征在于,所述计算机可读指令还使得所述处理器执行:
在系统固件分区中写入通用系统固件,并保持定制资源分区为空,当所述定制资源分区中不存在所述配置信息时,从所述通用系统固件中获取默认代码执行路径;按照所述默认代码执行路径,从所述通用系统固件中选择系统代码并执行,以对通用系统固件进行测试;
在所述定制资源分区中,轮次写入不同的定制资源包中的配置信息和相应的定制资源,通过运行的通用系统固件读取定制资源分区中的配置信息;获取所述配置信息中的定制属性标识;根据获取的定制属性标识确定代码执行路径;按照所述代码执行路径,从所述通用系统固件中选择系统代码并执行;通过执行的所述系统代码,从所述定制资源分区中加载定制资源,以分别对轮次写入的定制资源包进行测试。
10.一种计算机可读存储介质,其特征在于,其上存储有计算机可读指令,所述计算机可读指令被处理器执行时,使得所述处理器执行如权利要求1至5中任一项所述方法的步骤。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710453248.7A CN107341003B (zh) | 2017-06-15 | 2017-06-15 | 定制系统实现方法、计算机设备和存储介质 |
PCT/CN2017/101788 WO2018227798A1 (zh) | 2017-06-15 | 2017-09-14 | 定制系统实现方法、计算机设备和计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710453248.7A CN107341003B (zh) | 2017-06-15 | 2017-06-15 | 定制系统实现方法、计算机设备和存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107341003A CN107341003A (zh) | 2017-11-10 |
CN107341003B true CN107341003B (zh) | 2020-08-07 |
Family
ID=60220618
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710453248.7A Active CN107341003B (zh) | 2017-06-15 | 2017-06-15 | 定制系统实现方法、计算机设备和存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN107341003B (zh) |
WO (1) | WO2018227798A1 (zh) |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108549555A (zh) * | 2018-04-10 | 2018-09-18 | Tcl通力电子(惠州)有限公司 | 客制化软件的处理方法、嵌入式系统设备及存储介质 |
CN108959116A (zh) * | 2018-06-15 | 2018-12-07 | 深圳市西迪特科技有限公司 | 设备定制信息的管理方法 |
CN109656638A (zh) * | 2018-12-20 | 2019-04-19 | 广东浪潮大数据研究有限公司 | 一种基于Purley平台的用户定制化功能的实现方法 |
CN111309338A (zh) * | 2020-02-12 | 2020-06-19 | 杭州涂鸦信息技术有限公司 | 一种差异固件的导入方法及系统 |
CN111679834B (zh) * | 2020-04-25 | 2024-01-23 | 华帝股份有限公司 | 一种物联网模组的自动烧录系统及其烧录方法 |
CN113779652A (zh) * | 2020-06-09 | 2021-12-10 | 华为技术有限公司 | 数据完整性保护的方法和装置 |
CN112306506B (zh) * | 2020-06-28 | 2023-08-22 | 神州融安科技(北京)有限公司 | 计算机程序的烧录方法、装置、电子设备及存储介质 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1525325A (zh) * | 1997-08-29 | 2004-09-01 | 实施定制计算机系统的软件安装和测试的系统设备及方法 | |
US20060074850A1 (en) * | 2004-10-01 | 2006-04-06 | Alain Bouchet | Flexible management process for multiple activities executed on partitionable platforms of a multiple processor system |
CN103812948A (zh) * | 2014-03-04 | 2014-05-21 | 湘潭大学 | 智能手机操作系统云端交互定制系统与方法 |
CN104461533A (zh) * | 2014-12-03 | 2015-03-25 | 重庆蓝岸通讯技术有限公司 | 一种基于Marvell LTE平台的系统固件定制方法 |
CN104778424A (zh) * | 2015-03-24 | 2015-07-15 | 四川长虹电器股份有限公司 | 基于智能电视防止rom刷机的方法 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8490082B2 (en) * | 2005-11-03 | 2013-07-16 | International Business Machines Corporation | System and method for representing user processes as software packages in a software package management system |
CN101847099A (zh) * | 2010-06-08 | 2010-09-29 | 用友软件股份有限公司 | 个性化配置应用功能的方法和装置 |
CN103984564B (zh) * | 2013-02-08 | 2018-04-27 | 百度国际科技(深圳)有限公司 | 安装软件、升级软件的方法及装置 |
CN103631587B (zh) * | 2013-11-15 | 2017-01-18 | 北京奇虎科技有限公司 | 一种软件安装包的定制方法和一种服务器 |
-
2017
- 2017-06-15 CN CN201710453248.7A patent/CN107341003B/zh active Active
- 2017-09-14 WO PCT/CN2017/101788 patent/WO2018227798A1/zh active Application Filing
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1525325A (zh) * | 1997-08-29 | 2004-09-01 | 实施定制计算机系统的软件安装和测试的系统设备及方法 | |
US20060074850A1 (en) * | 2004-10-01 | 2006-04-06 | Alain Bouchet | Flexible management process for multiple activities executed on partitionable platforms of a multiple processor system |
CN103812948A (zh) * | 2014-03-04 | 2014-05-21 | 湘潭大学 | 智能手机操作系统云端交互定制系统与方法 |
CN104461533A (zh) * | 2014-12-03 | 2015-03-25 | 重庆蓝岸通讯技术有限公司 | 一种基于Marvell LTE平台的系统固件定制方法 |
CN104778424A (zh) * | 2015-03-24 | 2015-07-15 | 四川长虹电器股份有限公司 | 基于智能电视防止rom刷机的方法 |
Also Published As
Publication number | Publication date |
---|---|
CN107341003A (zh) | 2017-11-10 |
WO2018227798A1 (zh) | 2018-12-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107341003B (zh) | 定制系统实现方法、计算机设备和存储介质 | |
CN109214168B (zh) | 固件升级方法及装置 | |
US10735427B2 (en) | Method and apparatus for managing program of electronic device | |
JP5891414B2 (ja) | 情報処理装置およびアプリケーション不正連携防止方法 | |
CN109492378A (zh) | 一种基于设备识别码的身份验证方法、服务器及介质 | |
US9325506B2 (en) | Cryptographically enforcing strict separation of environments | |
US10872155B2 (en) | Computing system for managing firmware and firmware managing method thereof | |
US20140244993A1 (en) | Method of updating the operating system of a secure microcircuit | |
KR20150008546A (ko) | 보안 다운로드 및 기능 실행방법 및 장치 | |
US9344406B2 (en) | Information processing device, information processing method, and computer program product | |
KR20170114582A (ko) | 영상처리장치 및 그 제어방법 | |
US10248795B2 (en) | Implementing method for JavaCard application function expansion | |
KR101695639B1 (ko) | 클라우드 기반의 애플리케이션 보안 서비스 제공 방법 및 시스템 | |
CN110874467B (zh) | 信息处理方法、装置、系统以及处理器、存储介质 | |
US20160147542A1 (en) | Information processing apparatus, server apparatus, information processing system, control method, and computer program | |
US11496304B2 (en) | Information processing device, information processing method, and storage medium | |
JP6517435B2 (ja) | アプリケーションを管理する方法 | |
CN108021801B (zh) | 基于虚拟桌面的防泄密方法、服务器及存储介质 | |
JP2019008592A (ja) | セキュアエレメント、コンピュータプログラム、デバイス、os起動システム及びos起動方法 | |
CN112231649A (zh) | 一种固件加密处理方法、装置、设备及介质 | |
CN114675865A (zh) | 空中下载技术升级方法、装置、存储介质及终端设备 | |
CN117453343A (zh) | 虚拟机度量、机密计算认证方法、设备、系统及存储介质 | |
US11281778B2 (en) | Device and method for verifying application | |
KR20220062866A (ko) | 네트워크 카메라 및 그의 보안 서비스 제공 방법 | |
US12095902B2 (en) | Information processing terminal, information processing device, information processing method, program, and information processing system |
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 |