有几个问题,一直没搞清楚,今天问了很多人,懂了一点点,在这里总结一下
问题是:什么是JAVA EE,各种规范的接口的jar包(及源码)怎么获取,各种规范的实现的jar包(及源码)怎么获取
1、什么是JAVA EE
JAVA EE是由一系列规范组成的,规范是由JCP制定的,并且提供了参考实现。规范(Specification)是一系列接口,不包含具体实现
有以下常见的JAVA EE实现,包括JBOSS、GLASSFISH等。而tomcat是一个servlet容器,实现了servlet规范、jsp规范。但是它并没有实现EJB、JMS、JPA等规范,所以tomcat不是一个完整的JAVA EE实现
在oracle网站上,下载JAVA EE SDK时,会同时下载GLASSFISH,也就是同时下载了JAVA EE SDK,及一个JAVA EE的实现
2、怎么获取某个规范的接口的jar包
直觉上,我觉得既然规范是JCP制定的,那它当然也就应该负责提供接口的jar包及源码,比如jsr-914.jar,jsr-914_source.jar
然后实现规范的产商,基于这个jar包开发各自的实现;而规范的使用者,也基于这个jar包调用。这样可以保证接口和实现的分离
不过事实上,好像不是这样的。很多规范的接口jar包,我在www.jcp.org、www.java.net、www.oracle.com上,都找不到下载的链接。
有人说是因为从sun把java卖给oracle之后,oracle关闭了很多项目,所以这些jar包都找不着了,我也不知道是不是这样
总之,我感觉没有一个很方便的途径,可以获取到各种规范的“官方jar包”
不过有2个办法,都可以做到
第一个办法,是可以下载一个相关规范的实现,实现里肯定是有接口jar包的。还是拿jsr-914举例,我下载了2个实现,activemq和jboss
在activemq安装目录的lib目录下,可以找到接口的jar
在jboss安装目录的/modules/javax/jms/api/main目录下,也可以找到
第二个办法,好像更方便一点。eclipse有一个项目叫eclipse orbit,在这个项目里,可以找到大部分的规范接口jar包
以下是官方对此项目的说明:
This project will provide a repository of bundled versions of third party libraries that are approved for use in one or more Eclipse projects. The repository will maintain old versions of such libraries to facilitate rebuilding historical output. It will also clearly indicate the status of the library (i.e., the approved scope of use). The repository will be structured such that the contained bundles are easily obtained and added to a developer's workspace or target platform.
下载后的jar包,放在eclipse安装目录的plugins目录下,名字看起来比较奇怪
通过这2种方式,都可以得到规范的接口jar包,把它们加入到eclipse的工程里看一下:
可以看到3个jar包中的内容基本是一样的,根据javaeye网友canghailan的说法,所有这些jar包,都是经过了JCP认证的,所以都可以直接使用。那我理解这就相当于JCP偷了懒,本来这个jar包应该是由它提供的,但是它没有这么做。而是由各实现提供商来提供这个jar包,JCP只负责认证
3、怎么获取某个规范的接口的jar包的源码
其实搞清楚了上面一个问题,这个问题就很简单了。
orbit项目对每个接口jar包,都提供了相应的源码。所以如果是通过orbit得到jar包,那也就一定能够得到源码
如果是通过下载实现的方式获取到接口jar包,那么如果这个实现是开源的,就能得到相应的源码;如果不是开源的实现,那么就得不到源码了
比如说tomcat是比较方便的,可以直接下载并解压,得到apache-tomcat-7.0.23-src,其中的java目录,就是各种源码
jboss也是开源的,不过没有tomcat那么方便,需要下载以后自己再跑脚本进行编译
不过这里有一点要澄清一下,就是一般来说,开发者是不需要用到接口jar包的源码的
http://java.net/jira/browse/GLASSFISH-11389,这个帖子里说到:
To assist developers to do what?
The corresponding JARs are stripped (no bytecode for methods) and are meant to
be used only for compilation. IDEs like NB or Eclipse bundle a zip for the javadoc.
What other use case do you need to get the src? Debugging? In this case, these
jars are not used for execution so also not for debugging. In the case of
debugging, I think there is a complete GF src somewhere to step into the real
code you execute from the real non stripped gf jars.
接口jar包的源码是移除的,只是用于编译。一般的IDE都有zip文件来提供javadoc。对于需要debug的场景,需要源码的也应该是实现类,而不是接口
http://stackoverflow.com/questions/7457810/how-to-get-the-source-code-for-the-javaxjavaee-api-6-0-jar,这个帖子也表达了类似的意思:
The purpose of the javaee-api module is to satisfy compile-time dependencies (That is why the Maven scope is set to provided). The module contains interface declarations (or contract) which must be satisfied by the J2EE container you plan to use.
If you really need/want to see the source code, I'd suggest taking a look at one of the open source J2EE containers.
接口jar包的主要目的是满足编译时的依赖
所以,一般来说,开发者是不需要用到接口jar包的源码的,无论是为了javadoc或者debug,都不需要。当然,你可以说我就是想看看,那可以用上面说的方法获取到
4、怎么获取某个规范的实现的jar包/源码
搞清楚了上面3个问题,这个问题也就解决了。比如要得到tomcat的servlet实现的jar包,就下载tomcat,在其中的lib目录下就有
然后,如果你选择的实现是开源的,那就再下载一下其源码发布包,就可以得到源码了
5、题外话
在eclipse开发JAVA EE应用,在编译时需要引入所需的jar包,这跟最终的目标容器是有关系的,比如我打算开发一个部署在jboss中的WEB应用,那么eclipse会自动导入jboss-library
如果是打算部署在tomcat里,那么eclipse会导入tomcat-library
可以看到,这2个库是不一样的。但是,这个时候导入的jar包,只是为了满足编译时的需要,这些jar包并不会被打入最后的.war包里(WEB-INF/lib下的才会)。这些Runtime Library,在运行时会从容器的classpath里被找到并加载
理论上来说,开发一个servlet应用,就算开发时选择的是JBoss Runtime Library,但是只引用了接口,没有依赖jboss具体的实现类的话,那么打出的.war包,在运行时扔到tomcat里也是可以跑的。原因前面说过了,双方的servlet-api.jar,都是经过JCP认证的,所以能够保证一致性。但是如果编码时依赖了JBoss提供的实现类,那到tomcat里就绝对跑不了了
但是,如果开发的是完整的JAVA EE应用,比如依赖了JMS、EJB的接口,那扔到tomcat里就不能跑了,还需要额外的JMS中间件的支持,原因上面也说过了,因为tomcat只是一个servlet容器,部分实现了JAVA EE规范,不是一个JAVA EE的完整实现

