Struts2配置详解

本文深入解析Struts2框架的工作原理,包括核心控制器、Action处理流程、配置文件详解及常用常量配置,揭示如何通过struts.xml配置实现动态方法调用、通配符使用和结果类型管理。

1.Struts2执行过程解
比如用户登录的简单过程如下:
用户在登录界面发送请求会经过Struts2的核心控制器(Struts2的过滤器),它会找到匹配的Action类来处理此请求并返回不同的情况给结果处理器,结果处理器在跳转到不同页面默认的跳转方式为转发。
同时它的核心控制器——Struts2的过滤器的配置如下:

  <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
它配置在web.xml文件中。
  1. 对于web.xml文件,任何一个Web应用程序都是基于请求/响应模式进行创建的,无论采用哪种MVC框架,都离不开web.xml文件的配置,只有在Web项目中配置了web.xml文件,MVC框架才能真正地与Web应用融合起来。因此web.xml文件是所有JavaWeb项目程序都需要的核心文件。
    同时Struts2的核心控制器是用于对框架进行初始化,以及处理所有的请求。同时StrutsPrepareAndExecuteFilter作为一个Filter在Web应用中运行,它负责拦截所有用户的请求,如果用户请求是以**“.action”**结尾,该请求会被输入到Struts2框架中进行处理。
    2.Action在Struts2框架中,控制器是由两个部分组成,如下所示:
    1.核心控制器(Filter):用于拦截用户请求,对请求进行处理。
    2.业务控制器(Action):调用相应的Model类实现实现业务处理,返回结果。
    如何声明一个Action类,其实只要声明一个Java普通类通过继承ActionSupport类或者实现Action接口同时该类需要声明一个返回字符串的无参的public方法即可。(注:一般通过继承ActionSupport类来实现)。
    同时Struts2框架还有一个核心配置文件struts.xml,如下所示:

