【转】struts1的struts-config.xml的配置说明
<!-- struts-config.xml常用配置详解 2008年12月03日 --> 
<?xml 
version="1.0" encoding="UTF-8"?> 
<!DOCTYPE struts-config PUBLIC 
"-//Apache Software Foundation//DTD Struts Configuration 1.1//EN" 
"http://jakarta.apache.org/struts/dtds/struts-config.dtd"> 
<!-- struts-config.xml中的元素必须按照上述doc指令中的dtd文档定义顺序书写,本例即遵从了dtd定义顺序 
--> 
<!-- struts-config是整个xml的根元素,其他元素必须被包含其内 --> 
<struts-config><!-- struts-config 开始 --> 
<!-- 1 
------------------------------------------------------------------------------------ 
--> 
<!-- 
   名称:data-sources 
   描述:data-sources元素定义了web 
App所需要使用的数据源 
   数量:最多一个 
   子元素:data-source 
--> 
<data-sources> 
   <!-- 
名称:data-source 
描述:data-source元素定义了具体的数据源 
数量:任意多个 
属性: 
@key:当需要配置多个数据源时,相当于数据源的名称,用来数据源彼此间进行区别 
@type:可以使用的数据源实现的类,一般来自如下四个库 
Poolman,开放源代码软件 
Expresso,Jcorporate 
JDBC Pool,开放源代码软件 
DBCP,Jakarta 
   --> 
   <data-source key="firstOne" 
type="org.apache.commons.dbcp.BasicDataSource"> 
<!-- 
名称:set-property 
描述:用来设定数据源的属性 
属性: 
@autoCommit:是否自动提交 
可选值:true/false 
@description:数据源描述 
@driverClass:数据源使用的类 
@maxCount:最大数据源连接数 
@minCount:最小数据源连接数 
@user:数据库用户 
@password:数据库密码 
@url:数据库url 
@loginTimeout:超时 
--> 
<set-property property="url" 
value="jdbc:mysql://localhost:3306/数据库名称"/> 
<set-property 
property="driverClass" value="com.mysql.jdbc.Driver"/> 
<set-property 
property="autoCommit" value="true"/> 
<set-property 
property="description" value=""/> 
<set-property property="maxCount" 
value="10"/> 
<set-property property="minCount" value="2"/> 
<set-property property="user" value="root"/> 
<set-property 
property="password" value=""/> 
<!-- 或 --> 
<set-property 
property="driverClass" value="org.gjt.mm.mysql.Driver" /> 
<set-property property="url" value="jdbc:mysql://localhost:3306/数据库名称" 
/> 
<set-property property="autoCommit" value="false" /> 
<set-property property="user" value="root" /> 
<set-property 
property="password" value="root" /> 
<set-property property="minCount" 
value="5" /> 
<set-property property="maxCount" value="10" />      
<set-property property="description" value="" />      
<set-property property="readOnly" value="false" /> 
<set-property property="loginTimeout" value="" /> 
   
</data-source> 
</data-sources> 
<!-- 2 
------------------------------------------------------------------------------------ 
--> 
<!-- 
   名称:form-beans 
   描述:用来配置多个ActionForm Bean 
   
数量:最多一个 
   子元素:form-bean 
--> 
<!-- Form-beans 定义 ActionForm 
--> 
<form-beans><!-- form-beans 开始 --> 
   <!-- 
名称:form-bean 
描述:用来配置ActionForm Bean 
数量:任意多个 
子元素:form-property 
属性: 
@className:指定与form-bean元素相对应的配置类,一般默认使用org.apaceh.struts.config.FormBeanConfig,如果自定义,则必须继承 
FormBeanConfig 
@name:必备属性!为当前form-bean制定一个全局唯一的标识符,使得在整个Struts框架内,可以通过该标识符来引用这个ActionForm 
Bean。 
@type:必备属性!指明实现当前ActionForm Bean的完整类名。 
   --> 
   
