这种结构不仅把客户机从沉重的负担和不断对其提高的性能的要求中解放出来,也把技术维护人员从繁重的维护升级工作中解脱出来。由于客户机把事务处理逻辑部分分给了功能服务器,使客户机一下子"苗条"了许多,不再负责处理复杂
计算和数据访问等关键事务,只负责显示部分,所以维护人员不再为程序的维护工作奔波于每个客户机之间,而把主要精力放在功能服务器上程序的更新工作。这种三层结构在层与层之间相互独立,任何一层的改变不会
影响其它层的功能。
3.2 b/s三层体系结构的不足
经过近一两年的
应用,b/s体系结构也暴露出了许多不足地方,具体表现在以下几个方面:
(1) 由于浏览器只是为了进行web浏览而设计的,当其
应用于web应用系统时,许多功能不能实现或实现起来比较困难。比如通过浏览器进行大量的数据输入,或进行报表的应答都是比较困难和不便的。
(2) 复杂的应用构造困难。虽然可以用activex、java等技术开发较为复杂的应用,但是相对于
发展已非常成熟c/s的一系列应用工具来说,这些技术的开发复杂,并没有完全成熟的技术供使用。
(3) http可靠性低有可能造成应用故障,特别是对于管理者来说,采用浏览器方式进行系统的维护是非常不安全与不方便的。
(4) web服务器成为对数据库的唯一的客户端,所有对数据库的连接都通过该服务器实现。web服务器同时要处理与客户请求以及与数据库的连接,当访问量大时,服务器端负载过重。
(5) 由于业务逻辑和数据访问程序一般由javascript、vbscript等嵌入式小程序实现,分散在各个页面里,难以实现共享,给升级和维护也带来了不便。同时由于源代码的开放性,使得商业规则很容易暴露,而商业规则对应用程序来说则是非常重要的。
为克服以上不足,在原有b/s体系结构基础上,采用一种新的体系结构,如图2所示。
在该种结构体系中,一些需要用web处理的,满足大多数访问者请求的功能界面(如信息发布查询界面)采用b/s结构。后台只需少数人使用的功能应用(如数据库管理维护界面)采用c/s结构。组件位于web应用程序中,客户端发出http请求到web server。web server将请求传送给web应用程序。web应用程序将数据请求传送给数据库服务器,数据库服务器将数据返回web应用程序。然后再由web server将数据传送给客户端。对于一些实现起来困难的功能或一些需要丰富的html页面,通过在页面中嵌入activex控件来实现。
采用这种结构优点在于:(1)充分发挥了充分了b/s与c/s体系结构的优势,弥补了二者不足。充分考虑用户利益,保证浏览查询者方便操作的同时也使得系统更新简单,维护简单灵活,易于操作。(2)信息发布采用b/s结构,保持了瘦客户端的优点。装入客户机的软件可以采用统一的www浏览器。而且由于www浏览器和
网络综合服务器都是基于
工业标准,可以在所有的平台上工作。(3)数据库端采用c/s结构,通过odbc/jdbc连接。这一部分只涉及到系统维护、数据更新等,不存在完全采用c/s结构带来的客户端维护工作量大等缺点。并且在客户端可以构造非常复杂的应用,界面友好灵活,易于操作,能解决许多b/s存在的固有的缺点。(4)对于原有基于c/s体系结构的应用,可以非常容易地升级到这种体系结构,只需开发用于发布的www界面,可以保留原有的c/s结构的某些子系统,充分地利用现有系统的资源。使得现有系统或资源无需大的改造即可以连接使用,保护了用户以往的投资(5)通过在浏览器中嵌入activex控件可以实现在浏览器中不能实现或实现起来比较困难的功能。比如通过浏览器进行报表的应答。另外,在客户端activex控件的加盟,可以丰富html页面,产生另人惊奇的效果。(6)将服务器端划分为web服务器和web应用程序两部分。web应用程序采用组件技术实现三层体系结中的商业逻辑部分,达到封装源代码,保护知识产权的目的。internet应用程序大部分属于分布式应用程序,采用组件技术一个重要特点就是它的处理能力能够随着用户数量、数据量所需性能的提高而增加。com的无逢扩展集com+,有着如内存数据库、负载平衡等强大的功能。
4 实例
下面以某学校学生管理系统为例说明b/s结构软件的设计
方法,该系统采用b/s体系结构与com+技术相结合。通过该系统管理人员可以对学生的学籍、学生的日常表现、学生的
学习成绩、学校教师、学校的资产进行管理与维护。任课教师可以通过浏览器查询所教班级学生各种相关信息。学校管理人员通过浏览器对学校的学生、教师等信息进行管理与维护以及有关查询统计功能。学校资产管理人员通过c/s体系结构实现对学校资产的管理维护。