JavaEE与Spring
在Java社区中,Spring与Java EE之争是个永恒的话题。在这场争论中,来自两个阵营的布道师、架构师与铁杆粉丝都在不遗余力地捍卫着本方的尊严,并试图说服对方加入到自己的阵营当中,但结果却是双方都很难说服对方,每一方都有充分的理由表明自己的选择是正确的。参与到这场争论的有一些架构师,他们负责着平台的选择。那么对于普通开发者来说该如何思考这场旷日持久的Spring与Java EE之争呢?
Siva是一位充满激情的Java开发者、开源布道师、知名博主,擅长Java、Struts、hibernate、Spring等各项技术与框架。Siva既使用过Spring,也使用过Java EE,但他既不是Spring的铁杆粉丝,也不是Java EE的忠实追求者。相反,他对于Spring与Java EE有着自己的理解和认识,并且在项目当中会根据具体需求选择适合的技术。近日,Siva分享了他对于Spring与Java EE的一些认识和理解,希望能对各位读者起到帮助作用。
业务方面
在很多组织中,技术选择并不完全是由开发者决定的。具体来说,如果你工作在一家大型的企业组织中,那么极有可能会有一个专门的架构师团队负责决定在项目中该使用什么平台、框架与库。除此之外,大型企业在选择技术平台时还会考虑如下几个方面:
- 平台、语言、框架与库的成熟度
- 商业支持
- 许可费用等
作为一名开发者,你可能无法影响上述几方面的决策制定过程,特别是对于那些处于离岸开发中心的开发者来说更是如此。因此,对于开发者来说,你可能无需过多关注于上述几个方面。
如果你非常熟悉Spring,那么掌握Java EE也不是什么难事,反之亦然。
我非常奇怪有人会说他是个Java EE专家,但却无法理解Spring,反之亦然。无论Java EE还是Spring都使用了同样的核心APIs(Servlet、JPA、JMS、BeanValidation等),差别在于到底是什么将这些东西粘合到了一起,是Spring还是应用服务器。
虽然对于依赖注入(Spring DI、CDI)、REST(JAX-RS、SpringMVC)等存在着不同的APIs,但他们彼此之间的行为却是非常类似的。可能有人会说CDI在类型安全上要比Spring DI更好,比如说:
- 如果只有一个Spring/CDI Bean,那么使用@Autowired或是@Inject都是没问题的。
- 如果有两个Spring或CDI Bean实现,那么注入就会失败并抛出错误,说“找到了多个可注入的对象”。
- 使用@Produces或@Bean注解的方法可以实现自定义的Bean提供器。
只要二者行为类似,那么我就不关心谁的实现是更加类型安全的,谁在内部实现中采用了基于String的映射。我想说的是,怎么可能有人是Spring专家但却无法理解Java EE呢,反之亦然。一个Spring专家要花多长时间才能掌握Java EE呢?
Spring与Java EE哪一个对开发者更加友好呢?
我认为到现在为止,很多开发者应该能够认识到一项技术的成功与否其实并不完全取决于自身的优缺点,还要取决于开发者的使用率。我们要认识的重要一点是:“并不是每一个软件开发者都是明星开发者,还有很多处于中等水平的开发者”。为了让人们能够使用某一个框架或技术,框架或技术本身要贴合这一部分人的需求。我觉得Spring在这方面做得非常好,它提供了诸如Spring Boot、用户指南等工具帮助开发者上手。Spring Security、Spring Integration、Spring XD、Spring Social等项目都很好地解决了业务的需求。此外,Spring还提供了各种各样的模板,让人们能够轻松上手开发而无需编写大量的样板代码。
Java EE也通过JBoss Forge、Wildfly Swarm等工具帮助开发者上手。除了Picketlink之外,我几乎看不到有哪些Java EE框架提供了安全解决方案;但即便是Picketlink,我觉得也过于复杂了。我想表达的观点是“Spring能做到的事情,Java EE基本上也都能做”。区别在于哪一个会为普通开发者提供开箱即用的支持。
缺乏上下文的争论
当Spring阵营与Java EE阵营的人开始争论时,注定是没有终点的。但遗憾的是,争论很多时候都围绕着毫无意义或是过时的点上面,比如说下面这些:
大量使用XML
Java EE粉丝一开始就会说Spring大量使用了XML,我憎恶XML之类的。如果你还在使用Spring 2.5以下的版本,然后就认为Spring中充斥着大量的XML,那么我想说你醒醒吧,到http://spring.io看看。
EJB与JSF都是垃圾
Spring粉丝会猛烈抨击EJB与JSF,就好像他们还是EJB 2.x或JSF 1.x那样。如果仔细看看EJB 3.x与JSF 2.x,那么他们就不会有这个想法了。不要拿6年前EJB2.x的老眼光看待现在的EJB 3.x。
重量级与轻量级
这里的“重量级”指的是运行时情况。在将托管Beans部署到Java EE容器中时,容器会为其生成代理并注入所有的企业服务(事务、安全等),对于Spring来说,则是通过Spring AOP来实现的。这里其实没有办法判定哪一种方式更加重量级,容器代理呢,还是Spring AOP代理,不过我觉得二者之间的差别并不太大。有些人会将部署的war包大小作为判断是否“重量级”的一个依据。在这种情况下,Java EE应用服务器 + war与Spring App + 126 jar之间的差别倒是很明显。
厂商锁定
我认为选择平台时可以不依赖于某个特定的厂商是很重要的,不过纯粹基于可以迁移到另外一个实现这一理由来选择平台也是不恰当的。可以想想,你有多少机会会从一个服务器迁移到另外一个服务器?选择一个平台时不必锁定到某个厂商是个“锦上添花”的行为,但绝不应该将其作为关键因素。
我们不需要外部程序库
这就是所谓的“为了争论而争论”。给我看看有哪个应用不需要其他依赖?如果你说你要开发自己的日志库,编写自己的HTTP客户端、开发自己的通用库,那么我只能说这样的开发者也算是奇葩了,放着现成的不用,还要“重新发明轮子”。
你现在使用的是X,你应该迁移到Y
我发现很多社区站点都存在这样的观点,特别是在Reddit。当有人发出关于Java EE与Spring的帖子时,就会有两拨人参与进来,猛烈抨击对方,原因就是对方没有使用自己钟爱的平台。先想一想,如果Spring是垃圾,那怎么还会有那么多人使用并喜欢它呢。如果Java EE不好,那为何还会有人从Spring迁移到Java EE上呢。每个平台都有长处。你要做的就是尊重他人。如果可能,问一下他们为何要选择这个平台,是不是有你不知道的理由在里面呢?
作为一名热情的Java开发者,我真心希望在关于Java EE与Spring之间的争论中能找到我之前不了解的东西,比如说“在哪些情况下,Spring要比Java EE更合适;在哪些情况下,Java EE要比Spring更好”。我希望Spring与Java EE更够形成良性竞争,让自身变得越来越好。这样,无论谁最终赢得了竞争,受益的还是广大开发者们,因为他们拥有了更为强大的平台。原文地址是:http://www.infoq.com/cn/news/2015/07/spring-javaee
JavaEE与Spring的更多相关文章
- JavaEE 之 Spring Data JPA
1.事务 a.事务的关键属性(ACID) ①原子性(atomicity):事务的原子性确保动作要么全部完成,要么完全不起作用 ②一致性(consistency):一旦所有事务动作完成,事务就被提交.也 ...
- JavaEE 之 Spring(一)
1.Spring a.作用:降低组件与组件之间的关联,便于系统的维护和拓展 b.核心思想: ①IOC:控制反转——配置文件依赖注入 ②AOP:面向切面编程 2.IOC/DI a.建配置文件 <? ...
- JavaEE 之 Spring(三)
1.Spring Web MVC a.定义:是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web框架,即使用了MVC架构模式的思想,将web层进行职责解耦,基于请求驱动指的就是 ...
- [JavaEE] IBM - Spring 系列: Spring 框架简介
Spring AOP 和 IOC 容器入门 在这由三部分组成的介绍 Spring 框架的系列文章的第一期中,将开始学习如何用 Spring 技术构建轻量级的.强壮的 J2EE 应用程序.develop ...
- JavaEE高级-Spring Data学习笔记
Spring Data概述 - Spring Data : Spring 的一个子项目.用于简化数据库访问,支持NoSQL 和 关系数据存储.其主要目标是使数据库的访问变得方便快捷. - Spring ...
- JavaEE高级-Spring学习笔记
*Spring是什么? - Spring是一个开源框架 - Spring为简化企业级应用开发而生.使用Spring可以使简单的JavaBean实现以前只有EJB才能实现的功能 - Spring是一个I ...
- 关于JavaEE中Spring模块的学习!
七大模块,如下: 1. Spring Core: Core封装包是框架的最基础部分,提供IOC和依赖注入特性.这里的基础概念是BeanFactory,它提供对Factory模式的经典实现来消除对程序性 ...
- JavaEE 之 Spring Data JPA(二)
1.JPQL a.定义:Java持久化查询语言(JPQL)是一种可移植的查询语言,旨在以面向对象表达式语言的表达式,将SQL语法和简单查询语义绑定在一起·使用这种语言编写的查询是可移植的,可以被编译成 ...
- JavaEE 之 Spring(二)
1.AOP(面向切面编程) a.定义:AOP将分散在系统中的功能块放到一个地方——切面 b.重要术语: ①切面(Aspect):就是你要实现的交叉功能---共通业务处理可以被切入到多个目标对象.并且多 ...
随机推荐
- Needle in a haystack: efficient storage of billions of photos 【转】
转自09年的blog,因为facebook在国内无法访问,故此摘录. The Photos application is one of Facebook’s most popular features ...
- 构建更好的HashMap
在7月份的那期 Java理论与实践(“并发集合类”)中,我们简单地回顾了可伸缩性的瓶颈,并讨论了怎么用共享数据结构的方法获得更高的并发性和吞吐量.有时候学习的最好方法是分析专家的成果,所以这个月我们将 ...
- 微信工作汇报系统2——IOS原型设计
上一篇博客:一款自动汇报工作的微信机器人 上一篇博客中说道,我打算自己做一款能自动汇报工作的微信机器人,可惜学识有限,最后不知道怎么实现让机器人学习我的文本说话,所以就一直耽搁了,见天又打开这个系列, ...
- Java Servlet Filter
做web开发的人对于Filter应该不会陌生,一直在很简单的使用,但是一直没有系统的总结一下,随着年纪的慢慢长大,喜欢总结一些事情,下面说说我对Filter的理解,官方给出的Filter的定义是在请求 ...
- Docker 创建image
images 是containers的基础.每次使用docker run 命令都要指定image. 列出本地images zane@zane-V:~$ docker images REPO ...
- IOError: No translation files found for default language zh-cn.
IOError: No translation files found for default language zh-cn. 检查 ...\Lib\site-packages\Django-1.1 ...
- cordova热更新插件调试
有更新www目录内容后,首先sencha app build,然后进入 cordova目录 运行 cordova-hcp build, 然后查看 chcp.json文件时间,然后压缩cordova目录 ...
- mac复制文件命令
test1下有test01 test02两个文件 ,复制到test2下 则cp -r test1/ test2 权限不够,,则加sudo test2要事先存在, 如果复制test01到当前目录 cp ...
- java wait(),notify(),notifyAll()的理解
这个三个函数来自Object类,众所周知它们是用于多线程同步的.然而,有个问题却一直没搞清楚,即notify()函数到底通知谁?<Thinking in JAVA>中有这么一句话,当not ...
- 转:代码管理技巧——两步创建本地SVN服务器图文教程
from: http://www.cnblogs.com/tianhonghui/archive/2012/07/22/2603454.html 当我们进行开发的时候,不论是独立开发还是处在团队中 ...