`
hexiaodong
  • 浏览: 65203 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

我为什么不用struts

阅读更多

在我眼里,struts还有几个关键的缺点,所以我用了3-5个项目后就不用了。

主要的缺点有这么些:

1、输入输出变量范围定义不清晰。在一个action中,所有输入输出变量都是作为对象变量存在的,既无法区分某个变量是属于哪个方法的,也不能区分哪个变量是输入变量还是输出变量。有人说,我每个请求都用单独的action来处理不就行了。这个办法的确可以区分每个请求之间的输入输出,但是你会面临action数量急剧膨胀的问题。

     输入输出变量定义不清晰的带来的问题是代码可读性比较差。使用struts的时候,极端情况下,你得把jsp+action+js结合起来看才能确定某个请求有哪些输入输出。这对项目的维护者来说实在是件很痛苦的事情。

 

2、struts在处理ajax请求的时候太不方便了,虽然你可以配置一个插件让strus具备返回json result的功能。但是目前的插件距离我的实际需要还是有差距的。主要的问题在于,struts现有的json插件不能定义java对象序列化到json对象时的映射策略。就拿User对象来说吧,假如我目前设计的是订单界面,订单又引用了User对象作为订单的制单人属性。那么在序列化Order对象到前端的时候,我只需要序列化User对象的id,name就够了,user对象的其他属性可以统统不要。但我如果在维护用户的模块中,显示用户列表的时候,通常要显示用户对象的大部分属性。因此java对象到json对象的序列化策略应该是运行时动态设定的,不可能用annotation来申明。但struts以及struts插件并没有提供运行时根据请求为某个类选择不同映射策略的功能。

 

struts2,学习成本不可谓不高,功能不可谓不强大,但不符合我的需求。

 

学习strus2,假如不花个把月时间静下心来学习和实践,估计没人敢说自己精通strus2了。但mvc真的有必要那么复杂么?

 

mvc是什么?他应该能干什么?他的核心价值在哪?最小的mvc应该包含哪些功能?我们自己写一个mvc如何?自己写一个mvc框架需要超过一个月时间么?

分享到:
评论
18 楼 yin_bp 2011-04-15  
lookdd1 写道
LZ你提的第二个缺点我要开始蛋疼了。。这算哪门子缺点。。。去看看springside 里面的那个Struts2Utils类。。。这么点事还写这么一大段文字。。

我用过struts2 。。对于一些新手,用struts2很容易搞成一个个巨大的类,而且struts2的拦截器太灵活,又太过复杂,整了太多乱七八糟的概念,效率上也存在一些问题。


我也用过spring mvc2 。这个感觉比纯servlet没有提升多少。。相对还比较原始,应该是和struts1一个年代的玩意。mvc3没用过。。

我还是喜欢线程安全的controller一些。。。更加灵活和无所顾忌。。。

最最好用的一定当之无愧的算play!framework的controller+template,上面这些都是浮云。。谁要是能仿照play的CONTROLLER抛开play自己的那套玩意,抽取出它的MVC+template。那一定是个很好的可以用于企业应用的MVC框架。


用用bbossgroups吧,说不定能给你一个惊喜,目前的发布的最新版本是3.0,即将发布3.1版本,3.1版本集struts2和spring mvc 3.0的优势于一身,提供丰富的demo应用,不可小觑啊,相关的信息请参考新闻:
http://www.iteye.com/news/20177-bbossmvc-bbossaop
17 楼 jerry1985 2011-04-15  
用jsf吧
16 楼 evanzzy 2011-04-15  
Spring MVC3 性能比Struts2要高1倍以上,使用也方便,推荐用Spring MVC3
15 楼 do77 2011-04-15  
lookdd1 写道
LZ你提的第二个缺点我要开始蛋疼了。。这算哪门子缺点。。。去看看springside 里面的那个Struts2Utils类。。。这么点事还写这么一大段文字。。

我用过struts2 。。对于一些新手,用struts2很容易搞成一个个巨大的类,而且struts2的拦截器太灵活,又太过复杂,整了太多乱七八糟的概念,效率上也存在一些问题。


我也用过spring mvc2 。这个感觉比纯servlet没有提升多少。。相对还比较原始,应该是和struts1一个年代的玩意。mvc3没用过。。

我还是喜欢线程安全的controller一些。。。更加灵活和无所顾忌。。。

最最好用的一定当之无愧的算play!framework的controller+template,上面这些都是浮云。。谁要是能仿照play的CONTROLLER抛开play自己的那套玩意,抽取出它的MVC+template。那一定是个很好的可以用于企业应用的MVC框架。



建议这位用一下Spring MVC 3,跟其他MVC框架绝对不是在一个等级上的。

支持一下Spring MVC 3
14 楼 zwllxs 2011-04-15  
楼主对struts2太有偏见。本人从08年初到现在一直研究和使用struts2,爱死struts2,对我封装架构上,提供了巨大的灵活性和可扩展性,struts2不是把mvc复杂化了,而是更加更加简单化和灵活化,同时功能也大大的强大化,你以为你用struts1的mvc好用?我最开始用的是struts1,只感觉恶心死了
13 楼 mtnt2008 2011-04-15  

楼主既然后自己的主张,坚持就好了
12 楼 skzr.org 2011-04-15  
<p>
</p>
<h1 id="A.2BkAli6Q-Spring" style="font-family: sans-serif; font-size: 16px;">选择Spring</h1>
<span style="font-family: sans-serif; font-size: 16px;"></span>
<ul style="font-family: sans-serif;">
<li style="font-size: 16px;">项目技术体系:HTML+JSP+REST+MVC+JDBC</li>
<li>
<span style="color: #ff0000; font-size: large;">看好spring mvc的速度+spring生态环境的欣欣向荣</span><span style="font-size: small;"></span>
</li>
<li style="font-size: 16px;">Spring生态:从安全到各种服务集成具有天生的优势</li>
<li style="font-size: 16px;">Spring对REST的支持</li>
<li style="font-size: 16px;">MVC测试:<ol type="1">
<li>tomcat maxThread=10;使用ab -n 10000 -c 20 测试一个helloworld control!</li>
<li>spring3 mvc访问jsp速度高达5、6K/s</li>
<li>spring3 mvc采用freemarker速度高达5、6K/s</li>
<li>struts2(关闭log,关闭开发模式) mvc最高还达不到2K/s</li>
</ol>
</li>
</ul>
11 楼 linvar 2011-04-15  
"struts2,学习成本不可谓不高,功能不可谓不强大,但不符合我的需求。
学习strus2,假如不花个把月时间静下心来学习和实践,估计没人敢说自己精通strus2了。但mvc真的有必要那么复杂么?
mvc是什么?他应该能干什么?他的核心价值在哪?最小的mvc应该包含哪些功能?我们自己写一个mvc如何?自己写一个mvc框架需要超过一个月时间么?
"----在理
用springmvc的顶_一_下
10 楼 lookdd1 2011-04-15  
LZ你提的第二个缺点我要开始蛋疼了。。这算哪门子缺点。。。去看看springside 里面的那个Struts2Utils类。。。这么点事还写这么一大段文字。。

我用过struts2 。。对于一些新手,用struts2很容易搞成一个个巨大的类,而且struts2的拦截器太灵活,又太过复杂,整了太多乱七八糟的概念,效率上也存在一些问题。


我也用过spring mvc2 。这个感觉比纯servlet没有提升多少。。相对还比较原始,应该是和struts1一个年代的玩意。mvc3没用过。。

我还是喜欢线程安全的controller一些。。。更加灵活和无所顾忌。。。

最最好用的一定当之无愧的算play!framework的controller+template,上面这些都是浮云。。谁要是能仿照play的CONTROLLER抛开play自己的那套玩意,抽取出它的MVC+template。那一定是个很好的可以用于企业应用的MVC框架。
9 楼 firefly.li 2011-04-15  
struts2不行,lz可以退回去用struts1嘛
8 楼 bewithme 2011-04-15  
不知道不用strut的兄弟都用些什么?
7 楼 icanfly 2011-04-15  
我还是比较支持springMVC 3.0
6 楼 zmx198768 2011-04-15  
才能确定某个请求有哪些输入输出。

这个完全可以通过你的编码习惯跟编码注释来进行控制。
5 楼 zmx198768 2011-04-15  
第二点我说一下
你完全可以在对应的bean中写一个toJsonObject的方法来实现,
比如 propertyToJson、keyDateToJson 这一类方法,在你需要的时候调用对应的方法返回json。
4 楼 wendal 2011-04-15  
不如试试 Nutz
3 楼 liukai 2011-04-15  
抬个板凳等打架~
2 楼 lauo 2011-04-15  
只用jsp的飘过!
1 楼 george 2011-04-15  
你说的两个问题,可以归纳为:
1:Struts2 的Action是有状态的,存在成员变量;
2:Struts2 不能很好地支持json/xml甚至jpg等格式的输出;


你这两个问题,可以使用Spring MVC 3 来解决,但是如果使用Spring MVC 3,又引入一个致命的问题:Spring MVC 3 使用annotation可以把藏在任意层次的类映射到一个url上,这样,如果项目管理人员无法强制约束组员的命名风格和包路径存放规范,会造成到看到一个url,到处去找其对应的控制器类的问题。
使用struts2-convention-plugin 就不会有这个问题,因为它是使用约定的,你不按照约定来存放和命名action,你的url根本就无法访问,程序也运行不起来。

另外,Struts2所使用的模型驱动还有一个问题:当你的页面输入框内输入的数据类型,和实体类定义的数据类型不一致时(比如实体类A字段类型为Integer,而页面上为该字段输入了aaa),提交页面,Struts2既不报错,也不能执行,程序根本就不会进入Struts2的方法(使用struts2-convention-plugin 时),这是一个大问题。

但是和Spring MVC 3 的包路径无约束造成的项目混乱相比,Struts2的种种缺点我还是忍受了。

所以综合上述,我还是选择了Struts2

相关推荐

    struts2 最新版 不用去官网上下载了

    Struts2是一个非常知名的Java Web开发框架,由Apache软件基金会维护。它基于MVC(Model-View-Controller)设计模式,极大地简化了Java Web应用程序的开发过程,提供了强大的功能和可扩展性。在标题和描述中提到的...

    Struts2+jQuery(不用JSON)实现局部刷新

    - **jQuery的AJAX请求**:使用jQuery的$.ajax()方法,设置URL为Struts2的Action路径,成功回调函数内解析响应内容并更新DOM。 5. **示例代码**: - Struts2 Action代码可能如下: ```java public class ...

    struts2.0.11 jar 包

    - `xwork-2.0.4.jar`:XWork是Struts2的基础,提供了动作处理、类型转换、数据绑定等基础功能,为Struts2提供了强大的业务逻辑处理能力。 4. **OGNL(Object-Graph Navigation Language)**: - `ognl-2.6.11.jar...

    struts2配置2.5版

    可设置为本地【xml输入语法快捷提示】,就不用远程获取了:window--&gt;preference--&gt;输入Catalog--&gt;xml下的Catalog--&gt;Add--&gt;location:解压缩struts-core-2.5.16.jar 后,文件struts-2.5.dtd文件路径。 ...

    Struts2-2.3.16 全jar包

    例如你建一Web Project,名为Struts2 导入项目所需要的jar包,放入/Struts2/WebRoot/WEB-INF/lib下面 方法一: 在struts2存放目录(以我的举例说明) F:\JavaWeb教程\ssh-jar\struts-2.2.3.16-all\struts-2.2.3.16\...

    struts试题

    在 Struts.xml 文件中,有一个名为 `reload` 的常量,可以实现不用重新启动服务就可以得到反馈。 4. Package 的作用: 在 Struts2 中,Package 用于组织 Action。Package 可以为空,如果为空,则表示该包为默认...

    javaweb-struts2

    9. **国际化与本地化**:Struts2内置了对多语言的支持,开发者可以轻松地为应用程序添加不同语言的资源文件,实现内容的国际化。 10. **插件体系**:Struts2拥有丰富的插件库,如Struts2-dojo-plugin用于AJAX支持,...

    struts-2.3.20-lib.zip

    Struts 2是Java Web开发领域中一个广泛应用的...通过使用Struts 2,开发者可以更加专注于业务逻辑,而不用过多关注底层的HTTP处理和页面渲染。对于企业级应用来说,选择Struts 2.3.20可以带来高效、稳定的开发体验。

    Struts2+Spring+Hibernate和Struts2+Spring+Ibatis

    Struts2+Spring+Hibernate和Struts2+Spring+Ibatis是两种常见的Java Web应用程序集成框架,它们分别基于ORM框架Hibernate和轻量级数据访问框架Ibatis。这两种框架结合Spring,旨在提供一个强大的、可扩展的、易于...

    struts1和struts2的增删改查

    Struts2还支持动态方法调用,这意味着可以不用为每个CRUD操作创建单独的Action方法,而是在一个Action中使用通用的方法,通过参数决定执行哪个操作。此外,拦截器可以实现通用的功能,如权限检查、日志记录等,使得...

    struts框架的最简单应用,懂的就不用下了

    在Struts框架中,配置文件(通常为struts-config.xml或struts2的struts.xml)是非常重要的。这个配置文件定义了Action类与URL的映射,以及视图的跳转规则。压缩包可能包含了一个简单的配置示例,用于演示如何设置...

    struts2图书馆管理系统

    总的来说,这个"struts2图书馆管理系统"项目为初学者提供了一个了解和实践Struts2框架的机会,尽管它可能存在一些功能上的局限,但通过这个项目,学习者可以深入理解MVC架构,掌握Struts2的核心概念,并初步接触Web...

    Struts2 JDBC 增删改查

    项目中主键是通过sequence来自增的,这意味着数据库(如Oracle、PostgreSQL等支持序列的数据库)会自动为新记录生成唯一ID。在JDBC中,通常需要调用序列的nextval()函数来获取这个ID,然后插入到对应字段。 此外,...

    struts2 资料struts2 资料struts2 资料struts2 资料

    9. **技术选型**:《开源技术选型手册.pdf》可能包含关于为什么选择Struts2作为开发框架的讨论,对比其他框架的优势,以及在不同场景下的适用性。 10. **中文文档**:《starting-struts2-chinese.pdf》是Struts2的...

    Struts2jar包及dtd文件

    它的核心是基于MVC(Model-View-Controller)设计模式的,为开发者提供了丰富的功能和灵活性,使得开发者可以专注于业务逻辑,而不用过于关心底层的实现细节。 首先,我们来了解"jar包"。在Java开发中,jar(Java ...

    struts1总结

    Struts1是一个经典的Java Web开发框架,由Apache软件基金会维护,它主要负责处理MVC(Model-View-Controller)架构中的Controller部分。本篇文章将深入探讨Struts1的核心概念、工作原理及其在实际开发中的应用。 一...

    Struts2漏洞检查工具2017版

    采用scanner读数据流,再也不用担心s16不能执行net user/ipconfig/netstat -an等命令了。 增加复杂数据包(multipart/form-data)提交方式进行漏洞利用,可绕过部分防护。可执行命令,暂时无法上传文件。 2014-11-12...

    在struts2中使用freemarker模版

    在`struts.xml`配置文件中,定义一个action,比如`test`,并指定其结果类型为`freemarker`,这样当用户触发这个action时,Struts2会将控制权交给FreeMarker模板来渲染视图。例如: ```xml ...

    struts-2.5.12

    总之,Struts 2.5.12是一个功能强大且成熟的Web框架,它的设计理念和特性使得开发人员能够更专注于业务逻辑,而不用过于关心底层的实现细节。通过理解并熟练运用这些知识点,开发者可以构建出高效、可维护的Java Web...

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

    不用多说了,Struts 2权威指南--基于WebWork核心的MVC开发(高清完整版),解压出来有200多M,因为权限不怎么够,我一共分了12卷,是一本不可多得的好书。第一卷附目录: 第1章 Struts 2概述,第2章 Struts 2下的Hello...

Global site tag (gtag.js) - Google Analytics