`
isiqi
  • 浏览: 16562468 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

基于J2EE的三层B/S信息系统研究

阅读更多

  随着软件系统的规模和复杂性的增加 ,软件体系结构的选择成为比数据结构和算法的选择更为重要的因素 ,三层客户/服务器体系结构为企业资源规划的整合提供了良好的框架 ,是建立企业级管理信息系统的最佳选择。随着体系结构的发展,软件框架结构方面也在不断发展,目前在多层应用结构方面出现Java技术和.net技术的实现的不同的解决方案,二者各有优缺点,分别适用于不同规模的系统的要求。 本文将结合电信计划建设管理信息系统的实现,说明三层模式的体系结构,介绍基于三层模式的应用系统的分布式组件技术 ,阐述应用J2EE框架结构来实现应用系统的实现方法。

   一、系统结构的选择

   1、 传统两层C/S结构的缺点

  传统的两层客户/服务器模式比较适合于小规模、用户较少、单一数据库且在安全、快速的网络环境下 (例如局域网 )运行 。但是,随着应用系统的规模不断扩大 ,复杂性越来越高在多用户、多数据库且非安全的网络环境下(例如:Internet) ,这种两层结构的应用模型将无法适应 。而且传统的两层结构还存在以下缺陷:

  (1)它是单一服务器且以局域网为中心的 ,所以难以扩展至大型企业广域网或 Intranet;

  (2)受限于供应商,程序的升级维护必须由供应商重新开发扩展;

  (3)软、硬件的组合及集成能力有限;在软件上呈现出胖客户端,用户必须在客户端安装特定的客户端应用程序,而且企业的业务逻辑都写在客户端应用程序中,程序维护困难,程序升级需要每个客户端都要安装新的客户端应用程序,同时,对于程序开发商来说,程序模块的重用性差,各个模块相对独立;

  (4)C/S模式很难管理大量的客户机。

  基于以上原因,传统的C/S模式已经不能适应发展的需要,随着网络技术的普及和用户需求的进一步提高,三层WEB模式应运而生。

  2、 三层WEB结构的优点

  三层客户/服务器模式 (以下简称三层模式 )在两层模式的基础上,增加了新的一级。这种模式在逻辑上将应用功能分为三层:客户显示层、业务逻辑层、数据层。客户显示层是为客户提供应用服务的图形界面,有助于用户理解和高效的定位应用服务。业务逻辑层位于显示层和数据层之间,专门为实现企业的业务逻辑提供了一个明确的层次,在这个层次封装了与系统关联的应用模型,并把用户表示层和数据库代码分开 。这个层次提供客户应用程序和数据服务之间的联系,主要功能是执行应用策略和封装应用模式,并将封装的模式呈现给客户应用程序。数据层是三层模式中最底层,他用来定义、维护、访问和更新数据并管理和满足应用服务对数据的请求。

  三层模式的主要优点为 :

  ①良好的灵活性和可扩展性。对于环境和应用条件经常变动的情况,只要对应用层实施相应的改变,就能够达到目的。

  ②可共享性。单个应用服务器可以为处于不同平台的客户应用程序提供服务,在很大程度上节省了开发时间和资金投入;

  ③较好的安全性。在这种结构中,客户应用程序不能直接访问数据,应用服务器不仅可控制哪些数据被改变和被访问,而且还可控制数据的改变和访问方式 。

  ④增强了企业对象的重复可用性。“企业对象”是指封装了企业逻辑程序代码,能够执行特定功能的对象。随着组件技术的发展,这种可重用的组件模式越来越为软件开发所接受。

  ⑤三层模式成为真正意义上的“瘦客户端”,从而具备了很高的稳定性、延展性和执行校率。

  ⑥三层模式可以将服务集中在一起管理,统一服务于客户端,从而具备了良好的容错能力和负载平衡能力。


三层体系结构


  电信计划建设管理信息系统是由省电信公司对下属地市电信公司进行统一管理,所有业务逻辑都集中在省公司管理和制定,地市公司负责数据的录入和查询统计,用户的分布广泛,数据集中处理,因此在设计时充分考虑各种体系结构的优缺点,选择三层WEB模式进行开发实现。

  二、体系架构的选择

  1、 DCOM分布式技术和CORBA分布式技术

  Microsoft的分布式COM(DCOM)技术是将组建对象模型技术COM大大进行了扩展,是对在局域网、广域网甚至是Internet上计算机对象之间的通信提供了完全的支持。通过使用DCOM用户的应用程序就可以在任何网络位置上达到真正的分布性,从而满足客户应用的需要。整体结构如下图所示:


  由OMG提出的公共对象请求代理结构CORBA对象是目前比较流行的一种中间件规范,也是一种构件实现规范,主要目标是使对象在分布式环境中可重用、可移植和可互操作,CORBA的整体结构如下图所示:


  以上两种分布式结构可以实现在统一特定的环境下的应用,对于局域网中的实现比较流行,但是针对不同平台的应用和Internet上的应用,二者缺少灵活性。

  2、 J2EE体系结构介绍

  J2EE体系结构分为三个层次,分别是客户表示层、中间逻辑层和数据管理层及应用系统。本结构具有跨平台的特性,结构中的三个层次可以处于不同的平台下进行协作应用;因为客户表示层可以使用不同的客户端程序,因此具有很好的分布性,可以适应分布式管理的要求;在后台的应用系统集成中,可以把企业不同的应用系统集成到该结构中,因此可以有效的保护现有的资源不被破坏。基于J2EE来实现的WEB服务的核心框架如下图所示:



  用基于J2EE的体系结构开发的WEB服务还具有以下的优点:

  ① 可以跨越中间防火墙进行通信。因为WEB服务是利用HTTP最为传输媒介,中间层使用WEB服务的话,可以从客户界面直接调用中间层组件,而不必建立页面。

  ② 应用系统的集成。要把企业里不同语言写成的,运行于不同平台上的各种程序集成起来必然会花费很大的开发力量。通过WEB服务可以使用标准的方法把功能和数据暴露出来,供其他程序使用。

  ③ 所有的企业逻辑和服务都集成封装在可重用、可移植的EJB组件中,因此系统维护性和可重用性好。

  ④中间件代码可以集中在处理业务逻辑上,无需考虑数据表示。

  因为本次电信计划建设管理信息系统的业务逻辑和数据处理规则都是由集团公司和省公司统一管理,数据和程序集中在统一的服务器上,并且服务器运行平台与客户端的运行平台不同,因此采用J2EE的框架结构解决比较合适。

  二、体系架构的选择

  1、 DCOM分布式技术和CORBA分布式技术

  Microsoft的分布式COM(DCOM)技术是将组建对象模型技术COM大大进行了扩展,是对在局域网、广域网甚至是Internet上计算机对象之间的通信提供了完全的支持。通过使用DCOM用户的应用程序就可以在任何网络位置上达到真正的分布性,从而满足客户应用的需要。整体结构如下图所示:


  由OMG提出的公共对象请求代理结构CORBA对象是目前比较流行的一种中间件规范,也是一种构件实现规范,主要目标是使对象在分布式环境中可重用、可移植和可互操作,CORBA的整体结构如下图所示:


  以上两种分布式结构可以实现在统一特定的环境下的应用,对于局域网中的实现比较流行,但是针对不同平台的应用和Internet上的应用,二者缺少灵活性。

  2、 J2EE体系结构介绍

  J2EE体系结构分为三个层次,分别是客户表示层、中间逻辑层和数据管理层及应用系统。本结构具有跨平台的特性,结构中的三个层次可以处于不同的平台下进行协作应用;因为客户表示层可以使用不同的客户端程序,因此具有很好的分布性,可以适应分布式管理的要求;在后台的应用系统集成中,可以把企业不同的应用系统集成到该结构中,因此可以有效的保护现有的资源不被破坏。基于J2EE来实现的WEB服务的核心框架如下图所示:



  用基于J2EE的体系结构开发的WEB服务还具有以下的优点:

  ① 可以跨越中间防火墙进行通信。因为WEB服务是利用HTTP最为传输媒介,中间层使用WEB服务的话,可以从客户界面直接调用中间层组件,而不必建立页面。

  ② 应用系统的集成。要把企业里不同语言写成的,运行于不同平台上的各种程序集成起来必然会花费很大的开发力量。通过WEB服务可以使用标准的方法把功能和数据暴露出来,供其他程序使用。

  ③ 所有的企业逻辑和服务都集成封装在可重用、可移植的EJB组件中,因此系统维护性和可重用性好。

  ④中间件代码可以集中在处理业务逻辑上,无需考虑数据表示。

  因为本次电信计划建设管理信息系统的业务逻辑和数据处理规则都是由集团公司和省公司统一管理,数据和程序集中在统一的服务器上,并且服务器运行平台与客户端的运行平台不同,因此采用J2EE的框架结构解决比较合适。

  三、系统设计和实现

  通过对各种解决方案和框架结构的比较,选择JAVA技术作为本次系统设计的应用技术,我们对系统的设计如下:

  前台用户显示层使用jsp和servlet在浏览器上实现,中间使用EJB组件实现企业业务逻辑,后台数据库使用Sybase数据库。具体的企业应用结构如下所示:


  其中中间件使用Bea公司的Weblogic7.0,开发工具使用JBuilder9.0,数据库使用SYBASE数据库。

  在用户登录过程中,因为在整个客户端使用的用户比较多,因此在连接上我们使用连接池进行处理。具体的连接池实现如下:

class DBConnectionPool
{
 public DBConnectionPool(String name, String URL, String user, String password)
 {
  this.name = name;
  this.URL = URL;
  this.user = user;
  this.password = password;
  this.maxConn = maxConn;
 }
 private void createPools(Properties props)
 {
  private Hashtable pools = new Hashtable();
  String poolName = props.getProperty("poolname").trim();
  String url = props.getProperty(poolName+".url").trim();
  String user = props.getProperty(poolName + ".user");
  String password = props.getProperty(poolName + ".password");
  String maxconn = props.getProperty(poolName + ".maxconn", "0");
  int max;
  DBConnectionPool pool=New DBConnectionPool(poolName, url, user, password);
  Utility.log(pool.toString());
  pools.put(poolName, pool);
  Utility.log("成功创建连接池" + poolName);
 }
}

  为了使用SessionBean进行登录确认处理,同时利用Bean的监听功能对用户的登录时间进行监听,超过一定时间,自动切断用户登录连接,让用户进行重新登录。在应用系统中,用户登录后的权限控制是一个重点,我们在使用J2EE框架结构的过程中,使用SERVLET的过滤功能来实现权限的控制,具体的实现结构如下:


  过滤器的定义标记如下:

<web-app>
 <filter>
  <filter-name>IE Filter</filter-name>
  <filter-class>com.ibm.devworks.filters.IEFilter</filter-class>
 </filter>
</web-app〉

  在业务逻辑处理上,我们对各个业务进行相应的分解,然后针对每个业务逻辑应用EJB组件进行实现。客户做出请求后,使用SERVLET处理后调用各个业务模块处理逻辑,EJB组件访问数据库后将处理后的结果集返回给SERVLET,再汇集到客户端进行显示,供用户进行查询和使用。

  四、总结

  本文提出的B/S模式的系统结构已应用电信计划建设管理信息系统中,由于实际需要,在请求处理层中还增加了一个设备接口线程,用于通过SNMP协议获取网络设备的信息。与传统的CGI模式相比,本系统结构有明显的优势,具有较高系统效率,尤其适合于构造功能复杂的Web应用系统。另外在实现上还可以加强,比如进一步研究自动创建和撤销新的数据库操作线程的条件。


分享到:
评论

相关推荐

    基于J2EE的三层B/S企业信息系统 (2005年)

    #### J2EE三层B/S架构的构建方法 J2EE是面向企业级应用开发的Java平台标准,其三层B/S架构主要包括以下几个部分: 1. **表示层**:负责用户界面展示,通常采用HTML、JavaScript等前端技术。 2. **业务逻辑层**:...

    基于J2EE的三层B_S模式第三方物流管理信息系统研究.pdf

    【基于J2EE的三层B/S模式第三方物流管理信息系统研究】 第三方物流管理信息系统在现代商业环境中扮演着至关重要的角色,它能提升物流企业的服务质量,降低成本,优化运营效率。本文主要探讨了基于J2EE(Java 2 ...

    基于J 2EE的三层B /S企业信息系统

    ### 基于J2EE的三层B/S企业信息系统 #### 一、引言 随着科技的迅速进步和社会信息化程度的提高,企业信息系统的完善与否直接影响到企业的管理水平和竞争力。如何构建一个稳定、功能强大且界面友好的信息化平台,...

    基于J2EE四层体系框架系统的研究与实现

    传统的客户端/服务器(C/S)两层结构主要用于通过静态页面在Internet上发布信息,而浏览器/服务器(B/S)三层结构则通过在服务器端生成动态页面来集成数据生成和数据表现,使得动态页面变得庞大且难以维护。...

    基于B/S 模式的PACS 的研究与实现

    基于B/S模式的PACS系统采用了三层架构设计,分别为前端(客户端)、中间层以及后台系统。 - **前端**:即客户端,主要通过浏览器访问服务器端提供的JSP或Java Applet来实现用户界面。这种方式简化了客户端的配置和...

    基于J2EE的客户关系管理系统的设计与实现

    本系统基于J2EE平台的三层分布式架构设计,具体包括客户层、Web层和数据层,符合B/S架构的特点。 - **客户层**:负责用户界面展示,通过浏览器访问系统。 - **Web层**:采用MVC模式进行设计,负责处理用户的请求,...

    基于J2EE技术和工作流引擎构建B/S模式的文献资料管理系统

    ### 基于J2EE技术和工作流引擎构建B/S模式的文献资料管理系统 #### 一、引言 随着信息技术的飞速发展,企业科技文献资料的管理工作面临着新的挑战。传统的人工管理或简单的微机操作已经无法满足现代企业管理的需求...

    基于J2EE 与XML 的网站自动生成技术研究

    ### 基于J2EE与XML的网站自动生成技术研究 #### 一、引言 随着计算机网络技术的快速发展,信息处理平台的功能越来越强大。为了应对社会节奏加快和社会信息爆炸带来的挑战,许多单位和现代企业纷纷引入办公自动化...

    基于J2EE 的教学管理信息系统的设计

    总结:本文主要介绍了基于J2EE架构的教学管理信息系统的设计,采用B/S模型的三层体系结构,并提到了J2EE相关技术和数据库选择。同时,还探讨了非IT领域的问题——氧腐蚀及其防治策略,虽然这部分内容与主题关联度较...

    论文研究-基于J2EE的高校通用考试题库系统设计与实现 .pdf

    系统采用三层架构,即表示层、逻辑层和数据层。 - 表示层由Web浏览器和Web服务器组成,主要负责展示页面和接收用户输入。 - 逻辑层包含Servlet和EJB,负责处理业务逻辑。 - 数据层由数据库管理系统构成,负责数据...

    基于J2EE技术的林业企业进销存管理系统的设计

    #### 三、基于J2EE技术的进销存管理系统架构设计 **1. J2EE技术概述** J2EE(Java 2 Platform, Enterprise Edition)是一种广泛应用于企业级应用开发的技术标准,它提供了强大的组件模型和支持服务,能够满足复杂...

    基于J2EE的高校档案管理系统分析与设计

    ### 基于J2EE的高校档案管理系统分析与设计 #### 一、系统概述 在信息化快速发展的背景下,高校档案管理工作面临着巨大的挑战与机遇。传统的纸质档案管理模式已难以满足现代高效、便捷的需求。因此,开发一套基于...

    基于J2EE框架的个人博客系统项目毕业设计论文(源码和论文)

    伴随着Internet的迅速发展,计算机技术正在由基于C/S(client/ Server)模式的应用系统转变为基于B/S模式的应用系统。 过去,网络软件的开发都采用C/S(client)模式,在这种模式下,主要的业务逻辑都集中于客户端...

    基于J2EE的船舶机务管理信息系统的设计与实现

    基于J2EE的船舶机务管理信息系统采用多层次架构,如表示层、业务逻辑层和数据访问层。J2EE平台提供了一系列的标准服务,如Java数据库连接(JDBC)、Java消息服务(JMS)、Java命名目录接口(JNDI)等,这些技术的结合使用...

    基于J2EE体系的网络办公自动化系统

    在本系统中,采用B/S(Browser/Server)数据库三层架构,即浏览器、应用服务器和数据库服务器,这种架构降低了客户端的维护成本,使得用户只需通过浏览器即可访问和使用系统。 系统设计的关键在于模块化,允许流程...

    基于J2EE三层体系结构的网上商城的设计与实现

    采用B/S结构实现一个网上商城的系统,包括前台和后台,功能模块大致如下: 前台:显示公告,商品销售排行,新品展示,特价商品展示,查看订单,查看及修改购物车信息,查询商品信息,用户登录与注册。 后台:维护...

Global site tag (gtag.js) - Google Analytics