struts2源码系列(4)--配置文件解析

1.struts.xml配置文件主要有三个

strut2-default.xml(默认配置的),struts-plugin.xml(若是与spring整合),struts2.xml(本身配置的)java

2.配置文件的加载流程

每个配置文件的内容主要分为三类,一类是定义的bean,一类是常量<constant>,一类是packagenode

3.解析package过程

入口方法: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>

4.解析action过程

入口:XmlConfigurationProvider-->addAction

这里一样会解析属性,子标签等,而后封装成ActionConfig,同时会放到PackageConfig的actionConfigs属性下

5.重建运行时配置

DefaultConfiguration--->rebuildRuntimeConfiguration()

第3,4步将配置文件解析完毕,仅仅解析出了配置文件里的内容。接下来是重建运行时配置

为何要重建运行时配置?

由于,配置文件配置的只是用户配置的,还有好多的默认配置,须要从新解析一下,这样才能更好的处理请求。3,4步解析出来,自定义的ActionConfig PackageConfig中的拦截器,异常映射,返回结果类型等可能都是空的,这说明有继承父包的一些属性

好比:extends继承的父包的一些配置,一些全局性的配置(拦截器配置,异常映射配置等),重建之后,ActionConfig所须要的必要信息就全了。(拦截器信息不可少)

相关文章
相关标签/搜索