官网是这样描述Struts2的:Apache Struts is a free, open-source, MVC framework for creating elegant, modern Java web applications. It favors convention over configuration, is extensible using a plugin architecture, and ships with plugins to support REST, AJAX and JSON.
Apache Struts是一个免费的,开源的,创造优雅的MVC框架,现代的java web应用程序。它有利于约定优于配置,可使用一系列的插件架构,插件支持REST,AJAX和JSON。
初识Struts,先弄清楚struts.xml的配置项到底怎么使用。
<?xml version = "1.0" encoding = "UTF-8"?>
<!--下面是Struts2配置文件的DTD信息 -->
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<!--struts是struts2配置文件的跟元素 -->
<struts>
<!--constant 配置常量 name:常量名 value:常量值 可以出现n次 -->
<!--指定Web应用的默认编码集,相当于调用HttpServletRequest的setCharacterEncoding方法 -->
<constant name="struts.i18n.encoding" value="UTF-8" />
<!--设置页面struts标签的样式 -->
<constant name="struts.ui.theme" value="simple" />
<!--该属性指定需要Struts 2处理的请求后缀,该属性的默认值是action,即所有匹配*.action的请求都由Struts 2处理。如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。 -->
<constant name="struts.action.extension" value="do,action,html"></constant>
<!--设置国际化 ,value必须和国际化配置文件前缀相同 -->
<constant name="struts.custom.i18n.resources" value="guojihua" />
<!--设置浏览器是否缓存静态内容,默认值为true,开发阶段最好false -->
<constant name="struts.serve.static.browserCache " value="false" />
<!--当struts的配置文件修改后,系统是否自动重新加载该文件,默认值为false,开发阶段最好true -->
<constant name="struts.configuration.xml.reload" value="true" />
<!-- 开发模式下设为true,这样可以打印出更详细的错误信息 -->
<constant name="struts.devMode" value="true" />
<!--使用超链接方法,如<a href="user!add">添加</a>必须设为true动态方法调用,可以解决多个请求对应一个Servlet的问题,后面详细讲解,默认为true,关闭则设为false. -->
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
<!-- bean标签通常用来配置一系列的工厂来生产对象 -->
<bean class="com.opensymphony.xwork2.ObjectFactory" name="xwork" />
<!--package元素是struts配置文件的核心,该元素可以出现n次 -->
<package name="login" extends="struts-default" namespace="/">
<!--result-types可以出现,也可以不出现,最多出现一次 -->
<result-types>
<result-type name="" class="" default="false">
<param name=""></param>
</result-type>
</result-types>
<!--interceptors 拦截器 可以出现,也可以不出现,但最多出现1次 -->
<interceptors>
<!--interceptors元素的子元素interceptor元素和interceptor-stack至少出现其中之一,也可以两者都出现 -->
<!--下面的元素可以出现n次 -->
<interceptor name="myInterceptorStack" class="">
<!--下面的元素可以出现n次 -->
<param name="参数名"> </param>
</interceptor>
<!--拦截器栈下面的元素可以出现n次 -->
<interceptor-stack name="">
<!-- 在自定义interceptor并将其ref时, 系统会覆盖掉默认的interceptor-stack(defaultStack), 为了保证系统默认的defaultStack不受印象, 我们需要显式的将其引入 -->
<!-- 注意两个interceptor-ref的顺序, 顺序不同, 执行效果也不同: 先配置的先执行/后配置的先退出(先进后出) -->
<interceptor-ref name="">
<!-- 下面的元素可以出现0次,也可以出现无限多次 -->
<param name="defaultStack"></param>
</interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 此默认interceptor是针对所有action的 -->
<!-- 如果某个action中引入了interceptor, 则在这个action中此默认interceptor就会失效 -->
<default-interceptor-ref name="myInterceptorStack"></default-interceptor-ref>
<!-- 设置默认的action,在没有找到用户访问的action的时候访问默认的action,这样做通常可以避免404Not Found的异常错误,给用户一个友好的提示页面 -->
<default-action-ref name="login" ></default-action-ref>
<!--全局的标签 例如:当一个Action返回的String没有相应的<result>与之对应,Struts2就会查找全局的<result> 下面的元素可以出现n次 -->
<global-results>
<!-- 该元素必须出现,可以出现无限多次 -->
<result name="" type="">
<!-- 该字符串内容可以出现n次 -->
<param name="参数名"></param>
</result>
</global-results>
<!-- 下面的元素可以出现n次 -->
<global-exception-mappings>
<!-- 该元素必须出现,可以出现多次 -->
<exception-mapping name="" exception="" result="">
<!-- 下面的元素可以出现n次 -->
<param name="参数名"></param>
</exception-mapping>
</global-exception-mappings>
<!-- action标签是struts2的核心标签,用来配置我们处理用户请求的意图 -->
<action name="login" class="com.lagersoft.action.LoginAction">
<!-- 下面的元素可以出现n次 -->
<param name=""></param>
<!-- 下面的元素可以出现n次 -->
<result name="success" >/index.jsp</result>
<!-- 下面的元素可以出现n次-->
<interceptor-ref name="">
<!-- 下面的元素可以出现n次 -->
<param name="参数名"></param>
</interceptor-ref>
<!-- 下面的元素可以出现n次 -->
<exception-mapping name="" exception="" result="">
<!-- 下面的元素可以出现n次 -->
<param name="参数名"></param>
</exception-mapping>
</action>
</package>
</struts>