`
netxdiy
  • 浏览: 715042 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

深入Struts2

阅读更多
1.深入Struts2的配置文件
本部分主要介绍struts.xml的常用配置。
1.1.包配置:
Struts2框架中核心组件就是Action、拦截器等,Struts2框架使用包来管理Action和拦截器等。每个包就是多个Action、多个拦截器、多个拦截器引用的集合。
在struts.xml文件中package元素用于定义包配置,每个package元素定义了一个包配置。它的常用属性有:
lname:必填属性,用来指定包的名字。
lextends:可选属性,用来指定该包继承其他包。继承其它包,可以继承其它包中的Action定义、拦截器定义等。
lnamespace:可选属性,用来指定该包的命名空间。
<!DOCTYPEstrutsPUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<!-- struts2action必须放在一个指定的包空间下定义-->
<packagename="default"extends="struts-default">
<!--定义处理请求URLlogin.actionAction -->
<actionname="login"class="org.qiujy.web.struts.action.LoginAction">
<!--定义处理结果字符串和资源之间的映射关系-->
<resultname="success">/success.jsp</result>
<resultname="error">/error.jsp</result>
</action>
</package>
</struts>
如上示例的配置,配置了一个名为default的包,该包下定义了一个Action。
1.2.命名空间配置:
考虑到同一个Web应用中需要同名的Action,Struts2以命名空间的方式来管理Action,同一个命名空间不能有同名的Action。
Struts2通过为包指定namespace属性来为包下面的所有Action指定共同的命名空间。
把上示例的配置改为如下形式:
<!DOCTYPEstrutsPUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<!-- struts2action必须放在一个指定的包空间下定义-->
<packagename="qiujy"extends="struts-default">
<!--定义处理请求URLlogin.actionAction -->
<actionname="login"class="org.qiujy.web.struts2.action.LoginAction">
<!--定义处理结果字符串和资源之间的映射关系-->
<resultname="success">/success.jsp</result>
<resultname="error">/error.jsp</result>
</action>
</package>
<packagename="my"extends="struts-default"namespace="/manage">
<!--定义处理请求URLlogin.actionAction -->
<actionname="backLogin"class="org.qiujy.web.struts2.action.LoginAction">
<!--定义处理结果字符串和资源之间的映射关系-->
<resultname="success">/success.jsp</result>
<resultname="error">/error.jsp</result>
</action>
</package></struts>
如上配置了两个包:default和my,配置my包时指定了该包的命名空间为/manage。
对于包default:没有指定namespace属性。如果某个包没有指定namespace属性,即该包使用默认的命名空间,默认的命名空间总是""。
对于包my:指定了命名空间/manage,则该包下所有的Action处理的URL应该是“命名空间/Action名”。如上名为backLogin的Action,它处理的URL为:
http://localhost:8080/userlogin_struts2/manage/backLogin.action
Struts2的命名空间的作用等同于struts1里模块的作用。
1.3.包含配置:
在Struts2中可以将一个配置文件分解成多个配置文件,那么我们必须在struts.xml中包含其他配置文件。
<struts>
<includefile="struts-default.xml"/>
<includefile="struts-user.xml"/>
<includefile="struts-book.xml"/>
<includefile="struts-shoppingCart.xml"/>
......
</struts>
1.4.拦截器配置:
见后面章节介绍。
1.5.常量配置:
Struts2框架有两个核心配置文件,其中struts.xml文件主要负责管理应用中的Action映射, 及Action处理结果和物理资源之间的映射关系。除此之外,Struts2框架还包含了一个struts.properties文件,该文件主义了Struts2框架的大量常量属性。但通常推荐也是在struts.xml文件中来配置这些常量属性。
如:后面会讲到Struts2的国际化,它的资源文件位置就用常量属性来指定:
<struts>
......
<constantname="struts.custom.i18n.resources"value="messages"/>
</struts>
表示指定了资源文件的放置在classes目录下,基本名是messages,则在classes目录下您就应该放置类似messages_zh_CN.properties,message_en.properties名的文件。
2.Struts2的Action
2.1.实现Action类:
Struts2中Action是核心内容,它包含了对用户请求的处理逻辑,我们也称Action为业务控制器。
Struts2中的Action采用了低侵入式的设计,Struts2不要求Action类继承任何的Struts2的基类或实现Struts2接口。(但是,我们为了方便实现Action,大多数情况下都会继承com.opensymphony.xwork2.ActionSupport类,并重写此类里的public String execute() throws Exception方法。因为此类中实现了很多的实用接口,提供了很多默认方法,这些默认方法包括获取国际化信息的方法、数据校验的方法、默认的处理用户请求的方法等,这样可以大大的简化Action的开发。)
Struts2中通常直接使用Action来封装HTTP请求参数,因此,Action类里还应该包含与请求参数对应的属性,并且为属性提供对应的getter和setter方法。(当然,Action类中还可以封装处理结果,把处理结果信息当作一属性,提供对应的getter和setter方法)
修改第一部分的用户登录示例:把Action改成如下:
packageorg.qiujy.web.struts2.action;
importcom.opensymphony.xwork2.ActionSupport;
/**
*@authorqiujy
*@version1.0
*/
publicclassLoginActionextendsActionSupport{
privateStringuserName;
privateStringpassword;
privateStringmsg;//结果信息属性
/**
*@returnthemsg
*/
publicString getMsg() {
returnmsg;
}
/**
*@parammsgthemsgtoset
*/
publicvoidsetMsg(String msg) {
this.msg= msg;
}
/**
*@returntheuserName
*/
publicString getUserName() {
returnuserName;
}
/**
*@paramuserNametheuserNametoset
*/
publicvoidsetUserName(String userName) {
this.userName= userName;
}
/**
*@returnthepassword
*/
publicString getPassword() {
returnpassword;
}
/**
*@parampasswordthepasswordtoset
*/
publicvoidsetPassword(String password) {
this.password= password;
}
/**
*处理用户请求的excute()方法
*@return结果导航字符串
*@throwsException
*/
publicString execute()throwsException{
if("test".equals(this.userName) &&
"test".equals(this.password)){
msg="登录成功,欢迎"+this.userName;
returnthis.SUCCESS;
}else{
msg="登录失败,用户名或密码错";
returnthis.ERROR;
}
}
}
往success.jsp和error.jsp页面中添加 ${msg}EL表达式来显示结果信息。则最终效果跟以前一样。
2.2.Action访问Servlet API
Struts2中的Action并没有和任何Servlet API耦合,这样框架更具灵活性,更易测试。
但是,对于web应用的控制器而言,不访问Servlet API几乎是不可能的,例如跟踪HTTP Session状态等。Struts2框架提供了一种更轻松的方式来访问Servlet API。Struts2中提供了一个ActionContext类(当前Action的上下文对象),通过这个类可以访问Servlet API。下面是该类中提供的几个常用方法:
lpublic static ActionContext getContext() :获得当前Action的ActionContext实例。
lpublic Object get(Object key) :此方法类似于调用HttpServletRequest的getAttribute(String name)方法。
lpublic void put(Object key, Object value) :此方法类似于调用HttpServletRequest 的setAttribute(String name, Object o)。
lpublic Map getParameters() :获取所有的请求参数。类似于调用HttpServletRequest对象的getParameterMap() 方法。
lpublic Map getSession() :返回一个Map对象,该Map对象模拟了HttpSession实例。
lpublic void setSession(Map session) : 直接传入一个Map实例,将该Map实例里的key-value对转换成session的属性名-属性值对。
lpublic Map getApplication() :返回一个Map对象,该对象模拟了该应用的ServletContext实例。
lpublic void setApplication(Map application) :直接传入一个Map实例,将该Map实例里的key-value对转换成application的属性名-属性值对。
修改以上用户登录验证示例的Action类中的execute方法:
publicString execute()throwsException{
if("test".equals(this.userName) &&"test".equals(this.password)){
msg="登录成功,欢迎"+this.userName;
//获取ActionContext实例,通过它来访问Servlet API
ActionContext context = ActionContext.getContext();
//session中是否已经存放了用户名,如果存放了:说明已经登录了;
//否则说明是第一次登录成功
if(null!= context.getSession().get("uName")){
msg=this.userName+":你已经登录过了!!!";
}else{
context.getSession().put("uName",this.userName);
}
returnthis.SUCCESS;
}else{
msg="登录失败,用户名或密码错";
returnthis.ERROR;
}
}
Struts2中通过ActionContext来访问Servlet API,让Action彻底从Servlet API 中分离出来,最大的好处就是可以脱离Web容器测试Action。
另外,Struts2中还提供了一个ServletActionContext类,Action只要继承自该类,就可以直接访问Servlet API。具体方法参看struts2的API文档。
3.一个Action内包含多个请求处理方法的处理
Struts1提供了DispatchAction,从而允许一个Action内包含多个请求处理方法。Struts2也提供了类似的功能。处理方式主要有以下三种方式:
3.1.动态方法调用:
DMI:Dynamic Method Invocation 动态方法调用。
动态方法调用是指:表单元素的action不直接等于某个Action的名字,而是以如下形式来指定对应的动作名:
<form method="post"action="userOpt!login.action">
则用户的请求将提交到名为”userOpt”的Action实例,Action实例将调用名为”login”方法来处理请求。同时login方法的签名也是跟execute()一样,即为public String login() throws Exception。
注意:要使用动态方法调用,必须设置Struts2允许动态方法调用,通过设置struts.enable.DynamicMethodInvocation常量来完成,该常量属性的默认值是true。
3.1.1.示例:
修改用户登录验证示例,多增加一个注册用户功能。
1.修改Action类:
packageorg.qiujy.web.struts2.action;
importcom.opensymphony.xwork2.ActionContext;
importcom.opensymphony.xwork2.ActionSupport;
/**
*@authorqiujy
*@version1.0
*/
publicclassLoginActionextendsActionSupport{
privateStringuserName;
privateStringpassword;
privateStringmsg;//结果信息属性
/**
*@returnthemsg
*/
publicString getMsg() {
returnmsg;
}
/**
*@parammsgthemsgtoset
*/
publicvoidsetMsg(String msg) {
this.msg= msg;
}
/**
*@returntheuserName
*/
publicString getUserName() {
returnuserName;
}
/**
*@paramuserNametheuserNametoset
*/
publicvoidsetUserName(String userName) {
this.userName= userName;
}
/**
*@returnthepassword
*/
publicString getPassword() {
returnpassword;
}
/**
*@parampasswordthepasswordtoset
*/
publicvoidsetPassword(String password) {
this.password= password;
}
/**
*处理用户请求的login()方法
*@return结果导航字符串
*@throwsException
*/
publicString login()throwsException{
if("test".equals(this.userName) &&"test".equals(this.password)){
msg="登录成功,欢迎"+this.userName;
//获取ActionContext实例,通过它来访问Servlet API
ActionContext context = ActionContext.getContext();
//session中是否已经存放了用户名,如果存放了:说明已经登录了;
//否则说明是第一次登录成功
if(null!= context.getSession().get("uName")){
msg=this.userName+":你已经登录过了!!!";
}else{
context.getSession().put("uName",this.userName);
}
returnthis.SUCCESS;
}else{
msg="登录失败,用户名或密码错";
returnthis.ERROR;
}
}
publicString regist()throwsException{
//将用户名,密码添加到数据库中
//...
msg="注册成功。";
returnthis.SUCCESS;
}
}
2.struts.xml文件:没有什么变化,跟以前一样配置
<!DOCTYPEstrutsPUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<packagename="my"extends="struts-default"namespace="/manage">
<!--定义处理请求URLlogin.actionAction -->
<actionname="userOpt"class="org.qiujy.web.struts2.action.LoginAction">
<!--定义处理结果字符串和资源之间的映射关系-->
<resultname="success">/success.jsp</result>
<resultname="error">/error.jsp</result>
</action>
</package>
</struts>
3.页面:
index.jsp
<%@pagelanguage="java"pageEncoding="UTF-8"%>
<html>
<head>
<title>用户登录页面</title>
</head>
<body>
<h2>用户入口</h2>
<hr>
<formaction="manage/userOpt!login.action"method="post">
<tableborder="1">
<tr>
<td>用户名:</td>
<td><inputtype="text"name="userName"/></td>
</tr>
<tr>
<td>密码:</td>
<td><inputtype="password"name="password"/></td>
</tr>
<tr>
<tdcolspan="2">
<inputtype="submit"value="确定"/>
</td>
</tr>
</table>
</form>
</body>
</html>
regist.jsp
<%@pagelanguage="java"pageEncoding="UTF-8"%>
<html>
<head>
<title>用户注册页面</title>
</head>
<body>
<h2>用户注册</h2>
<hr>
<formaction="manage/userOpt!regist.action"method="post">
<tableborder="1">
<tr>
<td>用户名:</td>
<td><inputtype="text"name="userName"/></td>
</tr>
<tr>
<td>密码:</td>
<td><inputtype="password"name="password"/></td>
</tr>
<tr>
<tdcolspan="2">
<inputtype="submit"value="注册"/>
</td>
</tr>
</table>
</form>
</body>
</html>
4.运行结果:
3.2.Action配置method属性:
将Action类中的每一个处理方法都定义成一个逻辑Action方法。
<!DOCTYPEstrutsPUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<packagename="my"extends="struts-default"namespace="/manage">
<actionname="userLogin"class="org.qiujy.web.struts2.action.LoginAction"method="login">
<resultname="success">/success.jsp</result>
<resultname="error">/error.jsp</result>
</action>
<actionname="userRegist"class="org.qiujy.web.struts2.action.LoginAction"method="regist">
<resultname="success">/success.jsp</result>
<resultname="error">/error.jsp</result>
</action>
</package>
</struts>
如上,把LoginAction中的login和regist方法都配置成逻辑Action。要调用login方法,则相应的把index.jsp中表单元素的action设置为"manage/userLogin.action";要调用regist方法,把regist.jsp中表单元素的action设置为"manage/userRegist.action"。
3.3.使用通配符映射(wildcard mappings)方式:
在struts.xml文件中配置<action…>元素时,它的name、class、method属性都可支持通配符,这种通配符的方式是另一种形式的动态方法调用。
当我们使用通配符定义Action的name属性时,相当于用一个元素action定义了多个逻辑Action:
<actionname="user_*"
class="org.qiujy.web.struts2.action.UserAction"method="{1}">
<resultname="success">/success.jsp</result>
<resultname="error">/error.jsp</result>
</action>
如上,<action name=”user_*”>定义一系列请求URL是user_*.action模式的逻辑Action。同时method属性值为一个表达式{1},表示它的值是name属性值中第一个*的值。例如:用户请求URL为user_login.action时,将调用到UserAction类的login方法;用户请求URL为user_regist.action时,将调用到UserAction类的regist方法。
4.处理结果
Struts2的Action处理完用户请求后,将返回一个普通字符串,整个普通字符串就是一个逻辑视图名。Struts2通过配置逻辑视图名和物理视图资源之间的映射关系,一旦系统收到Action返回的某个逻辑视图名,系统就会把对应的物理视图资源呈现给浏览者。
4.1.配置处理结果:
Struts2的Action处理用户请求结束后,返回一个普通字符串-逻辑视图名,必须在struts.xml文件中完成逻辑视图和物理视图资源的映射,才可让系统转到实际的视图资源。
Struts2通过在struts.xml文件中使用<result …/>元素来配置结果。Struts2提供了两种结果。
l局部结果:将<result …/>作为<action …>元素的子元素配置。
l全局结果:将<result …/>作为<global-results …>元素的子元素配置。
在package元素中配置<global-results>子元素:
<global-results>
<result name="error">/Error.jsp</result>
<result name="invalid.token">/Error.jsp</result>
<result name="login" type="redirect-action">Logon!input</result>
</global-results>
4.2.处理结果类型:
Struts2提供了对不同种类返回结果的支持,常见的有JSP,FreeMarker,Velocity等。
Struts2支持的不同类型的返回结果为:
名字
说明
chain
用来处理Action链
dispatcher
用来转向页面,通常处理JSP,这是默认的结果类型
freeMarker
处理FreeMarker模板
httpHeader
用来控制特殊的Http行为
redirect
重定向到一个URL
redirect-action
重定向到一个Action
stream
向浏览器发送InputSream对象,通常用来处理文件下载
velocity
处理Velocity模板
xslt
处理XML/XLST模板
plaintext
显示原始文件内容,例如文件源代码
tiles
结合Tile使用
另外第三方的Result类型还包括JasperReports Plugin,专门用来处理JasperReport类型的报表输出;Jfreechart Plugin;JSF Plugin。
4.3.动态返回结果
有些时候,只有当Action执行完毕的时候我们才知道要返回哪个结果,这个时候我们可以在Action内部定义一个属性,这个属性用来存储Action执行完毕之后的result值,例如:
private String nextAction;
public String getNextAction() {
return nextAction;
}
在strutx.xml配置文件中,我们可以使用${nextAction}来引用到Action中的属性,通过${nextAction}表示的内容来动态的返回结果,例如:
<action name="fragment" class="FragmentAction">
<result name="next" type="redirect-action">${nextAction}</result>
</action>
上述Action的execute方法返回next的时候,还需要根据nextAction的属性来判断具体定位到哪个Action。
5.属性驱动和模型驱动
不管属性驱动还是模型驱动,Struts2框架都是通过拦截器负责提取请求参数,并将请求数据封装到相应的Action实例的属性或专门的模型的属性。
5.1.属性驱动:
属性驱动就是属性(property)作为贯穿MVC流程的信息携带者。简单的说,就是使用Action实例来封装请求参数和处理结果信息。前面我们做的示例都属于属性驱动模式。
5.2.模型驱动:
模型驱动就是使用单独的javaBean作为贯穿整个MVC流程的信息携带者。也就是说,使用单独的VO(值对象)来封装请求参数和处理结果信息。
示例:继续修改用户登录验证:
1.新增一用户域模型对象:User.java
packageorg.qiujy.domain;
publicclassUser {
privateStringuserName;
privateStringpassword;
/**
*@returntheuserName
*/
publicString getUserName() {
returnuserName;
}
/**
*@paramuserNametheuserNametoset
*/
publicvoidsetUserName(String userName) {
this.userName= userName;
}
/**
*@returnthepassword
*/
publicString getPassword() {
returnpassword;
}
/**
*@parampasswordthepasswordtoset
*/
publicvoidsetPassword(String password) {
this.password= password;
}
}
2.业务控制器:UserAction.java
packageorg.qiujy.web.struts2.action;
importorg.qiujy.domain.User;
importcom.opensymphony.xwork2.ActionContext;
importcom.opensymphony.xwork2.ActionSupport;
publicclassUserActionextendsActionSupport{
//定义用于封装请求参数的模型对象
privateUseruser=newUser();
privateStringmsg;//结果信息属性
/**
*@returntheuser
*/
publicUser getUser() {
returnuser;
}
/**
*@paramusertheusertoset
*/
publicvoidsetUser(User user) {
this.user= user;
}
/**
*@returnthemsg
*/
publicString getMsg() {
returnmsg;
}
/**
*@parammsgthemsgtoset
*/
publicvoidsetMsg(String msg) {
this.msg= msg;
}
/**
*处理用户请求的login()方法
*@return结果导航字符串
*@throwsException
*/
publicString login()throwsException{
String userName =user.getUserName();
String password =user.getPassword();
if("test".equals(userName) &&"test".equals(password)){
msg="登录成功,欢迎"+ userName;
//获取ActionContext实例,通过它来访问Servlet API
ActionContext context = ActionContext.getContext();
//session中是否已经存放了用户名,如果存放了:说明已经登录了;否则说明是第一次登录成功
if(null!= context.getSession().get("uName")){
msg= userName +":你已经登录过了!!!";
}else{
context.getSession().put("uName", userName);
}
returnthis.SUCCESS;
}else{
msg="登录失败,用户名或密码错";
returnthis.ERROR;
}
}
publicString regist()throwsException{
//将用户名,密码添加到数据库中
//...
msg="注册成功。";
returnthis.SUCCESS;
}
}
3.配置文件:struts.xml
<!DOCTYPEstrutsPUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<packagename="my"extends="struts-default"namespace="/manage">
<actionname="userOpt"class="org.qiujy.web.struts2.action.UserAction">
<resultname="success">/success.jsp</result>
<resultname="error">/error.jsp</result>
</action>
</package>
</struts>
4.页面:
index.jsp
<%@pagelanguage="java"pageEncoding="UTF-8"%>
<html>
<head>
<title>
分享到:
评论

相关推荐

    深入 struts2

    深入Struts2框架,我们需要了解其核心组件和配置机制。Struts2是一个基于MVC(Model-View-Controller)架构的Java web开发框架,它简化了创建和维护大型web应用的过程。本文将探讨Struts2的配置文件、Action、请求...

    深入Struts2的配置文件

    ### 深入Struts2的配置文件:详解struts.xml的配置机制 #### 一、包配置(Package Configuration) 在Struts2框架中,**包配置**是管理Action和其他核心组件的重要方式之一。通过使用包,我们可以组织Action、拦截...

    深入Struts2文档

    深入理解Struts2的核心概念和配置对于开发高效、可维护的web应用至关重要。 1. **配置文件**:Struts2的配置主要集中在`struts.xml`文件中,这是整个框架的配置中心。它定义了Action、拦截器和其他关键元素,使得...

    深入Struts2配置

    在深入理解Struts2配置时,我们首先需要了解其核心组件,包括Action和拦截器(Interceptor)。Action是业务逻辑的载体,而拦截器则是执行特定任务的中间层,比如日志记录、权限验证等。Struts2通过包(package)来...

    第四章 深入Struts2--4.1源码

    深入理解Struts2的源码,有助于我们更好地利用这个框架,解决实际开发中的问题,提升效率。在《Struts2权威指南》的第四章中,我们将探讨Struts2的4.1版本源码,以揭示其内部的工作原理和核心机制。 1. **...

    Struts2 技术内幕——深入解析Struts2架构设计与实现原理.pdf

    《Struts2技术内幕:深入解析Struts2架构设计与实现原理》以Struts2的源代码为依托,通过对Struts2的源代码的全面剖析深入探讨了Struts2的架构设计、实现原理、设计理念与设计哲学,对从宏观上和微观上去了解Struts2...

    Struts2 技术内幕-深入解析Struts2架构设计与实现原理

    《Struts2技术内幕:深入解析Struts2架构设计与实现原理》以Struts2的源代码为依托,通过对Struts2的源代码的全面剖析深入探讨了Struts2的架构设计、实现原理、设计理念与设计哲学,对从宏观上和微观上去了解Struts2...

    [Struts 2权威指南--基于WebWork核心的MVC开发(高清完整版) 1/12

    第1章 Struts 2概述,第2章 Struts 2下的HelloWorld,第3章 Struts 2基础,第4章 深入Struts 2,第5章 Struts 2的类型转换,第6章 文件的上传和下载.,第7章 Struts 2的拦截器,第8章 Struts 2的输入校验,9.2 ...

    深入浅出Struts2.pdf

    总之,“深入浅出Struts2”这份资料全面讲解了Struts2的各个关键组成部分,包括其工作原理、配置方式、拦截器机制、OGNL表达式、插件使用以及与Spring的整合,是学习和掌握Struts2框架的宝贵资源。通过深入学习和...

    Struts2+技术内幕——深入解析Struts2架构设计与实现原理

    本书《Struts2技术内幕——深入解析Struts2架构设计与实现原理》结合提供的《struts2基础.chm》资料,为我们提供了深入理解Struts2内部机制的机会。 首先,Struts2的核心在于它的拦截器(Interceptor)机制。拦截器...

    struts2 技术内幕——深入解析struts2架构设计

    《Struts2技术内幕:深入解析Struts2架构设计与实现原理》由国内极为资深的Struts2技术专家(网名:downpour)亲自执笔,iteye兼CSDN产品总监范凯(网名:robbin)以及51CTO等技术社区鼎力推荐。  本书以Struts2的...

    Struts2 技术内幕——深入解析Struts2架构设计与实现原理

    要深入学习和掌握Struts2,建议阅读官方文档,参与实际项目实践,也可以参考相关的技术书籍和教程,例如《Struts2技术内幕——深入解析Struts2架构设计与实现原理》等资源,来提升对Struts2框架的全面理解。

    struts2深入详解源码1-5章

    本资料包包含的是《Struts2深入详解》一书的源码分析,涵盖了从第一章到第五章的内容,并附带了相关的jar包,方便读者结合理论与实践进行学习。 首先,让我们从第一章开始,Struts2的基础知识。这一章通常会介绍...

    深入浅出Struts2 包含了源码

    这本书《深入浅出Struts2》旨在帮助读者深入理解Struts2的核心概念、工作原理以及实践技巧。 Struts2框架的主要特点包括: 1. **灵活的配置**:Struts2允许开发者通过XML或注解进行配置,提供了一种灵活的方式来...

    struts2 学习ppt

    2. **010_Struts2.1_0200_introduction.pptx** - 这部分可能深入Struts2的介绍,包含: - **Struts2核心概念**:介绍Action、Result、配置文件(struts.xml)等核心概念。 - **Struts2工作流程**:展示一个请求从...

    Struts2入门教材

    Struts2是一个强大的Java web应用程序框架,用于构建和管理MVC(模型-视图-控制器)架构的应用程序。...无论是chm格式的文件还是pdf文件,都将为学习者提供详尽的教程和实例,引导他们逐步深入Struts2的世界。

    深入浅出Struts2源代码

    这本书"深入浅出Struts2源代码"是针对该框架源码的深度解析,旨在帮助读者理解Struts2的工作原理,提升开发技能。 Struts2的核心组件包括: 1. **FilterDispatcher**:这是Struts2的入口点,它是一个Servlet ...

Global site tag (gtag.js) - Google Analytics