JAVAEE 是什么,如何获取各种规范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的完整实现
JAVAEE 是什么,如何获取各种规范jar包及各种规范的jar包源码的更多相关文章
- Django框架深入了解_01(Django请求生命周期、开发模式、cbv源码分析、restful规范、跨域、drf的安装及源码初识)
一.Django请求生命周期: 前端发出请求到后端,通过Django处理.响应返回给前端相关结果的过程 先进入实现了wsgi协议的web服务器--->进入django中间件--->路由f分 ...
- C# 获取汉字的拼音首字母和全拼(含源码)
C# 获取汉字的拼音首字母 一种是把所有中文字符集合起来组成一个对照表:另一种是依照汉字在Unicode编码表中的排序来确定拼音的首字母.碰到多音字时就以常用的为准(第一种方法中可以自行更改,方法为手 ...
- VS2010 .net4.0 登录QQ 获取QQ空间日志 右键选中直接打开日志 免积分 源码下载
代码有一部分是原来写的 最近翻代码 看到了 就改了一下 CSDN上传源码 上传了几次都没 成功 郁闷 不知道怎么回事 上传不了 想要的留 邮箱 或加群77877965 下载地址在下面 演示地址 ...
- 曹工说Spring Boot源码(25)-- Spring注解扫描的瑞士军刀,ASM + Java Instrumentation,顺便提提Jar包破解
写在前面的话 相关背景及资源: 曹工说Spring Boot源码(1)-- Bean Definition到底是什么,附spring思维导图分享 曹工说Spring Boot源码(2)-- Bean ...
- Flutter源码剖析(一):源码获取与构建
概述 本文介绍了Flutter源码的获取与构建,后面会另有文章介绍Flutter源码的版本管理.开发环境搭建等主题. 准备工作 Flutter源码分为两个部分: flutter/flutter是框架层 ...
- Atitit 项目源码的架构,框架,配置与环境说明模板 规范 标准化
Atitit 项目源码的架构,框架,配置与环境说明模板 规范 标准化 版本1.0 作者 艾龙 attilax 1. 概述:核心业务: 1 1.1. 功能文档路径 /palmWin/src/docum ...
- ReentrantLock获取到非公平锁的源码
/** * Performs lock. Try immediate barge, backing up to normal * acquire on failure. */ final void l ...
- org.reflections 接口通过反射获取实现类源码研究
org.reflections 接口通过反射获取实现类源码研究 版本 org.reflections reflections 0.9.12 Reflections通过扫描classpath,索引元数据 ...
- java使用websocket,并且获取HttpSession,源码分析
转载请在页首注明作者与出处 http://www.cnblogs.com/zhuxiaojie/p/6238826.html 一:本文使用范围 此文不仅仅局限于spring boot,普通的sprin ...
随机推荐
- Spring中通过java的@Valid注解和@ControllerAdvice实现全局异常处理。
通过java原生的@Valid注解和spring的@ControllerAdvice和@ExceptionHandler实现全局异常处理的方法: controller中加入@Valid注解: @Req ...
- [bzoj2091][Poi2010]The Minima Game_动态规划
The Minima Game bzoj-2091 Poi-2010 题目大意:给出N个正整数,AB两个人轮流取数,A先取.每次可以取任意多个数,直到N个数都被取走.每次获得的得分为取的数中的最小值, ...
- Ubuntu 16.04安装QtCharts时报错:'qtConfig' is not a recognized test function.
错误: 'qtConfig' is not a recognized test function. 解决方法: 其实5.9分支的版本有问题,转成5.7分支即可. git clone https://g ...
- PLSQL Developer来实现不同数据库的表结构以及表数据同步
PLSQL Developer菜单条中 Tools选项下有Compare User Objects和Compare Table Data功能. 一.Tools --> compare user ...
- iPhone 3gs 5.0.1降級到4.3.3 昨晚搞定(有shsh備份)
經過昨天白天一天的學習和準備,終於一次降級成功. 手機未降級時狀態: 無鎖港版 3GS 16G 固件:5.0.1 基帶:05.16.05 記錄且分享降級完整步驟: 準備以下軟件.工具 官網固件 ...
- Velocity高速新手教程
变量 (1)变量的定义: #set($name = "hello") 说明:velocity中变量是弱类型的. 当使用#set 指令时,括在双引號中的字面字符串将解析和又 ...
- Redis开源项目的终极杀手? ——CRUG解读Redis开源协议变更
引言: 数据库制造商 Redis Labs 本周将公司开发的Redis 模块从 AGPL 迁移到将 Apache v2.0 与 Commons Clause 相结合的许可证,对许可证涵盖的软件作了限制 ...
- 关于jiffies回绕以及time_after,time_before
系统中有非常多变量用来记录一个单调递增的现实,典型的有两个,一个是TCP的序列号.还有一个就是jiffies,可是由于计算机内表示的数字都是有限无界的,所以不论什么数字都不能做到全然意义的单调递增,它 ...
- android中怎么将桌面较长的图标名称显示完整
找到相应的 res 资源, 改动其 styles.xml <style name="WorkspaceIcon.Portrait"> <item ...
- python3 使用http.server模块 搭建一个简易的http服务器
from http.server import HTTPServer, BaseHTTPRequestHandler import json data = {'result': 'this is a ...