公开/公告号CN101655795A
专利类型发明专利
公开/公告日2010-02-24
原文格式PDF
申请/专利权人 金蝶软件(中国)有限公司;
申请/专利号CN200910177828.3
发明设计人 钟发然;
申请日2009-09-25
分类号
代理机构深圳市深佳知识产权代理事务所(普通合伙);
代理人彭愿洁
地址 518057 广东省深圳市南山区深南大道市高新技术产业园区W1-B4
入库时间 2023-12-17 23:31:30
法律状态公告日
法律状态信息
法律状态
2012-10-10
授权
授权
2010-04-28
实质审查的生效 IPC(主分类):G06F9/44 申请日:20090925
实质审查的生效
2010-02-24
公开
公开
技术领域
本发明涉及企业资源计划系统技术领域,具体涉及服务实例的创建方法和企业资源计划系统。
背景技术
在企业资源计划(ERP,Enterprise Resource Planning)系统中,创建服务实例(即企业服务实例)去执行服务方法是常见的服务使用场景之一。
创建服务实例,目前较常用的有三种方式:(1)直接创建;(2)使用各种设计模式进行创建,例如工厂方法;(3)由系统或容器进行依赖注入来进行创建,例如由系统或容器通过在构造方法中注入所需的服务,或者通过配置文件来指定注入的服务,从而实现服务实例的创建。
在对现有技术的研究和实践过程中,本发明的发明人发现,以上所述的各种创建方法的耦合性均较高,所谓耦合,指的是系统或模块或类之间的互相依赖关系,依赖越大,耦合就越高,运行和维护的成本也就越高。例如,如果需要增加新的创建服务类或者改变了配置文件或者增加新的创建方式,则需要对服务创建代码进行改变,甚至重新编写服务创建代码。
发明内容
本发明实施例提供服务实例的创建方法和企业资源计划系统,以实现零耦合。
一种服务实例的创建方法,其特征在于,包括:
通过读取创建标注确定解析创建处理类;
调用所述解析创建处理类;
通过预置的策略利用所述解析创建处理类获取待创建的服务实例的类型和创建方式;
根据所述服务实例的类型和创建方式创建服务实例。
一种企业资源计划系统,其特征在于,包括:
确定单元,用于通过读取创建标注确定解析创建处理类;
调用单元,用于调用所述确定单元确定的解析创建处理类;
获取单元,用于通过预置的策略利用所述调用单元调用的解析创建处理类获取待创建的服务实例的类型和创建方式;
创建单元,用于根据所述获取单元获取到的服务实例的类型和创建方式创建服务实例。
本发明实施例利用创建标注来标识和调用解析创建处理类,并通过预置的策略利用该解析创建处理类来确定创建方式,从而在保证各种创建方式自身的独立性的同时,将这多种创建方式整合起来,即可以兼容多种创建方式,使得在发生需要增加新的创建方式或需要对配置文件进行修改等情况时,可以不需要对服务创建代码进行修改或重新编写,即实现零耦合。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例一提供的方法的方法流程图;
图2是本发明实施例二提供的方法的方法流程图;
图3是本发明实施例提供的ERP系统的结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本发明实施例提供服务实例的创建方法和企业资源计划系统。以下分别进行详细说明。
实施例一、
本实施例将从ERP系统的角度进行描述。
一种服务实例的创建方法,在接收到用户输入的创建标注后,通过读取创建标注确定解析创建处理类,并调用该解析创建处理类,然后通过预置的策略利用所调用的解析创建处理类获取待创建的服务实例的类型和创建方式,最后根据该获取到的服务实例的类型和创建方式创建服务实例。如图1所示,具体流程可以如下:
101、通过读取创建标注确定解析创建处理类;
102、调用步骤101中所确定的解析创建处理类;
103、通过预置的策略利用步骤102中调用的解析创建处理类获取待创建的服务实例的类型和创建方式;其中,策略可以根据由设备提供方或用户进行预置。
例如,可以调用预置的配置文件;根据配置文件利用所述解析创建处理类获取待创建的服务实例的类型和创建方式。
又例如,可以通过查询数据库或注册表等可以保存配置和信息的模块,然后根据数据库或注册表等模块的记录利用步骤102中调用的解析创建处理类获取待创建的服务实例的类型和创建方式。
其中,创建方式可以是直接创建的方式、使用设计模式进行创建的方式和由系统/容器进行依赖注入以进行创建的方式中的任一种,也可以是其他的比如新配置的创建方式。
104、根据获取到的服务实例的类型和创建方式创建服务实例;例如,可以如下:
若步骤103中获取到的创建方式为直接创建的方式,则直接根据获取到的服务实例的类型创建服务实例;
若步骤103中获取到的创建方式为使用设计模式进行创建的方式,则调用该服务实例类型所对应的设计模式的类,以进行服务实例的创建;
若步骤103中获取到的创建方式为由系统/容器进行依赖注入以进行创建的方式,则使用配置文件中指定的类来创建服务实例,或根据类标注调用标注处理类,由标注处理类来创建服务实例;
若步骤103中获取到的创建方式为一种新的创建方式,则调用该新的创建方式来创建服务实例,等等。
需说明的是,为了描述方便以及便于区别,在本发明实施例中将创建服务实例的标注命名为创建标注,而将于创建方式相对应的标注称为类标注,应当理解的是,两者均为标注,只是应用的场景略有不同。
由上可知,本发明实施例利用创建标注来标识和调用解析创建处理类,并通过预置的策略利用该解析创建处理类来确定创建方式,从而在保证各种创建方式自身的独立性的同时,将这多种创建方式整合起来,即可以兼容多种创建方式,使得在发生需要增加新的创建方式或需要对配置文件进行修改等情况时,可以不需要对服务创建代码进行修改或重新编写,即实现零耦合。
实施例二、
根据实施例一所描述的方法,下面将举例作进一步详细说明。
假设某个服务类的名称为ERPService,需要创建的服务实例的名称为ServiceA,则,参见图2,创建过程可以如下:
201、ERP系统读取到创建标注:@ERPService,确定解析创建处理类为ERPService服务类的解析创建处理类;
202、ERP系统调用ERPService服务类的解析创建处理类;
203、ERP系统通过预置的策略利用ERPService服务类的解析创建处理获取待创建的服务实例的类型和创建方式,即交由ERPService服务类的解析创建处理类来处理创建;
例如,可以调用预置的配置文件;根据配置文件利用所述解析创建处理类获取待创建的服务实例的类型和创建方式;
又例如,可以通过查询数据库或注册表等可以保存配置和信息的模块,然后根据数据库或注册表等模块的记录利用调用的解析创建处理类获取待创建的服务实例的类型和创建方式。
其中,创建方式可以是直接创建的方式、使用设计模式进行创建的方式和由系统/容器进行依赖注入以进行创建的方式中的任一种,也可以是其他的比如新配置的创建方式。
假设在此解析创建处理类通过发射知道了需要创建出来的是一个ServiceA实例,则在确定创建方式为直接创建的方式时,执行步骤204;在确定创建方式为使用设计模式进行创建的方式时,执行步骤205;在确定创建方式为由系统/容器进行依赖注入以进行创建的方式时,执行步骤206;在确定创建方式为一种新的创建方式时,则执行步骤207;
204、缺省的创建一个ServiceA实例,即直接根据获取到的服务实例的类型创建个ServiceA实例;比如可以采用如下语法:
ERPService serviceA=new ServiceA(),即表明创建一个新的名称为“ServiceA”的服务实例;
205、调用该服务实例类型所对应的设计模式的类,以进行ServiceA实例的创建,比如,调用ServiceA的类工厂(即调用工厂类),来创建ServiceA实例,语法可以如下:
ERPService serviceA=ServiceAFactory.getInstance(),即表明通过类工厂创建一个新的名称为“ServiceA”的服务实例;
206、使用配置文件中指定的类来创建ServiceA实例,或根据类标注调用标注处理类,由标注处理类来创建ServiceA实例,比如存在一个@SUPERERPService标注处理类,则根据类标注“SUPERERPService”调用对应的标注处理类,然后交由这个标注处理类来创建ServiceA实例,等等。
(1)以Spring(当今流行的优秀开源框架之一)支持的方式为例,在此假设使用bean.xml作为配置文件,则使用配置文件中指定的类来创建ServiceA实例的语法可以如下:
ApplicationContext ctx=new //表示需要建立一个新的服务实例
FileSystemXmlApplicationContext(“bean.xml”);//表示使用bean.xml作为配置文件
IERPService serviceA=(ERPService)ctx.getBean(″ID001″);//表示ID001为唯一服务标识,配置文件中指向ServiceA服务
(2)以EJB3.0中的方式为例,假设用@EJB用于注入EJB业务对象,则由标注处理类来创建ServiceA实例的语法可以如下:
@EJB(beanName=“ServiceA”)//标注这是一个EJB服务,并且是“ServiceA”服务实例
private ERPService serviceA;//表示创建“ServiceA”服务实例
207、调用该新的创建方式来创建ServiceA实例。
当然,除了上面所列举的创建方式之外,还可以采用其他的创建方式,在此不再赘述。
当服务实例创建完毕后,可以返回创建好的ServiceA实例,以进行后续的其他操作。
由上可知,本发明实施例利用创建标注来标识和调用解析创建处理类,并通过预置的策略利用该解析创建处理类来确定创建方式,从而在保证各种创建方式自身的独立性的同时,将这多种创建方式整合起来,即可以兼容多种创建方式,使得在发生需要增加新的创建方式或需要对配置文件进行修改等情况时,可以不需要对服务创建代码进行修改或重新编写,即实现零耦合。而且,该方案的实施简便,具有较强的可读性和可维护性,便于用户理解(用户通过标注即可知道创建的是什么服务)。
实施例三、
为了更好地实施以上方法,本发明实施例还相应地提供一种企业资源计划系统,即ERP系统,如图3所示,该ERP系统包括确定单元301、调用单元302、获取单元303和创建单元304。
确定单元301,用于通过读取创建标注确定解析创建处理类;
调用单元302,用于调用确定单元301确定的解析创建处理类;
获取单元303,用于通过预置的策略利用调用单元302调用的解析创建处理类获取待创建的服务实例的类型和创建方式;其中,创建方式可以包括:直接创建的方式,或使用设计模式进行创建的方式,或由系统/容器进行依赖注入以进行创建的方式。
创建单元304,用于根据获取单元303获取到的服务实例的类型和创建方式创建服务实例。
其中,所述获取单元303,具体用于调用预置的配置文件,根据配置文件利用调用单元302调用的解析创建处理类获取待创建的服务实例的类型和创建方式;或者,
所述获取单元303,具体用于查询数据库或注册表,根据数据库或注册表的记录利用调用单元302调用的解析创建处理类获取待创建的服务实例的类型和创建方式。
其中,所述创建单元304包括直接创建子单元、设计模式创建子单元和依赖注入创建子单元;
直接创建子单元,用于当获取单元303获取到的创建方式为直接创建的方式时,直接根据所述服务实例的类型创建服务实例;
设计模式创建子单元,用于当获取单元303获取到的创建方式为使用设计模式进行创建的方式时,调用所述服务实例类型所对应的设计模式的类,以进行服务实例的创建;
依赖注入创建子单元,用于当获取单元303获取到的创建方式为由系统或容器进行依赖注入以进行创建的方式时,使用配置文件中指定的类来创建服务实例,或根据类标注调用标注处理类,由标注处理类来创建服务实例。
以上各个单元的具体实施,可参见前面实施例,在此不再赘述。
由上可知,本发明实施例的ERP系统利用创建标注来标识和调用解析创建处理类,并通过预置的策略利用该解析创建处理类来确定创建方式,从而在保证各种创建方式自身的独立性的同时,将这多种创建方式整合起来,即可以兼容多种创建方式,使得在发生需要增加新的创建方式或需要对配置文件进行修改等情况时,可以不需要对服务创建代码进行修改或重新编写,即实现零耦合。而且,该方案的实施简便,具有较强的可读性和可维护性,便于用户理解(用户通过标注即可知道创建的是什么服务)。
本领域普通技术人员可以理解上述实施例的各种方法中的全部或部分步骤是可以通过程序来指令相关的硬件来完成,该程序可以存储于一计算机可读存储介质中,存储介质可以包括:只读存储器(ROM,Read Only Memory)、随机存取记忆体(RAM,Random Access Memory)、磁盘或光盘等。
以上对本发明实施例所提供的服务实例的创建方法和企业资源计划系统进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。
机译: 创建服务网格实例,服务网格系统和多群集系统的方法
机译: 运行虚拟机实例的系统和方法,向虚拟机实例发布密钥的密钥服务器系统,能够将实例形成为虚拟机实例的虚拟机映像以及向虚拟机实例的密钥发布方法
机译: 在ip多媒体子系统中为基于非sip的移动站提供基于sip的实例消息服务以及针对该实例的实例消息代理服务的方法和系统