将XMLSchema文档转换为Java代码的方法与流程

文档序号:15399613发布日期:2018-09-11 17:10阅读:186来源:国知局

本发明涉及一种在软件设计情况下使用的方法。更具体地说,本发明涉及一种用在软件设计情况下的将xmlschema文档转换为java代码的方法。



背景技术:

xml(extensiblemarkuplanguage)是一种数据描述和交换的通用格式,并已在internet上和企业内部得到了广泛应用。由于xml的通用性和可交换性,在武器装备综合保障领域xml被广泛用于描述综合保障数据。xmlschema是w3c推荐使用的标准,是xml应用的基础。xmlschema文档用来设计、约束和验证xml文档。xmlschema文档本身是一个xml文档,它符合xml语法结构。由于xml语法的复杂性,一般人员很难使用文本编辑器编写格式正确的xml文档,并且编写的xml文档也无法使用xmlschema对其进行验证。

当前国外有众多商业化的xml编辑软件,此类软件技术成熟,功能强大,能有效支持xml文档的编辑和验证。但武器装备综合保障数据具有高度保密性,因此不能将xml编辑软件集成到综合保障系统中。设计开发一个自主可控、功能强大的xml编辑软件能有效武器装备综合保障数据的编写效率,提高武器装备综合保障水平。如何xmlschema完整的用编程语言表示是xml编辑软件开发的基础也是最重要的部分,直接关系着xml编辑软件后续开发能否正常进行,本发明在此应用背景下产生。

而现有的专利技术,只能实现对xml中对象或内容的部分抽取,无法实现将其转换成直接的java代码,以供其它软件进行识别、编辑、设计或使用。



技术实现要素:

本发明的一个目的是解决至少上述问题和/或缺陷,并提供至少后面将说明的优点。

本发明还有一个目的是提供一种将xmlschema文档转换为java代码的方法,采用本发明能够将任何格式正确的xmlschema文档完整地转化为java对象,并能够依据xmlschema文档中元素之间的嵌套关系建立java对象之间的关系,实现xmlschema文档到java代码的翻译,为其它软件的深度开发设计、应用、修改、编译等提供基础,即基于本发明可以开发xml编辑软件、xml验证软件等一系列xml相关的软件。

为了实现根据本发明的这些目的和其它优点,提供了一种将xmlschema文档转换为java代码的方法,包括:

s1,建立与xmlschema标准定义的30种元素、12种限定元素相对应的java类,并依据元素、限定元素之间的嵌套关系建立java类之间的引用关系;

s2,解析单元用java语言实现dom编程接口以获取解析器实例,并基于解析器实例对待转换的xmlschema文档进行解析,以获取对应的解析文档以及解析文档的第一个元素n;

s3,对象创建单元接收第一个元素n,获取元素n对应的本地名称,基于本地名称调用对应的java类构造函数,为n创建相应的java对象,并以n为根元素,按照深度优先遍历次序依次为解析文档中每个元素创建对应java对象,以实现xmlschema文档到java代码的转换。

优选的是,其中,在s1中java类的建立包括:

为与xmlschema标准定义的每种元素定义分别建立对应的元素类;

为与xmlschema标准定义的所有限定元素定义一个共用的限定元素类。

优选的是,其中,所述元素类的定义包括:

s11,对各元素类中对应元素包括的每一个属性,定义相配合的第一变量,同时对第一变量的数据类型和初始值进行定义;

s12,对各元素类中对应元素包括的每一个子元素,定义配合的第二变量,同时对第二变量的数据类型和初始值进行定义;

s13,在各元素类中额外定义与该元素类相配合的三个第三变量及其相关数据类型。

优选的是,其中,所述元素类的定义还包括:

s14,为元素类定义对应的构造函数,包括:

所述第三变量包括三个与该元素类对应的元素a,a的父元素b以及b的根元素c;

基于第三变量的相关参数,将构造函数的相关参数赋值给元素类中相应的变量;

