zoukankan      html  css  js  c++  java
  • 【转】struts1的strutsconfig.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 结束 -->

  • 相关阅读:
    Linux常用命令大全(非常全!!!)
    洛谷 P3379 【模板】最近公共祖先(LCA)
    POJ 3259 Wormholes
    POJ 1275 Cashier Employment
    POJ 3169 Layout
    POJ 1201 Intervals
    洛谷 P5960 【模板】差分约束算法
    洛谷 P3275 [SCOI2011]糖果
    POJ 2949 Word Rings
    POJ 3621 Sightseeing Cows
  • 原文地址:https://www.cnblogs.com/lzhitian/p/2931437.html
Copyright © 2011-2022 走看看