struts.xml是Struts2框架的核心配置文件,定义了Action、结果视图、拦截器、包结构等关键内容。1. 根元素为<struts>,包含多个继承struts-default的<package>,用于组织Action;2. <action>配置请求映射,通过name、class和method指定处理类及方法;3. <result>定义跳转视图,支持dispatcher、redirect等类型;4. 拦截器通过<interceptors>和<interceptor-ref>配置,可自定义栈并应用于包内Action;5. <constant>设置常量如devMode、编码等以调整框架行为;6. 使用<include>引入外部配置文件实现模块化管理。合理配置可提升应用结构清晰度与维护性。

Struts2 框架的核心配置文件 struts.xml 是整个应用的控制中枢,负责定义动作(Action)、结果视图、拦截器、包结构等关键内容。合理配置 struts.xml 能让请求分发更清晰、流程控制更灵活。下面详细介绍其结构与常用配置项。
1. struts.xml 基本结构
struts.xml 必须位于类路径下(通常为 src 目录或 resources 目录),其根元素是 <struts>,内部可包含多个 <package> 元素,每个 package 可组织一组相关的 Action 和配置。
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"
"http://struts.apache.org/dtds/struts-2.5.dtd">
<struts>
<package name="default" extends="struts-default">
<action name="login" class="com.example.LoginAction">
<result name="success">/success.jsp</result>
<result name="input">/login.jsp</result>
</action>
</package>
</struts>
说明:
- name:包名,唯一标识一个配置包。
- extends:继承其他包,通常继承 struts-default 以获得默认拦截器和结果类型。
- namespace:命名空间,用于区分不同模块的 Action 请求路径。
2. Action 配置详解
Action 是处理用户请求的核心组件,通过 <action> 标签配置。
- name:请求的 URL 名称,如访问 login.action 会匹配 name="login" 的 Action。
- class:实现类的全限定名,若不写,默认为 ActionSupport。
- method:指定调用的方法名,不设置则默认执行 execute() 方法。
示例:
<action name="userAdd" class="com.example.UserAction" method="add"><result name="success">/addSuccess.jsp</result>
</action>
此时访问 userAdd.action 将调用 UserAction 中的 add() 方法。
3. 结果视图(Result)配置
<result> 定义 Action 执行后跳转的目标资源。
- name:逻辑结果名,对应 Action 返回的字符串(如 "success"、"error")。
- type:结果类型,常见值包括:
示例:
<result name="success" type="redirect">/index.jsp</result><result name="toList" type="redirectAction">userList</result>
4. 拦截器(Interceptor)配置
拦截器用于在 Action 执行前后插入逻辑,如权限校验、日志记录等。
- 可在 package 中定义拦截器栈:<interceptors>
- 通过 <interceptor-ref> 引用拦截器或拦截器栈
示例:
<package name="secure" extends="struts-default"><interceptors>
<interceptor name="auth" class="com.example.AuthInterceptor"/>
<interceptor-stack name="myStack">
<interceptor-ref name="defaultStack"/>
<interceptor-ref name="auth"/>
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="myStack"/>
<action name="profile" class="com.example.ProfileAction">
<result>/profile.jsp</result>
</action>
</package>
上述配置中,所有该包下的 Action 都会使用自定义的 myStack 拦截器栈。
5. 常用常量配置(constant)
可通过 <constant> 修改框架行为。
<constant name="struts.devMode" value="true"/><constant name="struts.i18n.encoding" value="UTF-8"/>
<constant name="struts.multipart.maxSize" value="10485760"/>
常见常量:
- struts.devMode:开发模式,开启后输出详细日志
- struts.enable.DynamicMethodInvocation:是否允许动态方法调用
- struts.ui.theme:指定 UI 主题(如 simple、xhtml)
6. 包含外部配置文件
当配置较多时,可拆分为多个 XML 文件,使用 <include> 引入。
<include file="struts-user.xml"/><include file="struts-admin.xml"/>
便于模块化管理,提升可维护性。
基本上就这些。掌握 struts.xml 的核心配置,能有效支撑 Struts2 应用的开发与调试。配置虽灵活,但需注意命名规范与层级关系,避免冲突或覆盖。不复杂但容易忽略细节。