对元素a中的预定的相关属性,在构造函数中对其进行属性判断;

对元素a中的子元素,在构造函数中对其进行子元素判断。

优选的是,其中,所述限定元素类的建立包括:

s15,在限定元素类中为各限定元素的相关属性定义对应变量;

s16,为限定元素类定义构造函数,其包括各限定元素、以及与各限定元素对应的直接父元素类对象,且

在定义构造函数时将各限定元素的参数赋值给限定元素类中与各限定元素对应的变量,并在构造函数中对各限定元素包含的属性进行相应判断。

优选的是,其中,在s1中,还包括定义可供所有的java类实现的空接口(命名为thing),以作为java类构造函数第二传入参数的数据类型,以及存储预定元素类中相关变量的数据类型。

优选的是,其中,在s2中,解析器实例通过将xmlschema文档的url路径作为参数调用,以实现xmlschema文档的解析。

优选的是,其中,在s3中,对象创建单元接收第一元素n,并为n创建java对象的过程包括:

s31,接收n后,对其格式或是否是空文档进行判断,若是则结束,否则执行s32;

s32,获取元素n的本地名称,并基于本地名称所表示的类型,传入预定参数至构造函数;

s33,将构造函数的相关参数赋值给类中相应的变量;

s34,依次为元素的每个属性定义相应的属性判别函数,实现对元素所包含属性的处理。

s35,获取元素n的第一个子元素n′,并对n′是否为空进行判断,若其为空,则n′的父元素n的对象创建完成,进入s36,否则进入s37;

s36,若n的本地名称与根元素一致,则认为xmlschema文档中包含所有元素的对象创建完成,程序结束;

否则将创建的元素n的对象,赋值给元素n的父元素类中为n创建的对应变量,然后获取直接在元素n之后的元素n″,并将n″赋值给s35中的n′,再次执行s35;

s37,若n′与特定元素一致,则将元素n′赋值给s32中的元素n,否则执行s38;

s38,获取直接在元素n′的之后的元素n″′,并将n″′赋值给s35中的n′,再次执行s35。

优选的是,其中,在s32中,预定参数的传入包括:

若本地名称表示的是schema元素时,则向构造函数传入的参数为(n,null,null);

若本地名称表示的是除schema外的其它元素,则将(n,this,schema)作为参数传入构造函数;

若本地名称表示的是限定元素,则将(n,this)作为参数传入构造函数;

其中,this表示的是当前对象,schema是元素n所属的xmlschema文档的根元素的对象。

优选的是,其中,在s33中,若该类是元素类,则将构造函数的第三变量中a、b、c的参数分别赋值给类中对应的变量;

若该类是限定元素类,则将构造函数的相应参数赋值给类中相应的变量。

本发明至少包括以下有益效果:

其一,xmlschema文档转换得到的java对象依照源文档中元素的嵌套关系组织。

其二,在创建java对象时采用深度优先遍历算法,方法的时间复杂度为o(n),空间复杂度为o(n)。

其三,xmlschema文档转换得到的java对象中保存了源文档中包含的所有内容。

本发明的其它优点、目标和特征将部分通过下面的说明体现,部分还将通过对本发明的研究和实践而为本领域的技术人员所理解。

附图说明

图1中表格示出的是xmlschema定义的30种元素以及其父元素,属性和子元素;

图2中表格示出的是元素类中为元素属性创建的非string类型的变量;

图3中表格示出的是元素类中为可以出现至少1次或0-n次的子元素定义的变量的数据类型;

图4中表格示出的是xmlschema定义的12种限定元素及其父元素,属性和子元素;

图5是本发明的解析单元解析xmlschema文档并获取解析文档的第一个元素的流程图;

图6是本发明的对象创建单元接收元素n,并为元素n创建java对象的流程图;

图7是本发明中构造函数中一般属性判断语句执行过程的流程图;

图8是本发明的union类构造函数中membertypes属性判断语句执行过程的流程图;

图9是本发明的schema类构造函数中xmlns属性判断语句执行过程的流程图。

