Struts2 配置文件struts.xml 具体配置

傅元龙
2023-12-01

一、package节点

在逻辑上相关的一组action、global-results、interceptors等元素封装起来,形成一个独立的模块。

1. package节点的属性

  • name:每个package设置一个唯一的标识,这个标识在所有的package定义中不能重复;
  • abstract(可选):允许该package仅包含声明式的定义,不能包含action的定义,但可以定义其他需要的元素,如global-results、interceptors等;
  • extends(可选):指定本package继承另外一个package的所有的配置;子package重复定义则覆盖父package中对应的定义;
  • namespace(可选):对于action配置进行逻辑划分,默认值为“”(空);未指定namespace时,请求为:package_name/action_name;指定namespace时,请求为:package_name/namespace/action_name;

2. package节点的常用子节点

  • action:定义Action;
<!-- Action配置 一个Action可以被多次映射(只要action配置中的name不同)
	name:action名称,
	class: 对应的类的路径,
	method: 调用Action中的方法名 -->
<action name="hello" class="com.kay.struts2.Action.LoginAction">         
	<!-- 引用拦截器,name:拦截器名称或拦截器栈名称 -->            
	<interceptor-ref name="timer"></interceptor-ref>           
	<!-- 节点配置
		name : result名称 和Action中返回的值相同,
		type : result类型,
	不写则选用superpackage的type struts-default.xml中的默认为dispatcher -->           
	<result name="success" type="dispatcher">/talk.jsp</result>           
	<!-- 参数设置 name:对应Action中的get/set方法 -->           
	<param name="url">http://www.sina.com</param>        
</action>
  • global-results:定义全局result;
<!-- 全局results配置 -->        
<global-results>            
	<result name="input">/error.jsp</result>        
</global-results>
  • interceptors:定义拦截器;
<interceptors>            
	<!-- 定义拦截器:
		name:拦截器名称,
		class:拦截器类路径 -->            
	<interceptor name="timer" class="com.kay.timer"></interceptor>            
	<interceptor name="logger" class="com.kay.logger"></interceptor>            
	<!-- 定义拦截器栈 -->            
	<interceptor-stack name="mystack">                
		<interceptor-ref name="timer"></interceptor-ref>                
		<interceptor-ref name="logger"></interceptor-ref>            
	</interceptor-stack>        
</interceptors>
  • default-interceptor-ref:定义默认拦截器;
<!-- 定义默认的拦截器 每个Action都会自动引用,如果Action中引用了其它的拦截器 默认的拦截器将无效 -->        
<default-interceptor-ref name="mystack"></default-interceptor-ref>
  • 注:其他还有default-action-ref、defalut-class-ref、global-exception-mappings、result-types;

该部分参考:http://www.cnblogs.com/wkrbky/p/5889328.html

3.action节点中result type属性类型

  • dispatcher:它是默认的,用来转向页面,通常处理JSP
  • redirect:将用户重定向到一个已配置好的URL
  • redirectAction:将用户重定向到一个已定义好的action
  • chain:将action和另外一个action链接起来
  • freemarker:呈现Freemarker模板
  • httpheader:返回一个已配置好的HTTP头信息响应
  • stream:向浏览器发送InputSream对象对下载的内容和图片非常有用
  • velocity:呈现Velocity模板
  • xslt :该XML可以通过XSL模板进行转换
  • plaintext:显示原始文件内容,例如文件源代码

二、include 节点

Struts2中组件化的方式,可以将每个功能模块独立到一个xml配置文件中,然后用include节点引用;使用时需要注意以下四点:

  • xml文件完整性:用include引用的xml文件也必须是完整的struts2的配置;
  • name属性唯一性:struts.xml和struts-user.xml中package标签中的name属性不能相同;
  • 继承引用:只有子类文件struts-user.xml中的package继承自父类文件struts.xml中的package,才可以将struts-user.xml中的global-results放在struts.xml中;

示例配置文件代码:

  • 子类文件struts-user.xml
 <struts>          
	 <!-- 这里struts-user继承(extends)的是struts, 即struts.xml中package的name属性值 --> 
	 <!--  默认继承的是 extends="struts-default" -->          
	 <package name="struts-user" extends="struts">              
		 <action name="UserAction_login" class="userAction" method="login"></action>              
		 <action name="UserAction_insert" class="userAction" method="insert"></action>              
		 <action name="UserAction_update" class="userAction" method="update"></action>              
		 <action name="UserAction_delete" class="userAction" method="delete"></action>              
		 <action name="UserAction_queryById" class="userAction" method="queryById"></action>               
		 <action name="UserAction_queryByLike" class="userAction" method="queryByLike"> </action>              
		 <action name="UserAction_queryAll" class="userAction" method="queryAll">                  
		 	<result>/user/user_list.jsp</result>              
		 </action>          
	</package>      
</struts>
  • 父类文件struts.xml
<struts>      
	<include file="struts-user.xml"></include>      
	<package name="struts" extends="struts-default">          
		<global-results>              
			<result type="redirect-action">UserAction_queryAll</result>          
		</global-results>      
	</package>  
</struts> 

该部分参考:https://blog.csdn.net/zc_ad/article/details/53172809

三、constant 节点

用于设置一些Struts2的常量,这些常量用于控制struts2的某些特性;

<struts>    
	<!-- 请求参数的编码方式:指定Web应用的默认编码集.该属性对于处理中文请求参数非常有用,对于获取中文请求参数值,应该将该属性值设置为GBK或者GB2312;  提示:当设置该参数为GBK时,相当于调用HttpServletRequest的setCharacterEncoding方法。 -->    
	<constant name="struts.i18n.encoding" value="utf-8" />   
	
	<!--该属性指定处理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的包都要搜索。>   
	<constant name="struts.convention.package.locators" value="action" />    
	<!-- 让struts2支持动态方法调用 -->    
	<constant name="struts.enable.DynamicMethodInvocation" value="true" />    
	<!-- Action名称中是否还是用斜线 -->    
	<constant name="struts.enable.SlashesInActionNames" value="false" />    
	<!-- 允许标签中使用表达式语法 -->    
	<constant name="struts.tag.altSyntax" value="true" />
	
	<!--指定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" /
	<package>
	</package>
	</struts>

该部分参考:https://blog.csdn.net/thinkscape/article/details/7462670

【以上内容通过网络查找,并由个人整理所得,如有错误,希望留言提出,大家一起共同学习。】

 类似资料: