struts2Word文档格式.docx
- 文档编号:19303972
- 上传时间:2023-01-05
- 格式:DOCX
- 页数:12
- 大小:103.72KB
struts2Word文档格式.docx
《struts2Word文档格式.docx》由会员分享,可在线阅读,更多相关《struts2Word文档格式.docx(12页珍藏版)》请在冰豆网上搜索。
1)支持的表现层技术单一
2)与ServletAPI严重耦合,这点可以从Action的Execute的方法声明里面就可以看的出来
3)代码依赖Struts1API,有侵入性,这点可以从写Action类和FormBean的时候看的出来,Action必须实现Struts的Action类
而Struts2之所以以WebWork的设计思想为其核心,一点就是最近WebWork的上升势头,再就是WebWork没有Struts1上面的那些缺点,更符合MVC的设计思想,也更利于代码的复用。
基于以上介绍可以看的出,Struts2体系结构与Struts1的体系结构有很大的差别,Struts1是使用ActionServlet做为其中心处理器,Struts2则使用一个拦截器(FilterDispatcher)做为其中心处理器,这样做的一个好处就是将Action类和ServletAPI进行了分离。
Struts2的简单处理流程如下:
1)浏览器发送请求
2)中心处理器根据struts.xml文件查找对应的处理请求的Action类
3)WebWork的拦截器链自动对请求应用通用功能,例如:
WorkFlow、Validation等功能
4)如果Struts.xml文件中配置Method参数,则调用Method参数对应的Action类中的Method方法,否则调用通用的Execute方法来处理用户请求
5)将Action类中的对应方法返回的结果响应给浏览器
三、Struts2与Struts1对比
1)Action类的实现方式:
Struts1的Action在实现的时候必须扩展Action类或者Action的子类,Struts2的Action类实现的时候可以不用实现任何类和接口,虽然Struts2中提供一个ActionSupport类,但是,不是必须的。
2)Struts1的Action类是单例模式,必须设计成线程安全的,Struts2则为每一个请求产生一个实例
3)Struts1的Action类依赖与ServletAPI,从其execute的方法签名可看出,execute方法有两个Servlet的参数HttpServletRequest和HttpServletResponse,Struts2则不依赖于ServletAPI
4)Struts1依赖于ServletAPI这些Web元素,因此对Struts1的Action进行测试的时候是很困难的,需要借助与其他的测试工具,Struts2的Action可以象测试其他的一些Model层的Service类一样进行测试
5)Struts1的Action与View通过ActionForm或者其子类进行数据传递,虽然也有LazyValidationForm这样的ActionForm的出现,但是,还是不能象其他层面那样通过一个简单的POJO进行数据传递,而Struts2将这样的奢望变成了现实
6)Struts1绑定了JSTL,为页面的编写带来方便,Struts2整合了ONGL,也可以使用JSTL,因此,Struts2下的表达式语言更加强大
四、Struts2与WebWork对比
Struts2实际上就是WebWork2.3,不过,Struts2还是与WebWork有少许的差别:
1)Struts2不再支持内置IOC容器,改用Spring的IOC容器
2)Struts2对于Webwork的一些Ajax的特性的标签改用Dojo进行替换
(二)Struts2工作流程
Struts2框架本身大致可以分为3个部分:
核心控制器FilterDispatcher、业务控制器Action和用户实现的企业业务逻辑组件。
一、核心控制器FilterDispatcher
核心控制器FilterDispatcher是Struts2框架的基础,包含了框架内部的控制流程和处理机制。
业务控制器Action和业务逻辑组件是需要用户来自己实现的。
用户在开发Action和业务逻辑组件的同时,还需要编写相关的配置文件,供核心控制器FilterDispatcher来使用。
Struts2的工作流程相对于Struts1要简单,与WebWork框架基本相同,所以说Struts2是WebWork的升级版本。
Struts2框架按照模块来划分,可以分为ServletFilters、Struts核心模块、拦截器和用户实现部分。
Struts2框架结构图下图所示。
一个请求在Struts2框架中的处理大概分为以下几个步骤。
1)客户端提交一个(HttpServletRequest)请求。
2)请求被提交到一系列(主要是3层)的过滤器(Filter),如(ActionContextCleanUp、其他过滤器(SiteMesh等)、FilterDispatcher)。
注意:
这里是有顺序的,先ActionContextCleanUp,再其他过滤器(OthterFilters、SiteMesh等),最后到FilterDispatcher。
3)FilterDispatcher是控制器的核心,就是MVC的Struts2实现中控制层(Controller)的核心。
4)FilterDispatcher询问ActionMapper是否需要调用某个Action来处理这个(HttpServletRequest)请求,如果ActionMapper决定需要调用某个Action,FilterDispatcher则把请求的处理交给ActionProxy。
5)ActionProxy通过ConfigurationManager(struts.xml)询问框架的配置文件,找到需要调用的Action类。
例如,用户注册示例将找到UserReg类。
6)ActionProxy创建一个ActionInvocation实例,同时ActionInvocation通过代理模式调用Action。
但在调用之前,ActionInvocation会根据配置加载Action相关的所有Interceptor(拦截器)。
7)一旦Action执行完毕,ActionInvocation负责根据struts.xml中的配置找到对应的返回结果result。
Struts2设计的精巧之处就是使用了Action代理,Action代理可以根据系统的配置,加载一系列的拦截器,由拦截器将HttpServletRequest参数解析出来,传入Action。
同样,Action处理的结果也是通过拦截器传入HttpServletResponse,然后由HttpServletRequest传给用户。
其实,该处理过程是典型的AOP(面向切面编程)的方式。
Struts2处理过程模型如下图所示。
★说明★
拦截器是Struts2框架的核心,通过拦截器,实现了AOP(面向切面编程)。
使用拦截器,可以简化Web开发中的某些应用,例如,权限拦截器可以简化Web应用中的权限检查。
二、业务控制器Action
业务控制器Action是由开发者自己编写实现的,Action类可以是一个简单的Java类,与ServletAPI完全分离。
Action一般都有一个execute()方法,也可以定义其他业务控制方法。
Action的execute()返回一个String类型值,这与Struts1返回的ActionForward相比,简单易懂。
Struts2提供了一个ActionSupport工具类,该类实现了Action接口和validate()方法,一般开发者编写Action可以直接继承ActionSupport类。
编写Action类后,开发者还必须在配置文件中配置Action。
一个Action的配置应该包含下面几个元素:
•该Action的name,即用户请求所指向的URL。
•Action所对应的class元素,对应Action类的位置。
•指定result逻辑名称和实际资源的定位。
Action是业务控制器,在编写Action的时候,尽量避免将业务逻辑放到其中,尽量减少Action与业务逻辑模块或者组件的耦合程度。
三、业务模型组件
业务模型组件可以是实现业务逻辑的模块,可以是EJB、POJO或者JavaBean,在实际开发中,对业务模型组件的区分和定义也是比较模糊的,实际上也超出了Struts2框架的范围。
不同的开发者或者团队,都有自己的方式来实现业务逻辑模块,Struts2框架的目的就是使用Action来调用业务逻辑模块。
实际开发中,可以使用静态工厂获得业务逻辑组件的实例或者使用IoC容器来管理。
Action中不实现任何业务逻辑,只是负责组织调度业务逻辑组件。
调用关系如图所示。
业务控制器Action一般情况下不是直接创建业务逻辑组件实例,而是使用工厂模式或者是从Spring容器中获得业务逻辑组件实例,这样可以提高系统的性能。
四、视图组件
Struts1只能支持JSP作为视图资源,而Struts2的进步之处就是可以使用其他视图技术,如FreeMarker、Velocity等。
通过前面的学习和示例,读者会知道Action的返回结果只是一个简单的字符串,也就是一个逻辑上的视图名称,要与实际视图资源对应,必须通过配置文件来实现。
在struts.xml配置文件中,每一个Aciton定义都有name和class属性,同时还要指定result元素。
result元素指定了逻辑视图名称和实际视图的对应关系。
每个result都有一个type属性,前面介绍的struts.xml中并没有显式指定type值,即使用了默认的type类型:
dispatcher,该结果类型支持JSP所谓视图资源。
总结Strurs2的框架工作流程,与WebWork基本相同,
(三)Struts2简单实例
下面是struts2的helloWorld示例。
建工程,导入struts2包之类的就不多说了,主要说一下代码的构建过程。
一、配置web.xml文件
下面是登陆实例中的完整web.xml文件
<
?
xmlversion="
1.0"
encoding="
UTF-8"
>
web-appid="
WebApp_ID"
version="
2.4"
xmlns="
xmlns:
xsi="
http:
//www.w3.org/2001/XMLSchema-instance"
xsi:
schemaLocation="
<
filter>
<
!
—配置filter-->
filter-name>
struts2<
/filter-name>
filter-class>
org.apache.struts2.dispatcher.FilterDispatcher<
/filter-class>
/filter>
filter-mapping>
<
—拦截所有URL用户请求
url-pattern>
/*<
/url-pattern>
/filter-mapping>
—配置欢迎界面文件-->
welcome-file-list>
welcome-file>
index.html<
/welcome-file>
/welcome-file-list>
/web-app>
二、配置struts.xml文件
下面是登陆实例中的完整struts.xml文件
?
DOCTYPEstrutsPUBLIC
"
-//ApacheSoftwareFoundation//DTDStrutsConfiguration2.0//EN"
//struts.apache.org/dtds/struts-2.0.dtd"
—配置struts2-->
struts>
--配置包,名称为bookcode-->
packagename="
bookcode"
extends='
struts-default'
--配置Action-->
actionname="
HelloWorld"
class="
ch2.helloworld.HelloWorld"
--配置返回结果-->
resultname="
success"
/ch2/helloworld/success.jsp<
/result>
error"
/ch2/helloworld/error.jsp<
/action>
/package>
/struts>
在默认情况下,Struts2将会自动加载位于WEB-INF\classes目录下的struts.xml配置文件。
package>
定义了一个包空间,可以看到,该文件中只配置了一个Action,name为“HelloWorld”,对应的class为“ch2.HelloWorld”,也就是指定WEB-INF\classes\ch2目录下的HelloWorld.class类文件,当然现在还没有这个文件,后面将会编写该文件。
另外一个配置就是result,即Action处理后返回给用户的视图资源,从配置中可以看到配置了两个result:
success和error,分别对应\工程名\ch2目录下的success.jsp和error.jsp,后面也将会建立这两个文件。
这里介绍的HelloWorld的思路是用户在客户端输入一个字符串,由Action判断输入的字符串是否为空,如果不为空,则返回给用户success.jsp页面,并在控制台打印出该字符串;
如果用户输入为空,则返回error.jsp页面给用户,提示输入为空。
这个流程如下图。
用户输入字符串,发送请求给Struts2框架的核心控制器FilterDispatcher,FilterDispatcher根据配置,将请求转发给Action,Action是业务控制器,来判断用户输入的内容进行相应的操作。
HelloWorld的流程图
三、Action业务控制器
HelloWorld应用中的Action是业务控制器。
Struts2的Action可以是一个普通的Java类(POJO),与Struts1有很大的不同,这里的HelloWorld.java内容如代码如下所示。
packagech2.helloworld;
publicclassHelloWorld{
//定义msg属性
privateStringmsg;
//msg的get方法
publicStringgetMsg(){
returnmsg;
}
//msg的set方法
publicvoidsetMsg(Stringmsg){
this.msg=msg;
//Action的execute()处理方法
publicStringexecute(){
//判断条件
if(getMsg().equals("
"
)){
//显示错误信息
System.out.println("
noStringinput!
);
//返回错误结果
return"
;
}else{
//显示用户输入的信息
System.out.println(getMsg());
//返回一个处理成功结果
}
}
四、视图资源
到这里为止,该示例只缺少success.jsp、error.jsp和一个用户输入界面HelloWorld.jsp
1)HelloWorld.jsp
%@pagecontentType="
text/html;
charset=gb2312"
language="
java"
import="
java.sql.*"
errorPage="
%>
DOCTYPEhtmlPUBLIC"
-//W3C//DTDXHTML1.0Transitional//EN"
//www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
htmlxmlns="
//www.w3.org/1999/xhtml"
head>
metahttp-equiv="
Content-Type"
content="
/>
title>
HelloWorld!
/title>
/head>
body>
—form的action指向定义的action名称-->
formid="
form1"
name="
method="
post"
action="
HelloWorld.action"
p>
输入信息:
label>
inputname="
msg"
type="
text"
id="
username"
/label>
/p>
inputtype="
submit"
Submit"
value="
提交"
/form>
/body>
/html>
这里需要注意的一点就是,struts2中,表单提交之后,提交的表单数据不需要通过HttpServletRequest去取了,而是直接通过Action文件中对应字段的set方法来设值,get方法来取值。
该例子中,表单提交后,字段msg的值自动通过HelloWorld.java中的setMsg方法就设置了。
在使用该值的时候,只需要通过getMsg()方法就可以取得了。
2)success.jsp
%@pagelanguage="
contentType="
%>
-//W3C//DTDHTML4.01Transitional//EN"
//www.w3.org/TR/html4/loose.dtd"
html>
charset=ISO-8859-1"
返回界面<
HelloWorld,Struts2!
3)error.jsp
pageEncoding="
gb2312"
错误界面<
您没有输入内容!
这样,一个完整的代码就完成了。
五、小结
初次完成一个Struts2的HelloWorld示例,我们体会到:
•web.xml中需要加入Struts2的加载配置。
•在struts.xml中定义Action,其中包含Action返回视图的定义。
•Struts2的Action是一个简单的Java类,没有
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- struts2
![提示](https://static.bdocx.com/images/bang_tan.gif)