具体实施方式

下面结合附图对本发明做进一步的详细说明,以令本领域技术人员参照说明书文字能够据以实施。

应当理解,本文所使用的诸如“具有”、“包含”以及“包括”术语并不配出一个或多个其它元件或其组合的存在或添加。

发明提出的一种将xmlschema文档转换为java代码的方法,包括:

s1,建立与xmlschema标准定义的30种元素、12种限定元素相对应的java类,并依据元素、限定元素之间的嵌套关系建立java类之间的引用关系,其为xmlschema定义的30种元素和12种限定元素定义对应的java类;

s2,解析单元用java语言实现dom编程接口以获取解析器实例,并基于解析器实例对待转换的xmlschema文档进行解析,以获取对应的解析文档以及解析文档的第一个元素n,即解析单元首先使用java语言实现dom编程接口,获取解析器实例。然后解析器实例将xmlschema文档的url路径url作为参数调用parse(urlurl)方法实现xmlschema文档的解析,得到解析后的文档。第三获取解析后文档的第一个元素n,将元素n传入对象创建单元(对于格式良好的、非空的xmlschema文档,元素n实际为schema元素,为方便s3描述对象单元创建对象过程,以n命名);

s3,对象创建单元接收第一个元素n,获取n对应的本地名称,并基于本地名称调用对应的java类构造函数,为n创建相应的java对象,并以n为根元素,按照深度优先遍历次序依次为解析文档中每个元素创建对应java对象,其用于使得时间复杂度为o(n),空间复杂度为o(n),以实现xmlschema文档到java代码的转换。采用这种方案通过xmlschema文档转换得到的java对象,其依照源文档中元素的嵌套关系组织,使得xmlschema文档转换得到的java对象中保存了源文档中包含的所有内容,具有可实施效果好,稳定性好,可靠性强的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,在s1中java类的建立包括:

为与xmlschema标准定义的每种元素定义分别建立对应的元素类,即为图1中的每种元素定义一个java类,以首字母大写的元素名作为类名;

为与xmlschema标准定义的所有限定元素定义一个共用的限定元素类,以facet为类名。采用这种方案为按照xmlschema的语法结构,为每种元素创建一个对应的java元素类,为12种限定元素创建一个共用的java类,以使其嵌套关系相互对应,结构匹配,具有可实施效果好,可操作性强,适应性好的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,所述元素类的定义包括:

s11,对各元素类中对应元素包括的每一个属性,定义相配合的第一变量,同时对第一变量的数据类型和初始值进行定义,对元素的可以包含的每个属性,在元素对应的java类中定义一个变量,以属性名作为变量名,除图2列举的情况外,在元素类中为元素属性创建的变量的数据类型均为string,初始值为null。具体来说是,对元素的可以包含的每个属性,在元素对应的java类中定义一个变量,以属性名作为变量名,变量数据类型描述如下:

union元素的membertypes属性的取值可以是多个简单类型名的组合,简单类型名之间用空白符隔开。因此union类的membertypes变量的数据类型是string[],初始值为null。

schema元素的xmlns属性有两种使用情况:一种是表示默认名称空间,属性名是xmlns,默认名称空间在schema元素中最多出现1次;一种是带有名称空间前缀xmlns属性,属性名以”xmlns:”开头,”:”后是名称空间前缀,带有名称空间前缀的xmlns属性在schema元素中可以出现多次。因此在schema类中定义了一个xmlns变量,数据类型为string,初始值为null,用于存储默认名称空间;一个namespace变量,数据类型为hashmap<string,string>,初始值为null,<key,value>存储带有名称空间前缀的xmlns属性的<名称空间,名称空间前缀,>。

s12,对各元素类中对应元素包括的每一个子元素,定义配合的第二变量,同时对第二变量的数据类型和初始值进行定义;除以list<thing>作为数据类型的变量声明情况外,对元素可以包含的其它每种子元素,在元素类中定义一个变量,变量定义规则如下所示:,

