`
nianien
  • 浏览: 17573 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

基于《关于Java开发不明白的一些问题》,探讨一下Struts1和Struts2

阅读更多
在《关于Java开发不明白的一些问题》中提及Struts1和Struts2,

只不过是用来作为讨论解耦的一个例子而已,我没有从整体上评价孰优孰劣

事实上,我也是先接触了Struts2后来才看的Struts1,

看到一些把Struts2拿来膜拜,我觉得自己是不是应该好好反思一下?


凡是做过JavaWeb开发的莫不了解MVC,凡是了解MVC的莫不了解Struts

纵观java世界里的Web框架,无论形式上如何变化,其本质上却是大抵相同的

所有,不要见人就问你懂不懂某某框架啊

懂框架不如懂原理,举一反三的道理人人都懂,却不是人人都能做的到

那么,那么多的框架,本质是什么呢?相同点又在哪里呢?

其实,无论外表搞得多炫,核心还是Servlet驱动的

而驱动的模型无外乎两种:请求响应驱动和事件响应驱动

我知道的,基于事件驱动的框架有Seam,

而基于请求响应驱动的就很多了,如Struts1和2,XWebWork,Spring-MVC等等

脱离了这些框架之后,所有的东西都能有Servlet实现

而Servlet+JSP+JavaBean就是一个无任何框架的开发模式

这里看好了,JavaBean框架无关的,而JSP现在有多有视图模型可以替代

那么,框架的主要功能是什么呢?,就是取代Servlet的逻辑控制作用

在Struts中,取代Servlet的对象就是Action,

下面,我们来看看Struts1和2中Action的角色有什么不同

在MVC框架中,M作为数据承载的对象,是有状态的,

具体讲,就是一个对象有属性,通过方法的调用来改变属性的值,从而达到状态变化

如果M纯粹作为数据载体的话,那么它的状态变化需要外界来驱动

就像一辆车子,车子本身是不能动的,需要由人来驾驶

在String1中,M就是ActionForm,而C就是Action,

通过Action调用方法并将ActionForm作为参数,来改变ActionForm的属性,

从而完成对客户端的响应

这里,Struts1的一个弊端就是这个JavaBean不是框架无关的,而是需要继承框架的一个基类

为了解决这个弊端,到了Struts2,Struts已经完全否定了自己,转投XWebWork的怀抱

我想说的是,这个自我否定,做得有点过火了,因为你从本质上将还是一个Web框架,

我们将耦合与内聚,你把粒度放大,其实耦合不过就是更大粒度的内聚

不是解耦不是为了方便,耦合的越紧效率越高,使用越方便,这就是集成,它的缺点就是不适应变化

那么我就说了,Struts2你再怎么变化就有一点是不需要变化的,

那就是——你究竟不过是个Web框架

我们来看看Struts2的Action,

第一,action本身包含业务逻辑的数据,那么它承担着M的角色

第二,action还能执行方法,改变自身的属性,那么它同时承担这C的角色

所以在Struts2中,action是自驱动的,不需要外界的干涉,便能改变自己的状态

这就像一辆无人驾驶的汽车一样,有些人觉得这很爽,有些人觉得很不爽?为什么呢?

——因为有些人喜欢开车,有些人不喜欢开车!

也就是有些人喜欢自己控制代码的流程,而有些人却想什么都交给框架做



基于以上的比较,我们来看看Struts1和Struts2有关解耦的问题

可以这么说,即使什么框架都不用,纯粹的Servlet+Jsp+Bean都能解耦,

所以没有什么框架不能解构的,如果你觉得不能解耦,那么就是你的代码设计本身有问题?


还是举个例子吧:

有人说,Struts1中action方法里带有Request和Response对象,无法解耦

我想说,至少有两种办法来解耦:

第一,自己创建Request和Response对象对象

这两个对象不过就是个接口声明,你完全可以有的实现,如果使用了适配器模式,那就更方便了

第二,在需要从Request对象获取数据的地方,将变量提升为参数或者属性同样可以解耦


还是一点想说的是,解耦不过是个概念性的东西,主要是为了应对变化,

但是,现在好多人把解耦简单地理解为,我不继承你的类或接口,就是解耦,

这真是匪夷所思!!!!

再举个例子吧,看看所谓的Struts2的解耦~

对于一个数据对象,它就是一个Bean,

这个Bean是框架无关的,它只包含了业务数据,我们可以将它用到各个框架中,

但是在Struts2中,它是一个action,同样包含了业务数据,但是同时包含了业务逻辑

因为它没有继承Struts2的任何接口和类,你认为它是解耦的,

但是当你把它用到其他框架中,有用的只是它的数据,而不是它的处理方法,因为它的处理方法只有Struts2的框架有用

这种解耦的代价就是代码污染,因为一个数据对象到处包含着不能共享的业务逻辑处理方法

把这种情况放在Struts1中,你可能会说它需要继承一个ActionForm类,

不错,的确如此,但是仅仅这一个类,就可以让你免除那么无谓的代码污染

因为这个类属于Struts,你就认为耦合了,如果在JDK中,你就不那么觉得了?

JDK中的类和我们自己编写的类有区别么?除了身份不同罢了~~~~~~~~~


到了这里,也许你会说,我可以对业务数据进行包装,进行从Action到JavaBean的转换,

那么你可以这样,同样Struts1中也可以进行ActionForm到JavaBean的转换,

所以本质上的解耦根本不是由Struts2来提供的,而是在于你的代码设计

发这个帖子的目的,就是想澄清一下Struts2所谓的解耦,不过玩的概念而已

当然你以可以喜欢它,毕竟比Struts1开发更方便

也可不喜欢它,因为它让你更远离技术


在人家玩概念的时候,也许我们更需要明白的是概念表面下所隐藏的实质,

也许这实质不是我说的这样,但是学习不就是一个不断思考的过程么?


PS:

框架自然有它的好处,不然不会有那么多人用它,但是它无形中造成了程序员价值的贬值

个人的愚论:越是底层的知识,有效期就越长;越是上层的东西,依赖性越强~~~~~~~~~~

从更宏观的角度来讲,整天跟着框架跑,奔波于了解和掌握框架的最新特性,

倒不如研究一下框架本身隐藏的技术手段,能够做到以不变应万变

一旦哪天框架的开发者宣布不再维护了,那么,

是否你的学习就到了尽头了呢?还是继续寻找新的替代者?

分享到:
评论
17 楼 nianien 2011-03-11  
紧急下潜 写道
我来说点
1. 我想知道楼主到底有几年开发经验?
   我的初步判断应该不会超过3年
2. 我想知道楼主到底做过多少个项目,从事过的每个项目的人员和代码量有多少?
   其他的我不好说,但是项目代码量我估计不会太大
3. 你之前说自己看过struts 1 2和spring的源码,但是你有没有理解到他们的原理那?
   我的初步判断是楼主没有

如果你知道spring这个框架是怎么诞生的,你就不会如此肤浅了。
再说一次,就冲你之前的那个帖子被评为良好,就看出来了javaeye真的没落的

那些用项目大小和代码量来衡量人的,真的很无语,我最鄙视~~~~~~~
哪一个框架的代码量不比项目的代码量小?但是哪个才是精华?你懂的~
有的人编了一辈子代码,只不过会用几个框架而已
有的人一行代码不写,照样能成为专家
写和读和思考和创造都是有区别的~~~~~~~~
16 楼 nianien 2011-03-11  
peterwei 写道
前面话太多,没有全看完。应该写你言论的重点并标注,没人喜欢看这长篇大论。
引用
在人家玩概念的时候,也许我们更需要明白的是概念表面下所隐藏的实质,
也许这实质不是我说的这样,但是学习不就是一个不断思考的过程么?

这个是赞同的。


引用
框架自然有它的好处,不然不会有那么多人用它,但是它无形中造成了程序员价值的贬值
个人的愚论:越是底层的知识,有效期就越长;越是上层的东西,依赖性越强~~~~~~~~~~

开发者的价值不在于使不使用框架,而在于自身的不断总结和成长,并不仅仅是技术方面。

引用
从更宏观的角度来讲,整天跟着框架跑,奔波于了解和掌握框架的最新特性,
倒不如研究一下框架本身隐藏的技术手段,能够做到以不变应万变
一旦哪天框架的开发者宣布不再维护了,那么,
是否你的学习就到了尽头了呢?还是继续寻找新的替代者?

这个观点是对的。工具和框架只是提高我们开发效率的一种手段。


1.在Struts中,Action是Model层,更准确。
至于你说的什么Struts1中的ActionForm,Struts2中的pojo model是Model是不够精确的;还有Action是Controller是Action也是不精确的。这二者在于我眼里都是大Model,包括Action中调用后台的Service,应该都统归于MVC框架中的广义Model。
2.至于Controller应该是Struts1中的ActionServlet,Struts2中的FilterDispatcher.
3.view是jsp,jstl,freemarker,velocity这些东西。对应struts2就是result返回的东东。

又废话了一堆。哈哈。

至于Controller应该是Struts1中的ActionServlet,Struts2中的FilterDispatcher

这句你说的挺对的,但是这些本来就是Servlet的东西,框架不使用它就无法实现,
action 的出现难道不是为了替代Servlet么?
15 楼 ppgunjack 2011-03-11  
这种框架本身已经把应用按自己的模子给切开了,复用只是在移到同样其他struts项目会有大的意义
另外action本来就是自实现和框架的粘合剂,框架换了粘合剂也就该一起扔
14 楼 peterwei 2011-03-11  
紧急下潜 写道
我来说点
1. 我想知道楼主到底有几年开发经验?
   我的初步判断应该不会超过3年
2. 我想知道楼主到底做过多少个项目,从事过的每个项目的人员和代码量有多少?
   其他的我不好说,但是项目代码量我估计不会太大
3. 你之前说自己看过struts 1 2和spring的源码,但是你有没有理解到他们的原理那?
   我的初步判断是楼主没有

如果你知道spring这个框架是怎么诞生的,你就不会如此肤浅了。
再说一次,就冲你之前的那个帖子被评为良好,就看出来了javaeye真的没落的

老兄,不必过激。每个人都有投票的权利。要是每个钻级的大佬都来评分,这里的贴子就全进新手隐藏贴了。人家权重太大,不忍心下手。
13 楼 peterwei 2011-03-11  
前面话太多,没有全看完。应该写你言论的重点并标注,没人喜欢看这长篇大论。
引用
在人家玩概念的时候,也许我们更需要明白的是概念表面下所隐藏的实质,
也许这实质不是我说的这样,但是学习不就是一个不断思考的过程么?

这个是赞同的。


引用
框架自然有它的好处,不然不会有那么多人用它,但是它无形中造成了程序员价值的贬值
个人的愚论:越是底层的知识,有效期就越长;越是上层的东西,依赖性越强~~~~~~~~~~

开发者的价值不在于使不使用框架,而在于自身的不断总结和成长,并不仅仅是技术方面。

引用
从更宏观的角度来讲,整天跟着框架跑,奔波于了解和掌握框架的最新特性,
倒不如研究一下框架本身隐藏的技术手段,能够做到以不变应万变
一旦哪天框架的开发者宣布不再维护了,那么,
是否你的学习就到了尽头了呢?还是继续寻找新的替代者?

这个观点是对的。工具和框架只是提高我们开发效率的一种手段。


1.在Struts中,Action是Model层,更准确。
至于你说的什么Struts1中的ActionForm,Struts2中的pojo model是Model是不够精确的;还有Action是Controller是Action也是不精确的。这二者在于我眼里都是大Model,包括Action中调用后台的Service,应该都统归于MVC框架中的广义Model。
2.至于Controller应该是Struts1中的ActionServlet,Struts2中的FilterDispatcher.
3.view是jsp,jstl,freemarker,velocity这些东西。对应struts2就是result返回的东东。

又废话了一堆。哈哈。
12 楼 紧急下潜 2011-03-11  
我来说点
1. 我想知道楼主到底有几年开发经验?
   我的初步判断应该不会超过3年
2. 我想知道楼主到底做过多少个项目,从事过的每个项目的人员和代码量有多少?
   其他的我不好说,但是项目代码量我估计不会太大
3. 你之前说自己看过struts 1 2和spring的源码,但是你有没有理解到他们的原理那?
   我的初步判断是楼主没有

如果你知道spring这个框架是怎么诞生的,你就不会如此肤浅了。
再说一次,就冲你之前的那个帖子被评为良好,就看出来了javaeye真的没落的
11 楼 gtssgtss 2011-03-11  
复制别人一句话,再进行攻击的人,水平都值得怀疑,因为这是典型的“断章取义”反模式

看楼上上复制了,楼主没有复制,楼上上上也没有复制,水平立见高下
10 楼 shixueyou521 2011-03-11  
wn_1985 写道
struts/struts2/spring mvc,团队用哪个,你就用哪个就是了
这种框架日经贴,还非要比出个123来.......

+1 框架日经贴,基础非常重要,但是框架的作用不是为了超越基础,而是辅助基础。
9 楼 lqtcts 2011-03-11  
看完楼主的写的表面上振振有词,其实全部在扯淡。MVC理解不到位,解耦思想也不到位,对框架的认识也不到位。
“在String1中,M就是ActionForm,而C就是Action,

我就不知道你读过struts的源码没有,action是控制器?Action是模型?佩服啊!!!
“Servlet+JSP+JavaBean就是一个无任何框架的开发模式


又在说些火星的语言,是Servlet+JSP+JavaBean不是mvc模式么,楼主你在说笑吧?

“如果在JDK中,你就不那么觉得了?

JDK中的类和我们自己编写的类有区别么?除了身份不同罢了~~~~~~~~~


又说些搞笑的的话,JDK有的,你还需要写么?

还有,楼主说自建一个request,response就可以解耦合,真不知道你的脑子里想的啥...
楼主就是一个新手,不想多说,跟你多说你肯定会反驳,


8 楼 finallygo 2011-03-11  
1.在struts1中M就是ActionForm?
模型还包括Service,Dao,还有我们的pojo
actionForm通常都可以用pojo来替代
2.struts是一个web框架,但是你有没有想过为什么struts2要和servlet api解耦合?
我想一个主要的原因就是为了便于测试
(1)你说自己构建Request和Response?
不要忘了,execute方法中传的参数是HttpServletRequest,不管怎么说还是会和servlet api耦合
而且你还需要构建一个ActionMapping
(2)在需要从Request对象获取数据的地方,将变量提升为参数或者属性同样可以解耦?
提升为参数指的是在execute上添加一个参数吗?
execute的参数是固定的,不能改变
提升为一个属性指的是在action上添加一个属性吗?
struts1的action是单例的,你这么做会导致线程不安全
而struts2完全避免了与servlet api的耦合,request,response都转换为了Map,这样你可以很方便的写测试
总之,建议你在写下两个框架的action的测试代码,
你要是能写出一段struts1比struts2方便的测试代码那我就没有什么好说了.
3.Struts2中,它是一个action,同样包含了业务数据,但是同时包含了业务逻辑?
刚才已经说了,业务逻辑是不应该出现在action中的,不管是struts1还是2
4.JDK中的类和我们自己编写的类有区别么?
当然有区别,如果你毫无顾忌的这个类引用那个类,当你想要重用这个类的时候你就会发现是多么麻烦的一件事了


7 楼 Unmi 2011-03-11  
你在 Struts2 中用 ModelDriven 时,它的解耦就不会是个概念问题了。
6 楼 nianien 2011-03-11  
Jazag.van 写道
第二,action还能执行方法,改变自身的属性,那么它同时承担这C的角色

所以在Struts2中,action是自驱动的,不需要外界的干涉,便能改变自己的状态
-----------------------
不理解,不也是请求响应么,没有外界请求怎么改变自己的状态了?


还是举个例子吧:

有人说,Struts1中action方法里带有Request和Response对象,无法解耦

---------------------------
有了Request,Response为什么就会无法解耦了,他们不都是Servlet的对象么?
求解答

自驱动和被驱动的区别就是,还是那汽车做例子,一个是无人遥控汽车,一个是人工驾驶的汽车
在Struts1中,JavaBean作为参数,从其他类调用方法改变状态
在Struts2中,Action本身作为JavaBean,它是自己调用自己的方法
我不明白你怎么不明白呢?
还有,我没有说自驱动和请求响应由什么关系
一个是面对类来说的,一个是面对框架来说的


这里所说的解耦的意思,Action类的定义不需要引用其他非常用的类
有Request和Response对象,你就必须引用Servlet API,这就和Servlet API耦合了
同时方法参数还有ActionForm和ActionForward,这就和框架本身耦合了
5 楼 鼻涕猪 2011-03-11  
引用

越是底层的知识,有效期就越长;越是上层的东西,依赖性越强~~~~~~~~~~

从更宏观的角度来讲,整天跟着框架跑,奔波于了解和掌握框架的最新特性,

倒不如研究一下框架本身隐藏的技术手段,能够做到以不变应万变

一旦哪天框架的开发者宣布不再维护了,那么,

是否你的学习就到了尽头了呢?还是继续寻找新的替代者?


严重赞同...
4 楼 Jazag.van 2011-03-11  
第二,action还能执行方法,改变自身的属性,那么它同时承担这C的角色

所以在Struts2中,action是自驱动的,不需要外界的干涉,便能改变自己的状态
-----------------------
不理解,不也是请求响应么,没有外界请求怎么改变自己的状态了?


还是举个例子吧:

有人说,Struts1中action方法里带有Request和Response对象,无法解耦

---------------------------
有了Request,Response为什么就会无法解耦了,他们不都是Servlet的对象么?
求解答
3 楼 chainhou 2011-03-11  
严重同意楼主,框架是如此之多,生命是如此有限,会举一反三才是硬道理!
2 楼 wn_1985 2011-03-11  
struts/struts2/spring mvc,团队用哪个,你就用哪个就是了
这种框架日经贴,还非要比出个123来.......
1 楼 songry 2011-03-10  
从更宏观的角度来讲,整天跟着框架跑,奔波于了解和掌握框架的最新特性,
倒不如研究一下框架本身隐藏的技术手段,能够做到以不变应万变

非常赞同这个

相关推荐

    精通struts基于mvc的java web设计与开发

    《精通Struts基于MVC的Java Web设计与开发》是一本深入探讨如何使用Struts框架进行Web应用开发的专业书籍。作者孙卫琴以其丰富的经验和深入的理解,为读者提供了全面、系统的Struts MVC学习路径。 首先,我们要理解...

    精通Struts基于MVC的Java Web设计与开发 孙卫琴 光盘

    第4章到第7章深入探讨了Struts框架的核心组件ActionServlet和RequestProcessor的实现原理,详细介绍了开发Struts应用的模型、视图和控制器的各种技术,细致的描述了Struts配置文件的每个元素的使用方法。第8章到第9...

    用案例学Java Web整合开发:Java+Eclipse+Struts 2+Ajax

    Java Web整合开发是构建Web应用程序的关键技术,涵盖了Java语言、Eclipse集成开发环境(IDE)、Struts 2框架以及Ajax异步JavaScript和XML技术。这个主题深入探讨了这些技术如何协同工作,创建出高效、用户友好的Web...

    精通Struts:基于MVC的JavaWeb设计与开发(孙卫琴)

    《精通Struts:基于MVC的JavaWeb设计与开发》是由孙卫琴编著的一本经典书籍,专门探讨了如何使用Struts框架进行高效的JavaWeb应用程序开发。这本书深入浅出地介绍了Struts的核心概念、架构以及实践应用,帮助开发者...

    Java Web 基于Spring Struts Hibernate 轻量级架构开发实例

    Struts1是早期版本,而在本书中提到的是可能基于Struts2,它是Struts1的升级版,提供了更丰富的功能和更灵活的架构。Struts2通过拦截器实现AOP,允许自定义行为,比如验证、异常处理等。它与Spring的集成也更为紧密...

    第3章【源码】java web整合开发实战--基于struts 2+hibernate+spring 贾蓓 镇明敏 杜磊

    在本章"第3章【源码】java web整合开发实战--基于struts 2+hibernate+spring"中,我们将深入探讨如何在Java Web应用程序中集成三个关键的开源框架:Struts 2、Hibernate和Spring。这些框架分别负责控制层、持久层和...

    Struts1和Struts2区别

    Struts1和Struts2是两个非常著名的Java Web框架,它们都由Apache软件基金会开发,用于构建MVC(Model-View-Controller)架构的应用程序。虽然它们在目标上相似,但在设计模式、功能特性和使用体验上存在显著差异。...

    精通 Struts:基于 MVC 的 JavaWeb 设计与开发(PDF)

    第4章到第7章深入探讨了Struts框架的核心组件ActionServlet和RequestProcessor的实现原理,详细介绍了开发Struts应用的模型、视图和控制器的各种技术,细致的描述了Struts配置文件的每个元素的使用方法。第8章到第9...

    java+Struts1和Struts2教程

    本教程将深入探讨Java与Struts1和Struts2框架的集成与应用。 Struts1是Apache软件基金会下的一个开源项目,它是Java EE平台上用于构建Web应用程序的一个框架。它的核心是ActionServlet,它作为控制器协调用户请求与...

    项目实践精解:基于Struts-Spring-Hibernate的Java应用开发

    在Java世界中,Struts、Spring和Hibernate是三个非常重要的框架,它们构成了经典的"SSH"企业级应用开发栈。这个项目实践精解深入探讨了如何使用这三个框架来构建实际的Java应用程序,旨在提升开发者在实际项目中的...

    精通Struts,基于java的web开发和设计

    《精通Struts:基于MVC的Java Web设计与开发》这本书深入探讨了使用Java语言进行Web应用程序开发的核心技术,特别是围绕Struts框架展开。Struts是Apache软件基金会的一个开源项目,它是一个基于Model-View-...

    精通Java EE项目案例--基于Eclipse Spring Struts Hibernate (例子中的初始化SQL)

    在深入探讨Java EE项目开发的过程中,我们经常会遇到各种技术栈的整合使用,比如Eclipse、Spring、Struts和Hibernate这四个关键组件。本资源“精通Java EE项目案例--基于Eclipse Spring Struts Hibernate (例子中的...

    Struts1.x常用的开发包,需要学习struts1.x朋友可以下载

    虽然现在Struts1.x已经被Struts2等更新的框架所取代,但它的基础思想和设计模式仍然是Java Web开发中的重要参考。对于想要了解Web开发历史或深入理解MVC框架的开发者来说,学习Struts1.x仍然具有一定的价值。

    精通Struts基于MVC的Java Web设计与开发

    《精通Struts:基于MVC的Java Web设计与开发》是孙卫琴老师撰写的一本经典书籍,专门针对Java Web开发中的Struts框架进行了深入的探讨。这本书详细讲解了如何利用Struts框架来构建符合MVC(Model-View-Controller)...

    精通struts:基于mvc的java web设计与开发part1

    第4章到第7章深入探讨了Struts框架的核心组件ActionServlet和 RequestProcessor的实现原理,详细介绍了开发Struts应用的模型、视图和控制器的各种技术,细致的描述了Struts配置文件的每个元素的使用方法。...

    基于struts2的当当网项目

    在本文中,我们将深入探讨Struts2框架及其在构建当当网项目中的应用,以及如何通过MyEclipse进行开发。 Struts2是Apache软件基金会下的一个开源Java Web框架,它提供了控制层的解决方案,旨在简化MVC应用程序的开发...

    精通Struts_基于MVC的Java Web设计与开发

    第4章到第7章深入探讨了Struts框架的核心组件ActionServlet和RequestProcessor的实现原理,详细介绍了开发Struts应用的模型、视图和控制器的各种技术,细致的描述了Struts配置文件的每个元素的使用方法。第8章到第9...

    Java Struts2 实现CRUD

    Struts2是Apache软件基金会的开源项目,它是Struts1的升级版,提供了更灵活的架构和更强的控制力。Struts2的核心是Action类,它负责接收请求、处理业务逻辑并返回结果。此外,Struts2还利用拦截器(Interceptor)...

    精通struts:基于mvc的java web设计与开发part2

    第4章到第7章深入探讨了Struts框架的核心组件ActionServlet和 RequestProcessor的实现原理,详细介绍了开发Struts应用的模型、视图和控制器的各种技术,细致的描述了Struts配置文件的每个元素的使用方法。...

    图片上传成功实例java+struts1

    在本文中,我们将深入探讨如何实现一个基于Java和Struts1框架的图片上传功能,结合SWFUpload这一前端上传插件。首先,我们要明白图片上传是Web应用中常见的一种功能,它涉及到前端交互、文件传输协议以及后端处理等...

Global site tag (gtag.js) - Google Analytics