<form-bean name="Hello" type="myPack.Hello"> 
<!-- 
名称:form-property 
描述:用来设定ActionForm Bean的属性 
数量:根据实际需求而定,例如,ActionForm 
Bean对应的一个登陆Form中有两个文本框,name和password,ActionForm 
Bean中也有这两个字段,则此处编写两个form-property来设定属性 
属性: 
@className:指定与form-property相对应的配置类,默认是org.apache.struts.config.FormPropertyConfig,如果自定义,则必须继承FormPropertyConfig类 
@name:所要设定的ActionForm Bean的属性名称 
@type:所要设定的ActionForm Bean的属性值的类 
@initial:当前属性的初值 
--> 
<form-property name="name" 
type="java.lang.String"/> 
<form-property name="number" 
type="java.lang.Iteger" initial="18"/> 
</form-bean> 
<!-- 
////////////////////////////////////////////////////////////////////////////// 
<!-- 登录的 ActionForm 
     <form-bean name="登录loginForm" 
type="org.apache.struts.validator.DynaValidatorForm"> 
          
<form-property name="比如工作ID" type="java.lang.String"/> 
<form-property name="比如用户ID" type="java.lang.String"/> 
       ... 
等等 
     </form-bean> 
     <!-- 其他对应的 ActionForm 
     
<form-bean name="处理问题的Form" 
type="org.apache.struts.validator.DynaValidatorForm"/> 
          
<form-property name="标题,表字段" type="java.lang.String"/> 
<form-property name="姓名,表字段" type="java.lang.String"/> 
       ... 
等等 
</form-bean> 
/////////////////////////////////////////////////////////////////////////////////--> 
<!-- ActionForm -- 对应 --> 
<!-- 
@name:必备属性.为当前form-bean制定一个全局唯一的标识符,使得在整个Struts框架内,可以通过该标识符来引用这个ActionForm 
Bean - "userForm" 
@type:必备属性.当前ActionForm Bean的完整类名 - 
"org.我的项目.struts.form.UserForm.java" 
--> 
        <form-bean 
name="userForm" type="org.我的项目.struts.form.UserForm" /> 
<form-bean 
name="adminForm" type="org.我的项目.struts.form.AdminForm" /> 
</form-beans><!-- form-beans 结束 --> 
<!-- 3 
------------------------------------------------------------------------------------ 
--> 
<!-- 
   名称:global-exceptions 
   描述:处理异常 
   数量:最多一个 
   子元素:exception 
--> 
<global-exceptions> 
   <!-- 
名称:exception 
描述:具体定义一个异常及其处理 
数量:任意多个 
属性: 
@className:指定对应exception的配置类,默认为org.apache.struts.config.ExceptionConfig 
@handler:指定异常处理类,默认为org.apache.struts.action.ExceptionHandler 
@key:指定在Resource Bundle种描述该异常的消息key 
@path:指定当发生异常时,进行转发的路径 
@scope:指定ActionMessage实例存放的范围,默认为request,另外一个可选值是session 
@type:必须要有!指定所需要处理异常类的名字。 
@bundle:指定资源绑定 
   --> 
   
<exception 
key=""hello.error 
path="/error.jsp" 
scope="session" 
type="hello.HandleError"/> 
</global-exceptions> 
<!-- 
   名称:global-forwards 
   描述:定义全局转发 
   数量:最多一个 
   子元素:forward 
--> 
<global-forwards> 
   <!-- 
名称:forward 
描述:定义一个具体的转发 
数量:任意多个 
属性: 
@className:指定和forward元素对应的配置类,默认为org.apache.struts.action.ActionForward 
@contextRelative:如果为true,则指明使用当前上下文,路径以“/”开头,默认为false 
@name:必须配有!指明转发路径的唯一标识符 
@path:必须配有!指明转发或者重定向的URI。必须以"/"开头。具体配置要与contextRelative相应。 
@redirect:为true时,执行重定向操作,否则执行请求转发。默认为false 
   --> 
   <forward 
name="A" path="/a.jsp"/> 
   <forward name="B" path="/hello/b.do"/> 
