J2EE整体架构
来源:互联网 发布:广数g75编程实列 编辑:程序博客网 时间:2024/05/16 23:47
J2EE基础部分视频已经看完了,脑海中对这个J2EE有了一个比较模糊的轮廓,下面是我这几天看视频对J2EE的一些认识,由于根本谈不上理解,所以写这些不是为了给别人一个指导,而是把自己目前所认识的程度记下来,为了给以后深入的理解做一个参照,大家看完一笑而过就好,或者留下点痕迹那就更好了。
J2EE是一个平台,也可以称作一个技术架构,说白了就是一解决问题的方法。一个新事物出现是有它必然的理由的,而J2EE就是为解决日益复杂的需求而生的,它有很多好处,比如:可伸缩性、灵活性、易维护性,还有简化且规范应用系统的开发与部署,进而提高可移植性、安全与再用价值等等等等,诸多的好处,但是没有亲身体会过,也就不知道它到底好在哪里,就好像对着没吃过酸梅的人说梅挺酸的,他当然是不会有反应的,但这个甜头相信迟早会尝到的。
有了J2EE这个平台后,就会出现关于这个平台的一系列规范、开发方式和现成的组件等。先从J2EE的宏观入手,好比看一个人先看整体一样,J2EE采用经典的MVC架构,也就是多层分布式应用模式,只要做过项目的人,都会明白这种架构的好处,而J2EE将这种模式继续发扬光大。架构图如下:
从图中可以看出浏览器和JSP充当的是视图,也就是View;Servlet是控制器(C层),EJB或Java类做模型。
模型,是业务数据(状态)和服务(行为)的表示,JDBC和EJB提供访问数据的机制;也就是说Model层是实现系统中的业务逻辑和数据处理,写到这里我有一个强烈的感觉,就是J2EE中的M是指三层中的Model、BLL、DAL的合体,因为从它的作用上来看,它确实充当了这么一个角色。但大家好像并不这么认为,这只能靠以后用敲代码做项目去理解了。
JDBC:相当于ODBC,是为了以统一方式访问不同数据库的API,这样就为程序员省下了很大的力气,不用去关心底层用的是哪家的数据库系统,只需调用JDBC的API就可以了。
EJB:这又是一个技术规范,并不是一个产品,它分为:Entity Bean,域模型对象,和数据库中表记录形成映射关系;SessionBean,用于实现业务逻辑,一般通过Entity Bean实现数据库访问。MessageDriven Bean,它基于JMS消息,只能接收客户端发送的JMS消息然后处理,实际上是一个异步的无状态Session Bean,这适合于需要异步处理请求的场合,比如订单处理,这样就能避免客户端长时间的等待一个方法调用直到返回结果。
控制器,就好像媒婆一样,负责给M和V牵线搭桥。作为一个合格的媒婆就得认识很多单身的姑娘(以下比喻为View)和小伙子(以下比喻为Model),当姑娘(View)对媒婆提出心中喜欢小伙子(Model)的要求后,媒婆就得从认识的小伙子中挑选,找到最接近姑娘心思的那个,并且被选中的小伙子还要努力的改造自己,让自己完全符合目标,最后由媒婆引荐给姑娘。
从上图中可以看出,这个媒婆是由Servlet充当的,用专业术语来描述:Servlet是提供基于协议的请求/相应服务的Java类,用来处理各种Request和Response。
视图:包含JSP和HTML等,HTML主要是在浏览器中把Model传来的数据变成可视化的,而JSP为添加动态内容提供了多种机制,弥补了HTML的缺陷。
其实J2EE不止可以分为三层,可以分为四层甚至更多,如下图就是四层架构:
比较三层和四层这两种分法,三层更多是从逻辑出发,而四层考虑更多的是物理方面的需求,分法不同,道理其实是一样的。
知道了大体的架构,就该是组织方式了,sun公司就引入了一个叫JavaBean的东西,我把它叫 “咖啡豆”,它有点类似于微软平台上的com组件,功能上也和com组件差不多,可以重复利用、且独立于平台,如百度百科所举的例子:一个购物车程序,要实现购物车中添加一件商品这样的功能,就可以写一个购物车操作的JavaBean,建立一个public的AddItem成员方法,前台Jsp文件里面直接调用这个方法来实现。如果后来又考虑添加商品的时候需要判断库存是否有货物,没有货物不得购买,在这个时候我们就可以直接修改JavaBean的AddItem方法,加入处理语句来实现,这样就完全不用修改前台jsp程序了。
分布式部署最主要的就是组件之间的调用和通讯,这里用到了两个技术,一个是JDBC,是业务逻辑层调用后端数据库的统一API接口;另一个就是JNDI,是Web层访问业务逻辑层不同的命名和目录服务的统一API接口,命名服务将名称和对象联系起来,使得我们可以用名称访问对象。目录服务是一种命名服务,在这种服务里,对象不但有名称,还有属性。
有了以上这些,J2EE的大概轮廓就算是出来了。
- J2EE整体架构
- 整体架构
- J2EE架构
- Peercast整体架构分析
- Peercast整体架构分析
- Tomat6的整体架构
- 应用整体架构整合
- SSH整体架构记录
- PostgreSQL整体架构
- JVM Specification 整体架构
- ICE的整体架构
- Dialog整体架构详解
- ICE的整体架构
- mmc整体架构
- MVC3 整体架构预览
- ICE的整体架构
- WebRTC整体架构
- jquery整体架构分析
- RMI穿越防火墙
- 使用cacti监测memcache 之安装配置篇
- android恢复出厂设置以及系统升级流程
- 心情
- java 二级联动实现
- J2EE整体架构
- java mail 介绍
- 企业网站设计为什么要采用div+css?
- oracle 常用分页语句
- 什么是AOP?
- Dedecms常用函数解析
- linux中的cp命令总结
- 错误代码:0x800704cf 不能访问网络位置(win7 连不上smb了)
- thrift完整例子