Struts2原理(底层使用的是Servlet的doFilter方法):
Struts2优点:
第一个Struts程序:
在开发Struts程序之前,首先要导入额外的jar包,基本需求的是14个jar包,关于14个ja包是什么,有什么作用,此处不讲述。
还要配置web.xml文件,注册Struts启动项,如下:
<!--注册Struts启动项 -->
<filter>
<filter-name>Struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>Struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
第一步创建界面,属于前端知识,不详述。
第二步创建XXXAction类,注意创建的类所属的包,命名时末尾必须是XXX.....actions/action/struts/strut。在XXXAction类中,默认创建的一个执行方法是execute,方法名可以改,而且可以有不止一个执行方法,后面介绍,如果是方法名是execute,则该方法默认执行,不需要在struts.xml中注册。
第二步注册XXXAction类,即创建struts.xml文件(名字不能改)并注册,在这个xml文件头中要加入
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
这个文件约束,它规定了struts.xml文件中能用的标签,它同时也是xml文件的根。这个约束文件的说明在struts2-core-XXX.jar中的struts-XX.dtd文件中。
第四步,在struts.xml文件定义要求结果跳转的视图(页面),和创建对应的视图。
struts.xml文件基本配置如下:
<struts>
<package name="demo" namespace="/test" extends="struts-default">
<action name="login" class="com.tongji.actions.LoginAction">
<result name="success">/welcome.jsp</result>
</action>
</package>
</struts>
依次为包命名空间(包含继承关系)、action注册、结果跳转视图
第一步创建页面的时候,要注意表单的action要写成:action="test/login.action",注意后缀名。
第二步XXXAction中方法中要返回结果,例如return "success";如果是success,它是系统默认的返回值,注册时可以不写。
Struts相关的6个配置文件:
1. struts-default.xml(重要):
Struts2默认发的核心配置文件,其中定义了11种返回类型、35中拦截器、及拦截器栈,定了默认应用的拦截器栈,及默认注册的XXXAction类(ActionSupport),如果
<action name="login" class="com.tongji.actions.LoginAction">
中不定义class,则默认运行的XXXAction类就是这个ActionSupport类。
这个配置文件不能修改,只能做参考查询用,在struts2-core-XXX.jar中。
2. default.properties(重要):
定义了Struts2中常用的默认值,比如
struts.action.extension=action,,
定义了页面请求时的action="test/login.action",这个action后缀。
其他常量用到时再讲述,注意修改常量也不是在这里修改,这里也只是作参考,供修改默认值时参考。在struts2-core-XXX.jar中/org/apache/struts2的包下。
3. struts-plugin.xml:
Struts2与第三方插件的整合配置文件,在Struts框架lib目录中所有以-plugin-结束的jar包中。
4. struts.properties:
用于修改常量的值,因为常量在struts.xml文件中也可以进行修改,所以一般不使用该文件。该文件手工创建,在src目录下。
5. web.xml:
用于用于设置常量、拓展Struts2等,但一般不这样使用,因为常量在struts.xml文件中也可以进行修改,但常量修改优先级web.xml最高。
6. struts.xml(最重要):
具体后面讲述,讲一点:常量修改有效性优先级为struts.xml<struts.properties<web.xml,但一般都在struts.xml中修改。
<constant name="struts.action.extension" value="asp"></constant>
核心配置文件(struts.xml):
不要忘了文件约束:
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
配置一(基本配置):
<struts>
<constant name="struts.action.extension" value="do"></constant>
<package name="demo" namespace="/test" extends="struts-default">
<action name="login" class="com.tongji.actions.LoginAction" method="doSome">
<result>/welcome.jsp</result>
<result name="tooSmall">/tooSmall.jsp</result>
<result name="tooOld">/tooOld.jsp</result>
</action>
<action name="goRegister">
<result name="success">/register.jsp</result>
</action>
</package>
</struts>
constant修改default.properties中的常量;
package包名(包含定位名称和继承关系);
action定义响应的名称、对应的XXXAction类和响应方法(如果响应方法名称为execute,则为默认,可以不写method;
如果响应方法只是为了返回success,例如页面跳转的情况,则可以不写对应类class,此时默认的XXXAction类为默认的ActionSupport类,
这个类实现了返回success的execute响应方法,这个是在struts-default.xml中配置的)
result定义结果跳转页面(如果响应方法返回的是success,则为默认,可以不写name)
配置二(转发和重定向):
1. 页面之间的转发(type为返回类型,struts-default.xml配置的,dispatcher是默认的):
<struts>
<package name="demo" namespace="/test" extends="struts-default">
<action name="login" class="com.tongji.actions.LoginAction">
<result type="dispatcher">/welcome.jsp</result>
</action>
</package>
</struts>
2. 页面之间的重定向:
<struts>
<package name="demo" namespace="/test" extends="struts-default">
<action name="login" class="com.tongji.actions.LoginAction">
<!-- <result type="redirect">/welcome.jsp?uname=${name}&uage=${age}</result> -->
<result type="redirect">
<param name="location">/welcome.jsp</param>
<param name="uname">${name}</param>
<param name="uage">${age}</param>
</result>
</action>
</package>
</struts>
3. XXXAction之间的重定向:
<struts>
<package name="demo" namespace="/test" extends="struts-default">
<action name="login" class="com.tongji.actions.LoginAction">
<result type="redirectAction">
<param name="actionName">other</param>
<param name="uname">${name}</param>
<param name="uage">${age}</param>
</result>
</action>
<action name="other" class="com.tongji.actions.OtherAction">
<result>/welcome.jsp</result>
</action>
</package>
</struts>
4. XXXAction之间的转发:
<struts>
<package name="demo" namespace="/test" extends="struts-default">
<action name="login" class="com.tongji.actions.LoginAction">
<result type="chain">other</result>
</action>
<action name="other" class="com.tongji.actions.OtherAction">
<result>/welcome.jsp</result>
</action>
</package>
</struts>
配置三(全局视图):
1. 定义包全局视图:
<struts>
<package name="demo" namespace="/test" extends="struts-default">
<global-results>
<result>/welcome.jsp</result>
<result name="fail">/fail.jsp</result>
</global-results> <action name="some" class="com.tongji.actions.LoginAction" method="doSome" />
<action name="second" class="com.tongji.actions.LoginAction" method="doSecond">
<result name="old">/old.jsp</result>
</action>
</package>
</struts>
2 定义应用全局视图(使用包继承实现,被继承的包可以定义为抽象包):
<struts>
<package name="myBase" extends="struts-default" abstract="true">
<global-results>
<result>/welcome.jsp</result>
<result name="fail">/fail.jsp</result>
</global-results>
</package> <package name="demo" namespace="/test" extends="myBase">
<action name="some" class="com.tongji.actions.LoginAction" method="doSome" />
<action name="second" class="com.tongji.actions.LoginAction" method="doSecond">
<result name="old">/old.jsp</result>
</action>
</package>
</struts>
配置四(多配置文件):
<struts>
<!--<include file="struts-base.xml"></include>
<include file="struts-actions.xml"></include> --> <include file="struts-*.xml"></include>
</struts>
file不要定义成"*.xml",不合理。