spring的xml解析校验,有两种方式。
第一种,是在xml里指定对应的标签空间命名,这个校验主要的作用就是为了提醒我们在写入时候应该注意的事项。
第二种,是解析的时候,使用代码解析,这时候的解析是必要的,因为如果没有这时候的解析,会导致没有按照你规定格式xml也能被解析,从而导致程序出错。
使用代码解析案例:
使用代码校验有两种方式,一个是针对document类型
下面这个是scheam的校验,使用该校验就要启用SchemaFactory来创建一个Scheam对象
以spring的beans和contexts的校验为例
/**
* 提供验证,验证beans的
*/
URL beansUrl=new URL("http://www.springframework.org/schema/beans/spring-beans-3.2.xsd");//这个代表的校验文件
String beansPublicId="http://www.springframework.org/schema/beans";//这个是命名空间标识符
InputSource so1=new InputSource(beansUrl.openStream());
so1.setSystemId(beansPublicId);
so1.setSystemId(systemId);
Source beansSource=new SAXSource(so1);
/**
* 提供验证,验证Context的
*/
URL contextUrl=new URL("http://www.springframework.org/schema/context/spring-context-3.2.xsd");
String contextPublicId="http://www.springframework.org/schema/context";
InputSource contextSo=new InputSource(contextUrl.openStream());
contextSo.setEncoding("UTF-8");
contextSo.setPublicId(contextPublicId);
Source contextSource=new SAXSource(contextSo);
/**
* 将合成的校验组成一个数组,放入到校验集合里
*/
Source[] sources={beansSource,contextSource};
/**
* 创建一个约束工厂,java提供了多个,因此需要选取一个,我们使用的w3c
*/
SchemaFactory sf=SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
/**
* 将资源注入到校验器
*/
Schema schema=sf.newSchema(sources);
接下来要创建解析器了,无论是SAX形式的,还是Document形式的,都必须要要执行一个代码,以jaxp提供的dom解析为例
DocumentBuilderFactory documentBuilderFactory=DocumentBuilderFactory.newInstance();
/**
* 如果是使用scheam,这一行是必须要开启的,表示支持命名空间
*/
documentBuilderFactory.setNamespaceAware(false);
/**
* 这一行代码无需开启,如果开启的话,会和scheam形式冲突,因为该模式支支持DTD模式的校验
*/
documentBuilderFactory.setValidating(true);
/**
* 将scheam注入即可
*/
documentBuilderFactory.setSchema(schema);