</global-forwards> 
<!-- 4 
------------------------------------------------------------------------------------ 
--> 
<!-- 
   名称:action-mappings 
   描述:定义action集合 
   
数量:最多一个 
   子元素:action 
--> 
<action-mappings><!-- 
action-mappings 开始 --> 
   <!-- 
名称:action 
描述:定义了从特定的请求路径到相应的Action类的映射 
数量:任意多个 
子元素:exception,forward(二者均为局部量) 
属性: 
@attribute:制定与当前Action相关联的ActionForm Bean在request和session范围内的名称(key) 
@className:与Action元素对应的配置类。默认为org.apache.struts.action.ActionMapping 
@forward:指名转发的URL路径 
@include:指名包含的URL路径 
@input:指名包含输入表单的URL路径,表单验证失败时,请求会被转发到该URL中 
@name:指定和当前Acion关联的ActionForm 
Bean的名字。该名称必须在form-bean元素中定义过。 
@path:指定访问Action的路径,以"/"开头,没有扩展名 
@parameter:为当前的Action配置参数,可以在Action的execute()方法中,通过调用ActionMapping的getParameter()方法来获取参数 
@roles:指定允许调用该Aciton的安全角色。多个角色之间用逗号分割。处理请求时,RequestProcessor会根据该配置项来决定用户是否有调用该Action的权限 
@scope:指定ActionForm Bean的存在范围,可选值为request和session。默认为session 
@type:指定Action类的完整类名 
@unknown:值为true时,表示可以处理用户发出的所有无效的Action 
URL。默认为false 
@validate:指定是否要先调用ActionForm Bean的validate()方法。默认为true 
注意:如上属性中,forward/include/type三者相斥,即三者在同一Action配置中只能存在一个。 
   --> 
   <action path="/search" 
   type="addressbook.actions.SearchAction" 
   name="searchForm" 
   scope="request" 
   validate="true" 
   
input="/search.jsp"> 
<forward name="success" path="/display.jsp"/> 
   </action> 
   <!-- 
//////////////////////////////////////////////////////////////////////////////////////////////////// 
<!-- 配置进入主页的请求的 Action -- 
<action path="/index" scope="request" 
validate="false" input="error" type="com.项目.action.LogoutAction"> 
      
<forward path="index" name="Index"/> 
         </action> 
         <!-- 配置员工或用户登录的Action -- 
<action path="/登录路径" 
name="登录loginForm" scope="request" validate="false" input="index" 
type="com.项目.action.登录loginAction"> 
      <forward 
path="要转发的页面比如/techSupport.do?method=goTechSupportView" 
name="GoTechSupportView"/> 
<forward path="要转发的页面比如管理员" 
name="GoAdminView"/> 
         </action> 
//////////////////////////////////////////////////////////////////////////////////////////////////// 
--> 
   <!-- 配置用户的Action -- 对应 --> 
<!-- userForm --> 
         <action attribute="userForm" 
input="/jsp/errors.jsp" 
     name="userForm" 
parameter="status" 
path="/jsp/user" 
scope="request" 
type="org.我的项目.struts.action.UserAction"> 
<forward name="registersuccess" 
path="/jsp/index.do?status=list"></forward><!-- 配置局部跳转 --> 
<forward name="registerfailure" 
path="/jsp/register.jsp"></forward> 
<!-- 配置局部异常处理 
           
<exception type="" key=""/> 
        --> 
</action> 
<!-- 此处的意思是直接交给spring容器掌管了 
<action attribute="loginForm" 
name="loginForm" 
path="/login" 
scope="request" 
type="org.springframework.web.struts.DelegatingActionProxy" 
此处的意思是直接交给spring容器掌管了/> 
--> 
</action-mappings><!-- action-mappings 结束 --> 
<!-- 5 
------------------------------------------------------------------------------------ 
--> 
<!-- 
   名称:controller 
   描述:用于配置ActionServlet 
   
数量:最多一个 
   属性: 