若子元素在元素中可以出现0次或1次,则以子元素名作为变量名,数据类型为子元素类。

若子元素在元素中可以出现至少1次或0-n(n=1,2,3…)次,则以子元素名和字符“s”的组合作为变量名,变量与变量的数据类型的对应关系如图3所示。

元素类中所有为子元素定义的变量初始值均为null。

s13,除属性变量和子元素变量外,在各元素类中额外定义与该元素类相配合的三个第三变量及其相关数据类型:一个element变量,数据类型为element;一个parent变量,数据类型为thing;一个schema变量,数据类型为schema。采用这种方案对元素类中的各属性及子元素等进行定义,使得xmlschema的文档格式中的元素及嵌套关系转换关系更为具化,具有可实施效果好,可操作性强的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,所述元素类的定义还包括:

s14,为元素类定义对应的构造函数,包括:

所述第三变量包括三个与该元素类对应的元素a,a的父元素b以及b的根元素c,即构造函数有三个参数:elementelement,thingparent和schemaschema。第一个参数是与元素类对应的元素,第二个参数是element的直接父元素对象,第三个参数是element的根元素对象;

基于第三变量的相关参数,将构造函数的相关参数赋值给元素类中相应的变量,即将构造函数的element参数赋值给元素类的element变量,将构造函数的parent参数赋值给元素类的parent变量,将构造函数的schema参数赋值给元素类的schema变量;

对元素a中的预定的相关属性,在构造函数中对其进行属性判断即除schema元素xmlns属性、union元素的membertypes属性以及图2中的变量对应的属性外,对于元素可以包含的每个属性n,在构造函数中定义属性判断语句,其语句块如下所示:

if(element.getattributenode("属性n的名字")!=null)类中为属性n定义的变量=element.getattribute("属性n的名字");

union类的构造函数为union元素membertypes属性定义的属性判断语句块如下所示:

if(element.getattributenode("membertypes")!=null)membertypes=(element.getattribute("membertypes")).split("\\s");

在构造函数中为minoccurs属性定义的判断语句块如下所示:

if(element.getattributenode("minoccurs")!=null){

minoccurs=

integer.parseint(element.getattribute("minoccurs"));

在构造函数中为maxoccurs属性定义的判断语句块如下所示:

if(element.getattributenode("maxoccurs")!=null){

if("unbounded".equals(element.getattribute("maxoccurs")))

maxoccurs=integer.max_value;

else

maxoccurs=integer.parseint(element.getattribute("maxoccurs"));

}

在构造函数中为数据类型是boolean的属性变量定义的判断语句块如下所示:

if(element.getattributenode("属性名")!=null)

属性变量="true".equals(el.getattribute("属性名"));

对元素a中的子元素,在构造函数中对其进行子元素判断。在构造函数中定义子元素判断语句,语句块如下所示:

for(noden=element.getfirstchild();

n!=null;n=n.getnextsibling()){

if(ninstanceofelement){

if("子元素名".equals(n.getlocalname()))①

子元素变量=new子元素类构造函数((element)n,this,schema);

if("子元素名".equals(n.getlocalname()))②

子元素变量.add(new子元素类类构造函数((element)n,this,schema);

if("子元素名".equals(n.getlocalname()))③

子元素变量.add(new子元素类构造函数((element)n,this,schema);

子元素变量.add(newfacet((element)n,this);

if("子元素名".equals(n.getlocalname()))④

子元素类子元素变量1=new子元素类构造函数((element)n,this,this);

子元素变量.put(子元素变量1.getname(),子元素变量1);

……

}}

语句块中的子元素变量是在类中为子元素定义的变量,类型④中的子元素变量1是为子元素定义的一个临时变量。在构造函数中为元素所有可以出现的子元素都定义判断语句,判断语句分为四种类型。当在类中为子元素定义的变量类型为子元素类时,使用①类型子元素判断语句;当在类中为子元素定义的变量类型为arraylist<子元素类>时,使用②类型的子元素判断语句;当在类中为子元素定义的变量类型为list<子元素类>或list<thing>时,使用③类型的子元素判断语句;当在类中为子元素定义的变量类型为linkedhashmap<string,子元素类>时,使用④类型的子元素判断语句。

需要说明的是:类型③的变量赋值语句有两种情况:restriction类的构造函数判断restriction元素是否有限定子元素时,使用“子元素变量.add(newfacet((element)n,this);”赋值语句;其他情况使用“子元素变量.add(new子元素类构造函数((element)n,this,schema);”赋值语句。

采用这种方案对元素类中的相应的函数进行构造,以使其对应关系更加明确,进一步实现xmlschema文档的转换,具有可实施效果好,可操作性强的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,所述限定元素类的建立包括:

s15,在限定元素类中为各限定元素的相关属性定义对应变量,如图4所示,12种限定元素可以包含的属性相同:一个value属性和一个fixed属性。在facet类中定义一个string类型的value变量,初始值为null;一个boolean类型的fixed变量,初始值为false,两个变量分别对应于限定元素的value属性和fixed属性。除此之外,在facet类中定义三个变量:一个element变量,数据类型为element;一个parent变量,数据类型为thing;一个facet变量,数据类型为string;

s16,为限定元素类定义构造函数,其包括各限定元素、以及与各限定元素对应的直接父元素类对象,且

在定义构造函数时将各限定元素的参数赋值给限定元素类中与各限定元素对应的变量,并在构造函数中对各限定元素包含的属性进行相应判断。构造函数有两个参数:elementelement,thingparent,第一个参数是的限定元素,第二个参数是element元素的直接父元素类对象。将构造函数的element参数赋值给facet类的element变量,将构造函数的parent参数赋值给facet类的parent变量。获取element的本地名称将其赋值给facet变量。

构造函数中用于判断element元素包含的属性的判断语句如下所示:

if(element.getattributenode("value")!=null){

value=element.getattribute("value");

if(element.getattributenode("fixed")!=null)

fixed="true".equals(element.getattribute("fixed")));

采用这种方案使得xmlschema中限定元素的语法结构及格式与转换后的java对象相对应,具有可实施效果好,可操作性强的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,在s1中,还包括定义可供所有的java类实现的空接口(命名为thing),以作为java类构造函数第二传入参数的数据类型,以及存储预定元素类中相关变量的数据类型。thing接口是一个空接口,元素类和facet类都实现该接口,该接口在类中有五种用途:

1)在attributegroup、complextype、extension、restriction类中定义一个list<thing>类型的变量attributes,用于存储attribute和attributegroup子元素类对象。

2)在element类中定义一个list<thing>类型的变量identityconstraints,用于存储key,keyref,unique子元素类对象。

3)在redefine类中定义一个list<thing>类型的变量redefineables,用于存储simpletype,complextype,group,attributegroup子元素类对象。

4)在sequence和choice元素的类中定义一个list<thing>类型的变量modelgroup,用于存储element,group,choice,sequence,any子元素类对象。

5)作为元素类和facet类构造函数第二个传入参数的数据类型。

采用这种方案通过空接口,以使其在构造函数时的数据传入更加精准,具有可实施效果好,可操作性强的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,在s2中,解析器实例通过将xmlschema文档的url路径作为参数调用,以实现xmlschema文档的解析。采用这种方案通过解析器实例调用parse(urlurl)方法解析url路径指定的xmlschema文档,将解析结果赋值给document类型的schemadoc临时变量,以实现对xmlschema文档的解析,具有可实施效果好,可操作性强的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,在s3中,对象创建单元接收第一元素n,并为n创建java对象的过程包括:

s31,接收元素n,如果(n!=null&&ninstanceofelement)==true为真,执行s32;如果为假,则程序退出。(元素n实际为schema元素,当判断语句为假时,xmlschema文档为空文档或格式不正确);

s32,获取元素n的本地名称,并基于本地名称所表示的类型,传入预定参数至构造函数。若本地名称表示的是schema元素时,则向构造函数传入的参数为(n,null,null);若本地名称表示的是除schema外的其它元素,则将(n,this,schema)作为参数传入构造函数;若本地名称表示的是限定元素,则将(n,this)作为参数传入构造函数。this表示的是当前对象,schema是元素n所属的xmlschema文档的根元素--schema元素的对象,执行s33;

s33,将构造函数的相关参数赋值给类中相应的变量,若该类是元素类,则将构造函数的第一个参数赋值给类中element变量,第二个参数赋值给类中parent变量,第三个参数赋值给类中schema变量;若该类是facet类,则将构造函数的第一个参数赋值给类中element变量,第二个参数赋值给类中parent变量,执行s34;

s34,依次执行为元素的每个属性定义的属性判别语句,完成元素包含属性的处理,执行s35;

s35,获取元素n的第一个子元素n′,并对n′是否为空进行判断,若其为空,则n′的父元素n的对象创建完成,执行s36,否则执行s37。

s36,若n的本地名称与根元素一致,则认为xmlschema文档中包含所有元素的对象创建完成,程序结束;

否则将创建的元素n的对象,赋值给元素n的父元素类中为n创建的对应变量,然后获取直接在元素n之后的元素n″,并将n″赋值给s35中的n′,再次执行s35。

当(n.getlocalname==”schema”)为真时,则为xmlschema文档中包含的所有元素的对象创建完成,得到一个xmlschema文档根元素—schema元素的对象,schema元素的对象中保存了为xmlschema文档中所有其他元素创建的对象,程序正常结束;

s37,若(n’instanceofelement)==true为真,则将元素n′赋值给s32中的元素n,执行s32,否则执行s38。

s38,获取直接在元素n′的之后的元素n″′,并将n″′赋值给s35中的n′,再次执行s35。采用这种方案对其操作流程进行具化,但不限定于这一种可实施的方式,以使其实现本发明所宣称的将xmlschema转换成java对象,以供进一步对其进行开发、编辑或直接使用,具有可实施效果好,适应性强的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,在s32中,预定参数的传入包括:

若本地名称表示的是schema元素时,则向构造函数传入的参数为(n,null,null);

若本地名称表示的是除schema外的其它元素,则将(n,this,schema)作为参数传入构造函数;

若本地名称表示的是限定元素,则将(n,this)作为参数传入构造函数;

其中,this表示的是当前对象,schema是元素n所属的xmlschema文档的根元素的对象。采用这种方案对其进行进一步的具化,以使本发明的目的进一步的得以实现,具有可实施效果好,可操作性强的有利之处,并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

在另一种实例中,在s33中,若该类是元素类,则将构造函数的第三变量中a、b、c的参数分别赋值给类中对应的变量;

若该类是限定元素类,则将构造函数的相应参数赋值给类中相应的变量。采用这种方案对其进行进一步的具化,以使本发明的目的进一步的得以实现,具有可实施效果好,可操作性强的有利之处。并且,这种方式只是一种较佳实例的说明,但并不局限于此。在实施本发明时,可以根据使用者需求进行适当的替换和/或修改。

实施例:

本发明是基于格式正确的xmlschema文档,所谓格式正确是指xmlschema文档中的元素的定义或声明方式和元素间的嵌套关系符合xmlschema语法规则。对于任何格式正确的xmlschema文档,本发明都可以将其转换为java代码。对于一个格式正确的xmlschema文档,schema元素是其根元素,即一个格式正确的xmlschema文档的schema元素是任何其它xmlschema文档包含元素的父元素(直接父元素或祖宗元素)。本发明将xmlschema文档转化为java代码最终得到一个schema元素的java对象,该对象中的变量保存了schema的子元素对象信息,子元素对象中的变量保存了子子元素对象信息,依次类推。通过这种嵌套的方式,转换的得到的schema元素的对象既保存了xmlschema文档中的所有内容又保存了元素之间的嵌套关系。本发明可简要的概括为以下三步:

第一步,为xmlschema标准定义元素和限定元素建立对应的java类,依据标准定义的元素之间的嵌套关系建立java类之间的引用关系,并定义一个空接口。

第二步,用java语言实现dom编程接口以获取解析器实例,用其解析xmlschema文档,获取解析文档和解析文档的第一个元素(命名为n)。

第三步,将第一个元素作为根元素,按照深度优先遍历次序依次为解析文档中每个元素创建java对象。

图5是本发明的解析xmlschema文档的流程示意图,从图中可以看出:

步骤101、获取xmlschema文档的url路径。

步骤102、java语言实现dom编程接口并获取解析器实例。

步骤103、解析xmlschema文档,获取解析文档。

解析器实例调用parse(urlurl)方法解析url路径指定的xmlschema文档,将解析结果赋值给document类型的schemadoc临时变量。

步骤104、获取schemadoc的第一个元素n。

schemadoc调用getdocumentelement()方法,获取schemadoc的第一个元素,命名为n。(对于任何格式良好且非空的xmlschema文档,n实际是schema元素)。

图6是本发明的创建java对象的流程示意图,从图中可以看出:

步骤201、接收元素n,元素n是解析xmlschema文档得到的解析文档的第一个元素。

步骤202、判断((n!=null&&ninstanceofelement)==true)是否为真,若为真,则执行步骤204;若为假,则执行步骤203。

步骤203、程序中止执行,此时xmlschema文档是空文档或文档格式不正确,程序中止执行。

步骤204、获取元素n的本地名称,元素n调用getlocalname()方法获取元素n的本地名称。

步骤205、调用与本地名称对应的java类的构造函数,每种元素对应一个元素类,12种限定元素对应着facet类。当本地名称表示的是元素时,调用对应元素类的构造函数,传入构造函数的参数是:(n,this,schema);当本地名称表示的是schema元素时,传入的构造参数是:(n,null,null);当本地名称表示的是限定元素时,调用facet类的构造函数,传入构造函数的参数是(n,this)。

步骤206、将构造函数参数赋值给类中对应变量,若该类是元素类,则将构造函数的第一个参数赋值给类中的element变量,第二个参数赋值给类中的parent变量,第三个参数赋值给类中schema变量;若该类是限定元素类,则将构造函数的第一个参数赋值给类中的element变量,第二个参数赋值给类中的parent变量。

步骤207、判断元素包含的属性,在每种java类的构造函数中都定义了属性判断语句。依次执行这些语句,判断元素包含的属性。对于元素包含的属性,执行赋值语句,将属性的值赋值给类中为该属性定义的变量。

步骤208、获取元素n的第一个子元素n′,元素n调用getfirstchild()方法获取其的第一个子元素,命名为n′。

步骤209、判断元素n′是否是空元素,若为空,则执行步骤210;若非空,则执行步骤214。

若元素n′是步骤208获取的,则元素′是元素n的第一个子元素;若元素n′是步骤213获取的,则元素n′是直接在步骤209上一次判断的元素的父元素之后的元素;若元素n′是步骤215获取的,则n′是直接在步骤209上一次判断元素之后的元素。

步骤210、元素n′的父元素n的对象创建完成,当元素n′为空时,元素n′的父元素n的所有子元素对象创建完成,元素n的对象创建完成。

步骤211、判断元素n是否是schema元素,若是,则执行步骤212;若不是,则执行步骤213。

步骤212、对象创建完成,完成将xmlschema文档转化为java代码,程序正常结束。

步骤213、将元素n的对象赋值给对应变量并获取直接在元素n后的元素n′;

若元素n不是schema时,首先将为元素n创建的对象赋值给对应的变量,然后元素n调用getnextsibling()方法获取直接在元素n之后的元素n″,执行步骤209。

步骤214、判断n′是否是element实例;若是,则行步骤204;若不是,则执行步骤215。

步骤215、获取直接在元素n′之后的元素n″′;元素n′调用getnextsibling()方法获取直接在元素n′之后的元素n″′,执行步骤209。

图7是本发明中构造函数中一般属性判断语句执行过程的流程图,从图中可以看出:

步骤301、依据属性名获取属性n,元素调用getattributenode(“属性名”)方法获取元素的属性,命名为n。

步骤302、判断属性n是否为空,若为空,则执行步骤301;若非空,则执行步骤303。

步骤303、获取属性n的属性值,将其赋值给类中对应的属性变量,元素调用getattribute(“属性名”)方法获取属性值,并将其赋值给在类中为属性定义的变量。执行步骤301。

图8是本发明的union类构造函数中membertypes属性判断语句执行过程的流程图,从图中可以看出:

步骤401、获取membertypes属性;

元素调用getattributenode(“membertypes”)方法获取元素的membertypes属性。

步骤402、判断membertypes属性是否为空;

若为空,则执行步骤405;若非空,则执行步骤403。

步骤403、获取membertypes的属性值;

元素调用getattribute(“membertypes”)方法获取membertypes属性值。

步骤404、属性值按空白符分隔,将分割结果赋值给membertypes变量

步骤403获取的membertypes属性值数据类型为string,属性值调用split(“\\s”)对属性值按空白符进行分割,将分割结果赋值给union类中membertypes变量。

步骤405、执行其它属性判断语句。

图9是本发明的schema类构造函数中xmlns属性判断语句执行过程的流程图,从图中可以看出:

步骤501、获取元素的所有属性,存储在namednodemap类型的临时变量node中。定义一个int类型的变量i,初始值为0;

元素调用getattributes()方法获取元素的所有属性,并存储到node变量中。

步骤502、判断i<node.getlength()是否为真;

若为真,则执行步骤504;若为假,则执行步骤503。

步骤503、执行其它属性判定语句;

步骤504、获取node中索引为i的属性n;

步骤505、获取属性n的属性名name和属性值value;

属性n调用getnodename()方法获取属性名name,调用getnodevalue()方法获取属性值value。

步骤506、判断name是否以字符串”xmlns”开头;

若是,则执行步骤507;若不是,则执行步骤508。

步骤507、判断name是否以字符串”xmlns:”开头;

若是,则执行步骤509;若不是,则执行步骤510。

步骤508、将变量i的值加1;

对当前属性处理结束后,将变量i的值加1,以获取node中索引为i+1的属性。

步骤509、获取名称空间前缀prefix,将<value,prefix>保存到namespace变量中;

name调用substring(6)方法获取名称空间前缀prefix,将<prefix,value>键值对保存到类中namespace变量中。

步骤510、将属性值value赋值给类中的xmlns变量;

当属性名以字符串“xmlns”开头,不以“xmlns:”开头时,该属性属性名为“xmlns”。

以上对本发明所提供的一种将xmlschema文档转换为java代码的方法,进行了详细的介绍。本发明的优点在于,能够完整的为xmlschema文档中的所有元素建立java对象,并将元素之间的嵌套关系用java语言描述。该发明的正确性和有效性通过了大量的实验验证,故可以用在实际的xml相关的软件或系统的开发中。

故采用本发明,可以将xmlschema文档中的所有内容转化为java代码,并将元素之间的嵌套关系用java语言完整的表示。基于本发明,可以开发一系列xml相关软件,例如xml编辑软件、xml验证软件。

这里说明的设备数量和处理规模是用来简化本发明的说明的。对本发明的将xmlschema文档转换成java代码的方法的应用、修改和变化对本领域的技术人员来说是显而易见的。

尽管本发明的实施方案已公开如上,但其并不仅仅限于说明书和实施方式中所列运用。它完全可以被适用于各种适合本发明的领域。对于熟悉本领域的人员而言,可容易地实现另外的修改。因此在不背离权利要求及等同范围所限定的一般概念下,本发明并不限于特定的细节和这里示出与描述的图例。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1