下面这个struts.xml囊括了所有可能用到的标签用法,例如配置全局的异常处理<global-exception-mappings>全局结果result<global-results>,缺省action-class类名<default-class-ref class=""/>,还有缺省的action名字<default-action-ref name="" />
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<!-- 常量配置 -->
<constant name="..." value="..." />
<constant name="struts.devMode" value="false" />
<!-- 可以将每个功能模块独立到一个xml配置文件中 然后用include节点引用 -->
<include file="config/struts/struts_business.xml" />
<!-- package的名字必须是唯一的 extends: 继承的父package名称 abstract: 设置package的属性为抽象的,抽象的package不能定义action, 像struts-default.xml定义的就是一个名为struts-default的抽象package, 开发者只需要继承这个package就行了 -->
<package name="package_name" extends="struts-default" namespace="/namespace">
<!-- 定义结果类型,此标签最多出现一次 -->
<result-types>
<result-type name="..." class="..." />
<result-type name="dispatcher" default="true"
class="org.apache.struts2.dispatcher.ServletDispatcherResult" />
</result-types>
<!-- 拦截器 此标签最多出现一次 -->
<interceptors>
<interceptor name="timer" class="com.kay.timer" />
<interceptor name="logger" class="com.kay.logger" />
<!-- 定义拦截器栈 -->
<interceptor-stack name="mystack">
<interceptor-ref name="timer" />
<interceptor-ref name="logger" />
</interceptor-stack>
<interceptor-stack name="newStack">
<interceptor-ref name="paramsPrepareParamsStack"></interceptor-ref>
<interceptor-ref name="token">
<param name="includeMethods">submit</param>
</interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 设置默认的拦截器每个Action都会自动引用,如果action中引用了其它的拦截器 这里的默认的拦截器将无效 -->
<default-interceptor-ref name="newStack" />
<!-- 当所在包对应namespace下没有匹配的action时,struts2会调用此默认的action -->
<default-action-ref name="unknown" />
<!-- struts.xml默认的action类 action标签里面没有指定class时默认使用此值 -->
<default-class-ref class="com.opensymphony.xwork2.ActionSupport" />
<!-- 全局results配置 -->
<global-results>
<result name="unknownError">/error.jsp</result>
<result name="noSession">/login.jsp</result>
</global-results>
<!-- 全局异常处理 一般搭配<global-results>使用 -->
<global-exception-mappings>
<exception-mapping exception="com.exception.UserException"
result="noSession">
<param name="namespace">/login</param>
</exception-mapping>
<exception-mapping exception="java.sql.SQLException" result="dbError" />
<exception-mapping exception="java.lang.Exception" result="unknownError" />
<exception-mapping exception="java.lang.RuntimeException" result="error"/>
</global-exception-mappings>
<!-- 这里使用了默认的<default-class-ref class="..."/> -->
<action name="unknown">
<result>/common/input.jsp</result>
</action>
<action name="login" class="com.ui.web.LoginAction">
<result name="success" type="redirectAction">
<param name="namespace">/admin</param>
<param name="actionName">index</param>
</result>
<result name="common" type="redirectAction">
<param name="namespace">/common</param>
<param name="actionName">index</param>
</result>
<result name="safe" type="redirectAction">
<param name="namespace">/safe</param>
<param name="actionName">index</param>
</result>
<result name="safeadmin" type="redirectAction">
<param name="namespace">/safeadmin</param>
<param name="actionName">index</param>
</result>
</action>
<!--action配置 method默认值是execute -->
<action name="submit*" class="com.action.{1}Action" method="submit">
<result>{1}/view.jsp</result>
<result name="input">{1}/edit.jsp</result>
<result name="invalid.token">{1}/view.jsp</result>
<exception-mapping result="input" exception="" />
</action>
<action name="uploadCaseFile" class="com.action.UploadCaseFileAction">
<interceptor-ref name="fileUploadStack">
<param name="fileUpload.maximumSize">52428800</param>
<param name="fileUpload.allowedExtensions">.jpg,.jpeg,.gif,.png,</param>
</interceptor-ref>
<interceptor-ref name="workflow" />
<result type="redirectAction">
<param name="actionName"><![CDATA[listFiles?caseId=${caseId}]]></param>
<param name="namespace">/business</param>
</result>
<!-- ${}可以直接访问该action的值栈里面的属性 -->
<result name="input">/business/${resultPage}.jsp</result>
</action>
<action name="downloadCaseFile" class="com.action.DownloadCaseFileAction">
<result type="stream">
<param name="contentType">${contentType}</param>
<param name="contentLength">${contentLength}</param>
<param name="contentDisposition">attachment;filename="${name}"</param>
<param name="inputName">fileStream</param>
<param name="bufferSize">4096</param>
</result>
</action>
</package>
</struts>
分享到:
相关推荐
struts-config.xml struts标准配置文件 struts-config
- `classname`:配置类,默认为`org.apache.struts.config.FormBeanConfig`,自定义需继承该类。 - `form-property`:配置表单字段的属性。 - `name`:字段名称。 - `type`:字段的数据类型。 - `initial`:...
总结来说,`struts.xml` 负责Struts2的Action配置,`applicationContext.xml` 管理Spring的Bean和依赖,而`web.xml` 定义了Web应用的基本结构和组件。这三个文件共同协作,构建了一个功能完善的Java Web应用,实现了...
struts2中的struts-default.xml
总结,`struts.xml`和`struts.properties`是Struts2框架中至关重要的配置文件,通过它们可以灵活地控制应用的行为和设定。理解并熟练运用这两个文件,对于开发高质量的Struts2应用至关重要。在实际项目中,开发者应...
struts.xml文件配置解释,对action配置进行说明
Struts2的Spring插件会在Struts配置文件(如struts.xml)中定义一个`<package>`,包含`<interceptors>`和`<default-interceptor-ref>`元素,这样Struts2就会知道如何与Spring协作,将Action实例化和依赖注入交给...
Struts.xml文件是Apache Struts 2...总结来说,struts.properties和struts.xml文件共同构成了Struts 2框架的配置体系,它们分别负责框架的基础属性设置和具体应用行为的定义,为开发者提供了强大的定制能力和灵活性。
正确理解和配置`struts-config.xml`是开发Struts应用的关键步骤。配置文件的结构和顺序非常重要,错误的配置可能导致应用程序无法正常运行。在编写配置时,要确保遵循正确的顺序,并根据应用需求正确设置各项参数。
本文将深入探讨 `struts-config.xml` 的主要元素和属性,帮助开发者更好地理解和配置 Struts 应用。 1. **<struts-config>**:根元素,包含整个配置信息。 - **form-beans**: 子元素,用于定义表单bean,这些bean...
struts-default.xml
`struts.xml`是Struts2框架的核心配置文件,用于定义应用程序的行为、控制器、动作映射、结果类型和其他关键组件。下面我们将深入探讨`struts.xml`的各个方面。 1. **配置文件结构** `struts.xml`文件通常位于项目...
这些常量定义在`struts-default.xml`和`struts-plugin.xml`等配置文件中,它们以键值对的形式存在,如`struts.objectFactory`、`struts.devMode`等。常量配置可以全局影响整个应用程序,比如设置开发模式、指定对象...
Struts2 中的 Struts.xml 配置文件是 Struts2 框架的核心配置文件,用于定义应用程序的行为和结构。在 Struts.xml 文件中,我们可以定义 package、action、interceptor、result 等多种元素,以便于实现具体的业务...
Struts的配置文件通常命名为struts-config.xml,它是整个Struts应用的核心配置文件,通过定义一系列的XML元素来设定框架的不同功能和行为。下面将详细介绍struts-config.xml中8个主要配置元素的功能和使用方法。 1....
通过以上分析可以看出,`struts.xml`文件是Struts2项目的核心配置文件之一,它不仅定义了项目的全局配置,还具体指定了每个Action的行为和返回结果,是Struts2框架中不可或缺的一部分。开发者可以根据实际需求调整...
在 struts1 框架中,web.xml 文件是必不可少的配置文件之一,它用于配置 Struts 应用程序的核心组件 ActionServlet。本文将详细解释 web.xml 文件中的配置项和相关知识点。 1. 配置 Struts 的 ActionServlet 在 ...
通过对`struts-config.xml`配置文件的详细解析,我们可以了解到如何通过不同的元素和属性来配置数据源、表单Bean以及全局异常处理等内容。这对于理解和使用Struts框架来说至关重要。希望本文能帮助读者更好地掌握...