</struts>
最为重要的是package节点,因为我们要声明该配置文件指定要拓展的struts-default包,其中name属性为必需的并且是唯一的,用来指定包的名称,extends属性类似Java的extends关键字,指定要拓展的包。namespace是一个可选属性,该属性用于定义该包中action的命名空间。如果没有该属性则action被放入默认命名空间中。一般使用"/"来定义一个根命名空间。
同时Struts2允许将一个配置文件拆分成多个配置文件,但只默认加载WEB-INF/classes下的struts.xml文件,所以我们要使用include元素来包含其他配置文件。
同时我们可以在struts.xml配置一些常量来改变Struts2框架的一些行为,从而满足不同应用的需求,constant元素包含两种属性,其中name属性为常量的名称,value属性表示常量的值。
**以下为Struts2框架常用的常量:**



       <!--指定Web应用的默认编码集.该属性对于处理中文请求参数非常有用,对于获取中文请求参数值,应该将该属性值设置为GBK或者GB2312; 
           提示:当设置该参数为GBK时,相当于调用HttpServletRequest的setCharacterEncoding方法. >
 <constant name="struts.i18n.encoding" value="UTF-8" />
       <!--指定Struts 2默认的ObjectFactory Bean,该属性默认值是spring. >
 <constant name="struts.objectFactory" value="spring" />
       <!--指定Spring框架的自动装配模式, 该属性的默认值是name, 即默认根据Bean的name属性自动装配. >
 <constant name="struts.objectFactory.spring.autoWire" value="name" />
       <!--该属性指定整合Spring框架时,是否缓存Bean实例,该属性只允许使用true和false两个属性值,它的默认值是true.通常不建议修改该属性值. >
 <constant name="struts.objectFactory.spring.useClassCache" value="true" />
       <!--该属性指定处理multipart/form-data的MIME类型(文件上传)请求的框架,该属性支持cos,pell和jakarta等属性值, 即分别对应使用cos的文件上传框架,pell上传及common-fileupload文件上传框架.该属性的默认值为jakarta. 
           注意:如果需要使用cos或者pell的文件上传方式,则应该将对应的JAR文件复制到Web应用中.例如,使用cos上传方式,则需要自己下载cos框架的JAR文件,并将该文件放在WEB-INF/lib路径下. >
 <constant name="struts.multipart.parser" value="jakarta" />
       <!--该属性指定上传文件的临时保存路径,该属性的默认值是javax.servlet.context.tempdir. >
 <constant name="struts.multipart.saveDir" value="" />
       <!--该属性指定Struts 2文件上传中整个请求内容允许的最大字节数. >
 <constant name="struts.multipart.maxSize" value="1000000000000" />
       <!--该属性指定需要Struts 2处理的请求后缀,该属性的默认值是action,即所有匹配*.action的请求都由Struts 2处理.如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开. >
 <constant name="struts.action.extension" value="do" />
       <!--该属性设置是否通过JAR文件提供静态内容服务,该属性只支持true和false属性值,该属性的默认属性值是true. >
 <constant name="struts.serve.static" value="true" />
       <!--该属性设置浏览器是否缓存静态内容.当应用处于开发阶段时,我们希望每次请求都获得服务器的最新响应,则可设置该属性为false. >
 <constant name="struts.serve.static.browserCache" value="true" />
       <!--该属性设置Struts 2应用是否使用开发模式.如果设置该属性为true,则可以在应用出错时显示更多、更友好的出错提示.该属性只接受true和flase两个值,该属性的默认值是false.通常,应用在开发阶段,将该属性设置为true,当进入产品发布阶段后,则该属性设置为false. >
 <constant name="struts.devMode" value="false" />
       <!--该属性设置是否每次HTTP请求到达时,系统都重新加载资源文件(允许国际化文件重载).该属性默认值是false.在开发阶段将该属性设置为true会更有利于开发,但在产品发布阶段应将该属性设置为false. 
           提示:开发阶段将该属性设置了true,将可以在每次请求时都重新加载国际化资源文件,从而可以让开发者看到实时开发效果;产品发布阶段应该将该属性设置为false,是为了提供响应性能,每次请求都需要重新加载资源文件会大大降低应用的性能. >
 <constant name="struts.i18n.reload" value="false" />
       <!--该属性指定视图标签默认的视图主题,该属性的默认值是xhtml. >
 <constant name="struts.ui.theme" value="simple" />
       <!--该属性指定模板文件的后缀,该属性的默认属性值是ftl.该属性还允许使用ftl、vm或jsp,分别对应FreeMarker、Velocity和JSP模板. >
 <constant name="struts.ui.templateSuffix" value="ftl" />
       <!--该属性设置当struts.xml文件改变后,系统是否自动重新加载该文件.该属性的默认值是false. >
 <constant name="struts.configuration.xml.reload" value="false" />
       <!--该属性指定Struts 2应用所需要的国际化资源文件,如果有多份国际化资源文件,则多个资源文件的文件名以英文逗号(,)隔开. >
 <constant name="struts.custom.i18n.resources" value="nationz" />
       <!--对于某些Java EE服务器,不支持HttpServlet Request调用getParameterMap()方法,此时可以设置该属性值为true来解决该问题.该属性的默认值是false.对于WebLogic、Orion和OC4J服务器,通常应该设置该属性为true. >
 <constant name="struts.dispatcher.parametersWorkaround" value="false" />
       <!--指定是否缓存FreeMarker模版。默认值false。>
 <constant name="struts.freemarker.templatesCache" value="true" />
       <!--该属性只支持true和false两个属性值,默认值是true.通常无需修改该属性值. >
 <constant name="struts.freemarker.wrapper.altMap" value="true" />
       <!--该属性指定XSLT Result是否使用样式表缓存.当应用处于开发阶段时,该属性通常被设置为true;当应用处于产品使用阶段时,该属性通常被设置为false. >
 <constant name="struts.xslt.nocache" value="false" />
       <!--该属性指定Struts 2框架默认加载的配置文件,如果需要指定默认加载多个配置文件,则多个配置文件的文件名之间以英文逗号(,)隔开.该属性的默认值为struts-default.xml,struts-plugin.xml,struts.xml,看到该属性值,所以应该明白为什么Struts 2框架默认加载struts.xml文件了. >
 <constant name="struts.configuration.files" value="struts-default.xml,struts-plugin.xml" />
       <!--设置映射器是否总是选择完整的名称空间。该属性的默认值时false。>
 <constant name="struts.mapper.alwaysSelectFullNamespace" value="false" />
       <!--设置Convention插件定位视图资源的根路径。默认值为/WEB-INF/content>
 <constant name="struts.convention.result.path" value="/WEB-INF/content/" />
 
       <!--Convention插件以该常量指定包作为根包>
 <constant name="struts.convention.action.package" value="default" />
 
       <!--是否从包中搜索Action>
 <constant name="struts.convention.action.disableScanning" value="false"/>
       
       <!-- 官方只说明在jboss下需要设置,情况不明 -->
 <constant name="struts.convention.exclude.parentClassLoader" value="true" /> 
 <constant name="struts.convention.action.fileProtocols" value="jar,zip" />
 
       <!--包括哪些jar包中的action。逗号分割字符串。>
 <constant name="struts.convention.action.includeJars" value=".*?/_wl_cls_gen.*?jar(!/)?" />