- 大小: 20.8 KB

- 大小: 49 KB

- 大小: 11.4 KB

- 大小: 33.1 KB

- 大小: 11.9 KB

- 大小: 12.8 KB

- 大小: 12.2 KB

- 大小: 121.4 KB

- 大小: 120.4 KB

- 大小: 61 KB

- 大小: 40.9 KB
分享到:
相关推荐
JavaEE是Java平台标准版(Java SE)的扩展,专为构建企业级Web应用程序而设计。这个"javaee_web"的压缩包很可能包含了与开发JavaEE Web应用相关的库...理解和掌握这些库的使用是成为一名成功的JavaEE开发者的重要步骤。
总而言之,Servlet 3.1规范文档为Java开发者提供了一个详细的技术指南,帮助他们更好地理解和实现Servlet技术,同时也指出了如何通过相关工具和资源来确保实现的标准化。随着Web技术的快速发展,掌握Servlet 3.1规范...
通过这个项目,学生不仅可以学习到如何构建一个完整的信息系统,还能深入理解如何将信息技术应用于实际生活,提升社区服务的质量和效率。同时,该系统的设计与实现也是对计算机网络技术专业学生的一次实战训练,有助...
这一点对于开发者来说是一个巨大的优势,因为它能够减少为不同操作系统编译和维护不同版本代码的工作量。Java由Sun Microsystems公司于1995年发布,并在2009年被甲骨文公司(Oracle)收购,自此成为其旗下产品。 ...
首先,JavaWeb是基于Java技术栈的Web应用程序开发领域,主要涉及到Servlet、JSP(JavaServer Pages)、JSTL(JavaServer Pages Standard Tag Library)以及一系列的Java EE(Enterprise Edition)规范。在本项目中,...
文档中提到了REST实战这本书,这是关于RESTful架构风格的一本实践指南,为Jersey的使用提供了更深层次的理解和实践技巧。 总的来说,Jersey用户指南为开发者提供了一套全面的工具和指导来构建和部署RESTful Web服务...
### 魔乐科技Struts2.x框架笔记详解 #### 一、框架开发基础与特性 **框架开发来源**:框架开发的核心在于反射机制的应用,它...通过对上述知识点的深入理解和掌握,可以帮助开发者更高效地构建高质量的Java Web应用。
Struts2、Hibernate和Spring是Java Web开发中的三大主流框架,它们构成了...总的来说,SSH框架的结合使用,使得Java Web开发更加高效、规范,而理解并掌握这三个框架的核心概念和技术,对于Java EE开发者来说至关重要。