`
一日一博
  • 浏览: 229595 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

Struts2配置精要之struts.xml( global和default的配置)

阅读更多
下面这个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

    struts-config.xml struts标准配置文件 struts-config

    Struts框架中struts-config.xml文件配置小结

    - `classname`:配置类,默认为`org.apache.struts.config.FormBeanConfig`,自定义需继承该类。 - `form-property`:配置表单字段的属性。 - `name`:字段名称。 - `type`:字段的数据类型。 - `initial`:...

    struts.xml和applicationContext.xml、web.xml的配置

    总结来说,`struts.xml` 负责Struts2的Action配置,`applicationContext.xml` 管理Spring的Bean和依赖,而`web.xml` 定义了Web应用的基本结构和组件。这三个文件共同协作,构建了一个功能完善的Java Web应用,实现了...

    struts2中的struts-default.xml

    struts2中的struts-default.xml

    struts.xml和struts.properties配置详解

    总结,`struts.xml`和`struts.properties`是Struts2框架中至关重要的配置文件,通过它们可以灵活地控制应用的行为和设定。理解并熟练运用这两个文件,对于开发高质量的Struts2应用至关重要。在实际项目中,开发者应...

    struts.xml

    struts.xml文件配置解释,对action配置进行说明

    spring在web.xml中和在struts中的不同配置..pdf

    Struts2的Spring插件会在Struts配置文件(如struts.xml)中定义一个`&lt;package&gt;`,包含`&lt;interceptors&gt;`和`&lt;default-interceptor-ref&gt;`元素,这样Struts2就会知道如何与Spring协作,将Action实例化和依赖注入交给...

    struts.xml文件详解.doc

    Struts.xml文件是Apache Struts 2...总结来说,struts.properties和struts.xml文件共同构成了Struts 2框架的配置体系,它们分别负责框架的基础属性设置和具体应用行为的定义,为开发者提供了强大的定制能力和灵活性。

    struts-config.xml

    正确理解和配置`struts-config.xml`是开发Struts应用的关键步骤。配置文件的结构和顺序非常重要,错误的配置可能导致应用程序无法正常运行。在编写配置时,要确保遵循正确的顺序,并根据应用需求正确设置各项参数。

    配置struts--config.xml详解

    本文将深入探讨 `struts-config.xml` 的主要元素和属性,帮助开发者更好地理解和配置 Struts 应用。 1. **&lt;struts-config&gt;**:根元素,包含整个配置信息。 - **form-beans**: 子元素,用于定义表单bean,这些bean...

    struts-default.xml

    struts-default.xml

    struts.xml(struts2配置)

    `struts.xml`是Struts2框架的核心配置文件,用于定义应用程序的行为、控制器、动作映射、结果类型和其他关键组件。下面我们将深入探讨`struts.xml`的各个方面。 1. **配置文件结构** `struts.xml`文件通常位于项目...

    Struts2配置精要之常量constant配置详解(包括零配置Convention 的常量)

    这些常量定义在`struts-default.xml`和`struts-plugin.xml`等配置文件中,它们以键值对的形式存在,如`struts.objectFactory`、`struts.devMode`等。常量配置可以全局影响整个应用程序,比如设置开发模式、指定对象...

    Struts2中Struts.xml配置文件详解

    Struts2 中的 Struts.xml 配置文件是 Struts2 框架的核心配置文件,用于定义应用程序的行为和结构。在 Struts.xml 文件中,我们可以定义 package、action、interceptor、result 等多种元素,以便于实现具体的业务...

    Struts-config.xml配置详解

    Struts的配置文件通常命名为struts-config.xml,它是整个Struts应用的核心配置文件,通过定义一系列的XML元素来设定框架的不同功能和行为。下面将详细介绍struts-config.xml中8个主要配置元素的功能和使用方法。 1....

    struts2属性文件struts.xml的配置

    通过以上分析可以看出,`struts.xml`文件是Struts2项目的核心配置文件之一,它不仅定义了项目的全局配置,还具体指定了每个Action的行为和返回结果,是Struts2框架中不可或缺的一部分。开发者可以根据实际需求调整...

    struts1中web.xml配置详解

    在 struts1 框架中,web.xml 文件是必不可少的配置文件之一,它用于配置 Struts 应用程序的核心组件 ActionServlet。本文将详细解释 web.xml 文件中的配置项和相关知识点。 1. 配置 Struts 的 ActionServlet 在 ...

    Struts struts-config.xml配置

    通过对`struts-config.xml`配置文件的详细解析,我们可以了解到如何通过不同的元素和属性来配置数据源、表单Bean以及全局异常处理等内容。这对于理解和使用Struts框架来说至关重要。希望本文能帮助读者更好地掌握...

Global site tag (gtag.js) - Google Analytics