strut2-default.xml(默认配置的),struts-plugin.xml(若是与spring整合),struts2.xml(本身配置的)java
每个配置文件的内容主要分为三类,一类是定义的bean,一类是常量<constant>,一类是packagenode
入口方法:DefaultConfiguration-->reloadContainer()spring
public synchronized List<PackageProvider> reloadContainer(List<ContainerProvider> providers) throws ConfigurationException { // 解析配置文件中的package标签 for (final ContainerProvider containerProvider : providers) { if (containerProvider instanceof PackageProvider) { container.inject(containerProvider); ((PackageProvider)containerProvider).loadPackages(); packageProviders.add((PackageProvider)containerProvider); } } }
接着进入XmlConfigurationProvider-->loadPackages()app
for (Document doc : documents) { Element rootElement = doc.getDocumentElement(); NodeList children = rootElement.getChildNodes(); int childSize = children.getLength(); for (int i = 0; i < childSize; i++) { Node childNode = children.item(i); if (childNode instanceof Element) { Element child = (Element) childNode; final String nodeName = child.getNodeName(); if ("package".equals(nodeName)) { PackageConfig cfg = addPackage(child);//构造一个PackageConfig对象 if (cfg.isNeedsRefresh()) { reloads.add(child); } } } } loadExtraConfiguration(doc); }
接下来就是解析<package>标签元素--ide
解析属性信息:extends属性--继承的父包名称 abstract--是不是抽象的包默认false name--包的名称 namespace--命名空间默认"" strict-method-invocation--是不是严格的方法执行默认falseui
若是有继承的父包,则解析父包信息:根据配置的父包的名称,找到是否配置了这样一个包,若是找到了就把对应的父包PackageConfig添加进去,不然抛出异常不存在这样的父包spa
解析结果类型<result-types>--封装成LinkedHashmap---key 结果类型名称,value值为对应的结果类型class名称code
解析拦截器 <interceptors>---封装成LinkedHashmap---key为拦截器名称,value值为拦截器class名称xml
解析默认的拦截器引用<default-interceptor-ref>--字符串---只取name属性,表明的确实多个拦截器(也就是拦截器栈)对象
解析默认的class引用<default-class-ref>---字符串--只取class属性,实际上是一个类的class
解析全局的结果类型 <global-results>
解析全局的exception映射<global-exception-mappings>
解析action<action>---下面介绍
解析默认的action引用<default-action-ref>
入口:XmlConfigurationProvider-->addAction
这里一样会解析属性,子标签等,而后封装成ActionConfig,同时会放到PackageConfig的actionConfigs属性下
DefaultConfiguration--->rebuildRuntimeConfiguration()
第3,4步将配置文件解析完毕,仅仅解析出了配置文件里的内容。接下来是重建运行时配置
为何要重建运行时配置?
由于,配置文件配置的只是用户配置的,还有好多的默认配置,须要从新解析一下,这样才能更好的处理请求。3,4步解析出来,自定义的ActionConfig PackageConfig中的拦截器,异常映射,返回结果类型等可能都是空的,这说明有继承父包的一些属性
好比:extends继承的父包的一些配置,一些全局性的配置(拦截器配置,异常映射配置等),重建之后,ActionConfig所须要的必要信息就全了。(拦截器信息不可少)