Struts2笔记——struts.xml配置详解
访问HelloWorld应用的路径的设置
* 在struts1中,通过<action path=“/primer/helloWorldAction.action”>节点的path属性指定访问该action的URL路径。
<package name="primer" namespace=“/primer“ extends="struts-default"> <action name="helloWorldAction" class="com.pwc.primer.HelloWorldAction"> <result name="success"type="dispatcher">/success.jsp</result> </action>
</package> http://server/struts2/path1/path2/path3/test.action 2.首先寻找namespace为/path1/path2/path3的package, 如果存在这个package,则在这个package中寻找名字为test的action, 如果不存在这个package则转步骤3; 3.寻找namespace为/path1/path2的package, 如果存在这个package,则在这个package中寻找名字为test的action, 如果不存在这个package,则转步骤4; 4.寻找namespace为/path1的package, 如果存在这个package,则在这个package中寻找名字为test的action, 如果仍然不存在这个package,就去默认的namaspace的package下面去找名 字为test的action(默认的命名空间为空字符串“/” ),
如果还是找不到,页面提示找不到action。 * 问题:如果没有为action指定class,默认是com.opensymphony.xwork2.ActionSupport 执行ActionSupport中的execute方法
由struts-default.xml文件<default-class-refclass="com.opensymphony.xwork2.ActionSupport" />决定 <packagename="primer" namespace="/" extends="struts-default"> <action name="helloWorldAction" class="cn.itcast.primer.HelloWorldAction"> <result name="success"type="dispatcher">/success.jsp</result> </action> <action name="actionNoClass"> <result>/success.jsp</result> </action>
</package> 1>如果没有为action指定class,默认是ActionSupport。 2>如果没有为action指定method,默认执行action中的execute() 方法。 ActionSupport的execute方法里面就一句话return"success";
3>如果没有指定result的name属性,默认值为success。 * 问题:如果请求的路径查找不到action的情况下,程序运行会抛出异常 ,可以通过配置当找不到action的情况下,会执行默认的action
<!--指定默认的action引用,如果该包下没有对应action配置,则启用该配置--> <default-action-ref name="helloWorldAction"></default-action-ref>
<action name="helloWorldAction" class="cn.itcast.primer.HelloWorldAction"> <result name="success"type="dispatcher">/success.jsp</result> </action> <action name="actionNoClass"> <result>/success.jsp</result> </action> </package>
* StrutsPrepareAndExecuteFilter是Struts2框架的核心控制器,它负责拦截由<url-pattern>/*</url-pattern>指定的所有用户请求,当用户请求到达时,该Filter会过滤用户的请求。默认情况下,如果用户请求的路径不带后缀或者后缀以.action结尾,这时请求将被转入Struts 2框架处理,否则Struts 2框架将略过该请求的处理。
* 根据配置文件:struts2-core-x.x.x.jar包下的org.apache.struts2/default.properties文件定义的常量决定
<struts> <constantname="struts.action.extension" value="do"/> </struts>
<constantname="struts.action.extension" value="do,go"/>
* 常量可以在struts.xml或struts.properties中配置,建议在struts.xml中配置,两种配置方式如下:
<struts>
</struts>
> 在struts.properties中配置常量, (struts.properties文件放置在src下)
struts.action.extension=do
* 因为常量可以在多个配置文件中进行定义,所以我们需要了解下struts2加载常量的搜索顺序: 1 struts-default.xml 2 struts-plugin.xml 3 struts.xml 4 struts.properties
5 web.xml
* 如果在多个文件中配置了同一个常量,则后一个文件中配置的常量值会覆盖前面文件中配置的常量值. * 指定默认编码集,作用于HttpServletRequest的setCharacterEncoding方法 和freemarker 、velocity的输出 <constant name="struts.i18n.encoding"value="UTF-8"/>
<constant name="struts.action.extension" value="do"/>
<constant name="struts.serve.static.browserCache" value="false"/>
<constant name="struts.configuration.xml.reload" value="true"/>
<constant name="struts.devMode" value="true" />
<constant name="struts.ui.theme" value="simple" />
<constant name="struts.objectFactory" value="spring" />
<constant name="struts.enable.DynamicMethodInvocation" value="false"/>
<constant name="struts.multipart.maxSize" value=“10701096"/>
在大部分应用里,随着应用规模的增加,系统中Action的数量也会大量增加,导致struts.xml配置文件变得非常臃肿。为了避免struts.xml文件过于庞大、臃肿,提高struts.xml文件的可读性,我们可以将一个struts.xml配置文件分解成多个配置文件,然后在struts.xml文件中包含其他配置文件。下面的struts.xml通过<include>元素指定多个配置文件:
<struts> <include file="struts-user.xml"/> <includefile="struts-order.xml"/>
</struts>
通过这种方式,我们就可以将Struts 2的Action按模块添加在多个配置文件中。 |