@bufferSize:指定上传文件的输入缓冲的大小.默认为4096 
@className:指定当前控制器的配置类.默认为org.apache.struts.config.ControllerConfig 
@contentType:指定相应结果的内容类型和字符编码 
@locale:指定是否把Locale对象保存到当前用户的session中,默认为false 
@processorClass:指定负责处理请求的Java类的完整类名.默认org.apache.struts.action.RequestProcessor 
@tempDir:指定文件上传时的临时工作目录.如果没有设置,将才用Servlet容器为web应用分配的临时工作目录. 
@nochache:true时,在相应结果中加入特定的头参数:Pragma 
,Cache-Control,Expires防止页面被存储在可数浏览器的缓存中,默认为false 
--> 
<!-- 
配置RequestProcessor插件 
    <controller 
processorClass="com.项目.MyRequestProcessor"></controller> 
--> 
    <!-- 自定义RequestProcessor 用于解决汉字乱码和Spring集成问题 --> 
<controller processorClass="com.项目.processor.EncodingProcessor"/> 
    <!-- 
<controller contentType="text/html;charset=UTF-8" 
   locale="true" 
   processorClass="CustomRequestProcessor"> 
</controller> 
--> 
<!-- 6 
------------------------------------------------------------------------------------ 
--> 
<!-- 
   名称:message-resources 
   描述:配置Resource Bundle. 
   数量:任意多个 
   属性: 
@className:指定和message-resources对应的配置类.默认为org.apache.struts.config.MessageResourcesConfig 
@factory:指定资源的工厂类,默认为org.apache.struts.util.PropertyMessageResourcesFactory 
@key: 
@null: 
@parameter: 
--> 
<!-- 配置国际化资源文件 --> 
<message-resources parameter="com.项目.resource.ApplicationResources"/> 
<!-- 
<message-resources 
   null="false" 
   
parameter="defaultResource"/> 
<message-resources 
   key="images" 
   null="false" 
   parameter="ImageResources"/> 
--> 
<!-- 7 
------------------------------------------------------------------------------------ 
--> 
<!-- 配置Title标记库插件 --> 
<plug-in 
className="org.apache.struts.title.TitlesPlugin"> 
     <set-property 
property="definitions-config" value="/WEB-INF/title-defs.xml"/> 
    
</plug-in> 
<!-- 8 
------------------------------------------------------------------------------------ 
--> 
<!-- 配置表单验证组件 -- validate验证文件 
<plug-in 
classNme="org.apache.struts.validator.ValidatorPlugin"> 
     
<set-property property="pathnames" 
value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml"/> 
<set-property property="stopOnFirstError" value="false"> 
</set-property> 
--> 
<!-- 
   名称:plug-in 
   
描述:用于配置Struts的插件 
   数量:任意多个 
   子元素:set-property 
   属性: 
@className:指定Struts插件类.此类必须实现org.apache.struts.action.PlugIn接口 
--> 
<plug-in 
   
className="org.apache.struts.validator.ValidatorPlugIn"> 
   <!-- 
名称:set-property 
描述:配置插件的属性 
数量:任意多个 
属性: 
@property:插件的属性名称 
@value:该名称所配置的值 
   --> 
   <set-property 
property="pathnames" 
value="/WEB-INF/validator-rules.xml,/WEB-INF/vlaidation.xml"/> 
</plug-in> 
<set-property property="stopOnFirstError" 
value="false"></set-property> 
<!-- 9 
------------------------------------------------------------------------------------ 
--> 
<!-- 配置spring插件 --> 
<plug-in 
className="org.springframework.web.struts.ContextLoaderPlugin"> 
     
<set-property property="contextConfigLocation" 
value="/WEB-INF/applicationContext.xml"></set-property> 
    
</plug-in> 
<!-- 10 
------------------------------------------------------------------------------------ 
--> 
<!-- 配置Plugin插件 --> 
   <plug-in 
className="com.项目.MyPlugin"> 
<!-- 11 
------------------------------------------------------------------------------------ 
--> 
</struts-config> <!-- struts-config 结束 -->
 
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号