Action主要三个作用如下;
1.Action最重要的作用是为给定的请求封装需要做的实际工作 (调用特定的业务处理类);
2.为数据的转移提供场所;
3.帮助框架决定由那个结果呈现请求响应。
我们可以在在struts.xml下的action节点添加method属性用来减少Action的数量。原因是:如果一个请求对应一个Action,则将要编写许多的Action类,于是我们使用method属性可以减少大部分的Action例如当指向的实现类的引用相同时我们可以是用method来指定调用该类下的那个方法,它的值与方法名相等。
如果需要实现Action中动态方法则需要在struts.xml文件中配置允许动态方法掉用的常量,因为在Struts2框架中默认禁止动态方法的调用。
示例如下:

<constant name="struts.enable.DynamicMethodInvocation" value="true"/>

Action中通配符的使用

<action name="*User" method="{1}">
        <result name="success">/page/{1}_success.jsp</result>
        <result name="input">/page/{1}.jsp</result>
        <result name="error">/page/error.jsp</result>
    </action>

{1}代表“*”的值。
如何配置默认的Action即当用户的请求没有一个Action可以匹配则将会被默认的Action来处理,每个package下只能有一个

<default-action-ref>.......</default-action-ref>

使用如下:

<!-- 设置默认的Action-->
        <default-action-ref name="defaultAction"/>
        <action name="defaultAction">
            <result>error.jsp</result>
        </action>

Result的配置,前面也由说到在Struts2框架中调用Action对请求进行处理之后,就要向用户呈现结果视图。Strus2支持多种类型的视图,这些视图由不同的结果类型来管理。
常用结果类型
示例如下:

<action name="*User" method="{1}">
            <!-- 转发指定的JSP页面-->
            <result name="success" type="dispatcher">/page/{1}_success.jsp</result>
            <!-- 重定向指定的JSP页面-->
            <result name="input" type="redirect">/page/{1}.jsp</result>
            <result name="error" type="redirectAction">/page/error.jsp</result>
            <!-- 采用重定向的方式请求一个新的Action,原请求中的数据会丢失其中${}里的值为新的Action中被封装的属性名-->
            <result type="redirectAction">${nextDispose}</result>
        </action>

全局结果集示例如下:

 <!-- 设置全局结果集-->
        <global-results>
        <result name="error">error.jsp</result>
        <result name="login" type="redirect">/page/login.jsp</result>
        </global-results>
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值