【struts2】struts2简介

Struts2其实并不是一个陌生的Web框架,Struts2是以Webwork的设计思想为核心,吸收了Struts1的优点,因此,可以认为Struts2是Struts1和Webwork结合的产物。

一、MVC简介

Struts2是一个兼容Struts1和WebWork的MVC框架(struts是属于web层的MVC框架),既然,提到了MVC框架,就不得不对MVC框架做一个简单介绍,仅限于简单介绍,如果,想了解更多的MVC的知识可以查看相关的文档,或者找一本Struts1的书籍,相信上面关于MVC的篇幅不会很少。言归正传,其实,Java目前出现的这些框架而言,其最终目的都是为了接触耦合,不论是Spring、Hibernate或MVC框架,目的都是为了接触耦合增加复用。MVC接触的是View和Model间的耦合。

MVC包含三个基础部分:Model、View和Controller,这三个部分以最小的耦合协同工作,以增加程序的可扩展性和可维护性。各个部分的实现技术可以总结如下:

1)Model:JavaBean、EJB的EntityBean

2)View:JSP、Struts的TagLib

3)Controller:Struts的ActionServlet、Action

概括起来MVC的优点主要有一下方面:

1)多个视图可以对应一个模型。按MVC设计模式,一个模型对应多个视图,可以减少代码的复制及代码的维护量,一旦模型发生改变,也易于维护;

2)模型返回的数据与显示逻辑分离。模型数据可以应用任何的显示技术,例如,使用JSP页面、Velocity模板或者直接产生Excel文档等;

3)应用被分隔为三层,降低了各层之间的耦合,提供了应用的可扩展性;

4)控制层的概念也很有效,由于它把不同的模型和不同的视图组合在一起,完成不同的请求。因此,控制层可以说是包含了用户请求权限的概念;

5)MVC更符合软件工程化管理的精神。不同的层各司其职,每一层的组件具有相同的特征,有利于通过工程化和工具化产生管理程序代码;

再普通的java web项目中我们使用servlet来接收前台数据,调用业务层方法对数据进行处理,根据处理结果跳转到相应的页面;其事实际过程就是:客户端发送请求给Tomcat,Tomcat读取web.xml文件找到相应的匹配请求的servlet,之后Tomcat将该servlet返回给客户端,让其进行相应请求的执行。在这个过程中一个请求对应一个servlet,这样在一个项目中我们就要写好多的servlet,太麻烦!

改进一:一个servlet获得所有的请求:URL:/*

如果在一个servlet中获取所有请求的地址,然后在servlet中挨个进行请求处理就太麻烦了,我们可以做以下改进,把每个请求的处理抽取出来放到一个单独的action中去:创建一个类AddUserAction.java,该类中有一个方法:
String execute(request,response):获取数据,调用DAO进行数据的持久化(数据库),返回一个显示执行结果的字符串;

String returnValue="";
String uri=request.getRequestURI();//获取请求的地址
if(uri.equals(request.getContextPath()+"/"+"addUser.do")){

    //实现:将请求提交给AddUserServlet(一个请求对应一个servlet)
    //改进实现:在一个单独的action中进行数据的处理,在这里我们只需调用action中进行相应数据处理的方法
    AddUserAction addUser=new AddUserAction();
    returnValue=addUser.execute(request,response);

}else if(uri.equals(request.getContextPath()+"/"+"*.do")){
    //将请求提交给*Servlet
}else if(){
    ...
}
//页面跳转
request.getRequestDispatcher(returnValue).forward(request,response);

改进二:

所有的请求都发送到一个主控制器,由主控制器将请求进行分发;(struts2)

二、Struts2简介

这里写图片描述

Struts2看似是从Struts1发展而来,但实际上Struts2与Struts1在框架的设计思想上面还是有很大的区别,Struts2是以WebWork的设计思想为核心,为什么Struts2不沿用Struts1的设计思想,毕竟Struts1在目前的企业应用中还是有非常大的市场在的,那么,来看下Struts1的一些缺点吧:

1)支持的表现层技术单一

2)与Servlet API严重耦合,这点可以从Action的Execute的方法声明里面就可以看的出来

3)代码依赖Struts1 API,有侵入性,这点可以从写Action类和FormBean的时候看的出来,Action必须实现Struts的Action类

而Struts2之所以以WebWork的设计思想为其核心,一点就是最近WebWork的上升势头,再就是WebWork没有Struts1上面的那些缺点,更符合MVC的设计思想,也更利于代码的复用。

以上介绍可以看的出,Struts2体系结构与Struts1的体系结构有很大的差别,Struts1是使用ActionServlet做为其中心处理器,Struts2则使用一个拦截器(FilterDispatcher)做为其中心处理器,这样做的一个好处就是将Action类和Servlet API进行了分离。

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类依赖与Servlet API,从其execute的方法签名可看出,execute方法有两个Servlet的参数HttpServletRequest和HttpServletResponse,Struts2则不依赖于Servlet API

4)Struts1依赖于Servlet API这些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进行替换

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值