struts-config.xml文件详解

380人浏览 / 0人评论
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.3//EN" "http://struts.apache.org/dtds/struts-config_1_3.dtd">
<struts-config>
    <!--弄清楚struts-config.xml中各项元素的作用,对于我们构建web项目有莫大的好处。它主要有8个子元素-->
    <!--1、存放form-bean-->
    <form-beans>
        <!--该元素主要用来配置表单验证的类。-->
        <!--classname:一般用得少,指定和form-bean无素对应的配置类,默认为org.apache.struts.config.-->
        <!--name:ActionForm Bean的惟一标识。必须。-->
        <!--type:ActionForm的完整类名。必须。-->
        <form-bean name="" type=""></form-bean>
    </form-beans>
    <!--2、该元素主要配置异常处理,它的exception子元素代表全局的异常配置。struts采取配置的方式来处理异常。它用来设置java异常和异常处理类 org.apache.struts.action.ExceptionHandler之间的映射。-->
    <!--className:指定和exception元素对应的配置类,默认为:org.apache.struts.config.ExceptionConfig。可有可无。-->
    <!--Handler:指定异常得理类,默认为:org.apache.struts.action.ExceptionHandler。可有可无-->
    <!--key:指定在Resource Bundle中描述该异常的消息key-->
    <!--path:指定当异常发生时的转发路径。-->
    <!--scope:指定ActionMessages实例的存放范围,可选值包括:request和session,默认为request。可有可无。-->
    <!--type:指定所需处理异常类的名字,必须。-->
    <!--bundle:指定Resource Bundle-->
    <global-exceptions>
        <exception type=""></exception>
    </global-exceptions>
    <!--3、该元素主要用来声明全局的转发关系-->
    <!--className:和forward元素对应的配置类,默认为:org.apache.struts.action.ActionForward。可有可无。-->
    <!--contextRelative:此项为true时,表时path属性以"/"开头,相对于当前上下文的URL,默认为false.可有可无 -->
    <!--name:转发路径的逻辑名.必填。-->
    <!--path:转发或重定向的URL,当contextRelative=false时,URL路径相对于当前应用(application),当为ture时,表示URL路径相对于当前上下文(context)。-->
    <!--redirect:当此项为ture时,表示执行重定向操作。当此项为false时表示转向操作。默认为false。-->
    <global-forwards></global-forwards>
    <!--4、描述从特定的请求路径到相应的Action类的映射。-->
    <!--attribute:设置和Action关联的ActionForm Bean在request和session范围内的key。如:Form Bean存在于request范围内,此项设为“myBenas”,则在request.getAttribute("myBenas")就可以返回该 Bean的实例。-->
    <!--classsName:和action元素对应的配置元素,默认为:org.apache.struts.action.ActionMapping.-->
    <!--forward:转发的URL路径。-->
    <!--include:指定包含的URL路径。-->
    <!--input:输入表单的URL路径,当表单验证失败时,将把请求转发到该URL。-->
    <!--name:指定和Action关联的Action FormBean的名字,该名字必须在Form-Bean定义过。-->
    <!--path:指定访问Action的路径,以“/”开头,无扩展名。-->
    <!--parameter:指定Actgion的配置参数,在Action类的execute()方法中,可以调用ActionMapping对象的getParameter()方法来读取该配置参数。-->
    <!--roles:指定允许调用该Action的安全角色,多个角色之间用,隔开,在处理请求时,RequestProcessor会根据该配置项来决定用户是否有权限调用Action权限。-->
    <!--scope:指定ActionForm Bean的存在范围,可选取为request和session,默认为session。-->
    <!--type:指定Action类的完整类名。-->
    <!--unknown:如果此项为true,表示可以处理用户发出的所有无效的Action URL,默认为false;-->
    <!--validate:指定是否要调用Action FormBean的validate方法,默认值为ture.-->
    <action-mappings>
         
        <action path="/aa" forward="/aa.jsp"></action>
    </action-mappings>
    <!--5、该元素用于配置ActionServlet。-->
    <!--bufferSize:指定上载文件的输入缓冲大小,可选,默认为4096-->
    <!--className:指定和controller元素对应的配置类,默认为org.apache.struts.config.ControllerConfig-->
    <!--conentType:字符编码,如果在Action和JSP网页中设置了,则覆盖该设置。-->
    <!--locale:指定是否把Locale对象保存到当前用户的session中,默认值为false.-->
    <!--processorClass:指定负责请求的java类完整路径。-->
    <!--tempDir:指定处理文件的临时工作目录,如果此项没有设置,将采用Servlet容器为web应用分配的临时工作目录。-->
    <!--nochache:如果为true:在响应结果中将加入特定的头参数:Pragma,Cache-Control和Expise-->
    <controller contentType="text/html;charset=UTF-8" locale="true" processorClass="con.ok"/>
    <!--6、主要配置本地化消息文本,-->
    <!--className:和message-resources元素对应的配置类,默认为org.apache.struts.config.MessageResourcesConfig。-->
    <!--factory:指定消息资源的工厂类,默认为:org.apache.struts.util.PropertyMessageResourcesFactory类-->
    <!--key:指定Resource Bundle存放的ServletContext对象中时采用的属性Key,默认由Globals.MESSAGES_KEY定义的字符串常量,只允许一个Resource Bundle采用默认的属性Key。-->
    <!--null:指定MessageSources类如何处理未知消息的key,如果为true,则返回空字符串,如果为false,则返回相关字串,默认为false-->
    <!--prameter:指定MessageSources的资源文件名,如果为:a.b.ApplicationResources,则实际对应的文件路径为:WEB-INF/classes/a/b/ApplicationResources.properties.-->
    <message-resources parameter=""></message-resources>
    <!--7、配置Struts的插件-->
    <!--className:指定的Struts插件类,必须实现org.apache.struts.action.PlugiIn接口。-->
    <plug-in className="a.b.c."/>
    <!--date-sources元素用来配置应用程序所需要的数据源。java语言提供了javax.sql.DateSource接口,所有数据源必须实现该接口。-->
</struts-config>