`
hotbarsmu
  • 浏览: 7429 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

做减法的Web应用二次开发平台(一)

阅读更多

拼出一张世界地图

一位软件开发商的老总曾经问,“当初自己做项目时就用Delphi,几个人3个月的时间完成了。为什么现在十几个人,用了这个平台那个框架,还需要半年多的时间。”在笔者不知如何作答之际,老总自己说出了心中的答案,“可能是现在需要实现的不是几个业务功能而是一个大的业务系统,要写大量的项目文档量,比起C/SB/S的这种多层架构在技术上需要考虑的东西也更多了”。

每一次计算模式与通讯模式的变革,都会摧生一批相应的二次开发平台,好比一次次航海技术与行陆技术的升级之后,人们总会发现未知的世界。如果将C/S架构带来的新世界比作一个岛屿,B/S架构带来就是一个新大陆,后者需要更多的勘探时间。没有人能在很短的时间内走遍这块大陆,务实的做法是将一部分地域勘探清楚,测绘出局部地图,若干份局部地图拼起来构成全貌。因此,一个有趣的现象是在C/S时代,DelphiPowerBuilderNotes二次开发平台或工具自成体系,并基本是互斥的;而在B/S时代,数据持久层框架、业务对象层框架、表现层框架是相互配合的。

C/S时代的技术假设是以桌面操作系统为前台环境,业务逻辑前置;B/S时代的技术假设是以浏览器为前台环境,业务逻辑后置,原来的二次开发平台已无用武之地。多数公司选择了重要而且紧急的后台业务逻辑框架作为研发重点,少数公司,选择了重要但不紧急的表现层框架作为研发重点。这好比多数人从大陆的一端开始勘探,少数人从另一端开始,经过一段时间的各自努力,在内陆会师。交换成果后,大家发现至少可以拼成一张贯穿大陆主线的地图。

在表现层框架成熟之时,构建一个真正意义上的贯穿前后台的快速开发平台就成为可能,这也意味着占代码量50%的前台开发有规范与标准可依。

新一代的二次开发平台应该是:

1, 较为完整,涵盖从前台到后台的软件架构各个层次。

2, 组装灵活,可以使用全部也可以使用其中一部分。

3, 开放度高,当某一层出现更为先进的框架时,可以取代现有该层框架。

换言之,用户可以用做加减法的方式,将不需要的部分从该平台中移除,将需要的部分引入,从而调整出适用某个项目需求的最精简的开发架构平台。随着这样的二次开发平台不断发展,用户将更多地做减法。

 

由简入繁难,由繁入简易

有过J2EE Web应用开发经历的程序员都知道,对于每一个应用我们除了要处理复杂的界面与排版之外,还要处理诸如权限、异常、日志等等这些与业务无关但又不可或缺的功能,实现这些功能要占用我们的大量时间,让本来就短的项目工期更显得捉襟见肘。

       按照做减法的二次开发平台的设想,我们选取对应于软件架构中各层的成熟框架,以松耦合的形式将这些框架整合到一起协调工作,这样就可以初步满足上述需求了。

       J2EE Web系统开发中最麻烦的不是占50%工作量后台业务逻辑,而是另一个50%——前台界面开发,我们引入展现中间件来负责这一层,后台业务逻辑层中众多的Java对象与属性配置文件的管理交给业务对象层,再加上必需的应用中间件与数据库,就构成了二次开发平台的核心。数据库里存放的是平面化的二维数据,在面向对象的开发模式中,操作的是立体化的对象数据,增加一个持久层框架来负责这个O/R mapping的过程。需要细化对系统资源的权限管理,比如按角色方式管理用户能否访问页面、组件、组件里的元素及后台的Java方法,可以引入一个权限框架。在强调业务流转或规则计算的场景中可以引入工作流管理系统与规则引擎。如果业务流转跨系统并涉及SOA架构体系,可以引入企业服务总线层。

 

(图:做减法的二次开发平台总揽)

 

dorado应用基础框架(MARMOT

2000年开始,笔者所在公司BSTEK的研发团队就开始专注于交互型Web应用系统的表现层的技术研发,2002BSTEK成立,2003年推出Extra 32005年推出dorado 42006年推出企业级AJAX展现中间件dorado 5dorado的出现解决了B/S应用的前端展现问题,使我们原来要花费一天时间才能做好的界面现在一个小时或更短的时间就可以完成了。用户提出在此基础上如果提供现成的更加贴近于应用的诸如各种展现组件自定义、权限等相关功能的实现,将进一步优化dorado的实际应用效果,另一方面,每家软件开发商引入dorado展现中间件都或多或少有一个与既有开发平台整合的过程。为此,BSTEK推出了dorado应用基础框架(代号Marmot )。

MARMOT在英文是土拨鼠、旱獭的意思。每年22日是传统的“土拨鼠日”(Groundhog Day)。民间传说,如果土拨鼠在这一天出洞时看到自己影子的话,会回洞继续冬眠,那意味着冬天还将持续6周,反之则意味着春天的脚步近了。因此每逢此日,经历着漫漫长冬的人们便关注着土拨鼠“预报员”的春天预言。最初给起代号的时候,需要一个能让联想到“HibernateSpring”的单词,会冬眠而又能预言春天来临的土拨鼠是不是很可爱呢。名字就这样延用下来,现在又增加了像土拨鼠一样打通应用架构中的各个环节的喻意。

 

DORADO设计与实现

       在介绍Marmot之前,先介绍一下DORADO展现中间件的设计与实现,其设计有以下几个特点:

1, OPOB设计模式。OPOB - One Page One Business,即通过一个页面完成一个业务功能,是更适应页面复杂操作频繁的交互型MIS类业务需求的设计模式。之前的MPOB是适应浏览型与填报型业务需求的设计模式。

数据模型驱动。表现层框架数据与UI组件相分离,通过具有管理功能的对象(dataset称为数据集合或数据模型)保证各种数据控件具有一致的行为,用户完全通过各种数据感知控件来观察和操作数据模型中的数据。dorado所采用的数据与表象分离的设计方式,事实上就是一种MVC的架构模式,是存在于Client端内部的“迭代式的MVC架构”。

 

(图:dorado中的数据模型驱动)

dorado中的组件主要分为DatasetControl两种。Dataset用于分装展现层中的数据,Control用于封装各种界面元素和操作逻辑。Control主要用于与用户交互,Dataset主要用于与后台数据、业务逻辑交互。

 

 

(图:dorado实现原理)

随着技术的发展,对数据的管理、对UI组件的管理、对AJAX通信的封装、国际化等等表现层的功能和设计已经变得越来越复杂,现在已经不再是那个表现层里只有HTML的年代了,已经成为了一个跨越Server端和Client端的子系统。

1, 松耦合整合。表现层框架与后台业务逻辑框架的对接采取松耦合模式,只要能把数据塞给表现层框架,表现层框架就能展现,并能够把数据回填给后台业务逻辑框架。

2, 性能优化。DORADO客户端的优化包括通过大量测试寻到最优实现方案(JavaScript+DHTML的使用方面) 、复杂界面按需初始化、规避由浏览器BUG导致的内存泄露等,对网络通讯的优化包括数据的懒加载、利用GZIP对通讯数据进行压缩、利用JavaScript编译器对库文件进行代码压缩、利用Ajax改善用户的操作体验等。

 

DORADO展现中间件的实现,有以下几个层次:

1,表现层4大功能。数据通过各种控件展示,进行查询、增加、修改、删除、保存等操作,占表现层技术需求的80%,这是DORADO本身研发实现的重点,提供控件Widget Lib、国际化I18N、皮肤Skin,角色RoleAJAX通讯引擎等支持通过视图模型viewModel进行表现层建模。剩余20%包括报表与打印、复杂图形与数据分析、文书等,通过与第三方产品整合或集成来实现。

2,前后台交互。通过不同的数据集合dataset支持不同的后台,包括SQL查询结果集,POJOJavabeanMapcollection),Web ServiceXML,定制的数据集合等,对框架而言,支持SpringHibernate/ibatisWfMC/BPEL/自有标准流程引擎等。

3,开发与调试环境。提供集成开发工具 dorado studioEclipse插件用于提供针对产品所需的各种源文件的模版化生成、创建向导、可视化配置,以及一些简单的编译、部署、测试等功能。Debugger提供评估JavaScript并计时、显示调试日志、显示部分系统信息等功能的简单JS调试小工具。

4,性能测试与调优。内置多种浏览器端性能优化措施。提供Web Console进行参数配置与性能监控。提供自主研发开源小工具TestFrame专用于测试页面刷新用时、提交用时等浏览器端页面性能定量指标。

 

分享到:
评论
2 楼 fxsjy 2008-09-19  
架构图画得很漂亮,请问是用什么工具画的?
1 楼 魔力猫咪 2008-09-19  
从开发商网站上抄过来的。看起来是广告。

相关推荐

    quadratic:一个帮助您求解二次方程式的网页

    总的来说,"quadratic"是一个基于JavaScript的在线工具,它利用了Web技术的便捷性,帮助用户快速求解二次方程,展现了JavaScript在教育和实用计算方面的应用潜力。通过深入理解JavaScript以及Web开发的基本原理,...

    二进制在线转换 v1.0.zip

    借位规则“借一当二”则是在减法中,借位相当于加上二的负幂次。 `phpbin.php`可能是该在线转换工具的核心代码,使用PHP语言编写。PHP是一种广泛使用的开源脚本语言,特别适合于Web开发,可以嵌入到HTML中。在这个...

    Flex4编写计算器小程序

    - **Flex4**:一种用于构建桌面和移动设备上的高性能、跨平台的富客户端应用程序的软件开发框架。Flex4提供了一套强大的工具集,用于创建用户界面、处理数据绑定和事件驱动的操作。 - **MXML**:Flex的应用程序通常...

    多项式计算器-简易版本-java

    Java的类库丰富,适合开发各种类型的应用程序,包括桌面应用、Web应用以及移动应用等。 接下来,我们要探讨的是这个简易版多项式计算器的核心功能。多项式是指由常数、变量以及它们之间的加、减、乘、幂运算组合而...

    计算机 英语 词汇 大全

    - **应用场景**:在游戏开发、电影制作以及教育软件中广泛应用。 #### Application software(应用软件) - **定义**:专为执行特定任务而设计的软件程序。 - **例子**:文字处理软件、电子表格应用程序等。 #### ...

    基于C# 实现的计算器 源码

    C#是一种由微软开发的面向对象的编程语言,广泛应用于Windows应用程序、游戏开发、移动应用以及Web服务等多个领域。在这个源码中,我们将看到如何利用C#的基础语法、控制结构和图形用户界面(GUI)来构建一个简单的...

    VB计算器

    由于其源代码开放,用户在下载后可以根据自己的需求进行二次开发,轻松添加更多自定义功能。 Visual Basic是Microsoft公司推出的一种面向对象的编程环境,它以直观易学著称,尤其适合初学者学习编程。在VB中,我们...

    java开发视频

    - **JAVA语言的应用范围**: Java广泛应用于各种领域,包括Web开发、移动应用开发、大数据处理、云计算服务等。 - **JAVA开发环境的安装和配置详解**: - **下载JDK**: 可以从Oracle官网或其他可信源下载适合您操作...

    Python语言重要知识点梳理一(极其详细).docx

    Python在软件开发领域扮演着重要角色,它被广泛应用于Web开发、数据分析、人工智能、自动化脚本等多个领域。Python的跨平台特性使其可以在Windows、Linux、Mac OS等操作系统上运行,其丰富的第三方库如Numpy、Pandas...

    java计算器设计报告(含源代码)

    HotJava 浏览器是 Java 应用的一个早期示例,它展示了 Java applet 在网页上的动态展示效果,这也推动了 Web 技术的发展。 **1.2 Java 语言的特点** - **面向对象**:Java 是一种完全的面向对象的语言,支持封装、...

    编程英语单词

    - ASP 是一种服务器端脚本环境,用于创建和运行动态、交互式Web应用程序和服务。 21. **ASP.NET Worker Process (ASP.NET 工作者进程):** - ASP.NET 工作者进程是用于托管ASP.NET应用程序的进程,它可以独立于IIS...

    C#程序设计

    它结合了多种语言的优点,如C++的性能与Java的健壮性,特别适用于构建Windows桌面应用程序、Web应用、游戏(特别是Unity引擎中的游戏开发)、服务端应用等。 #### 二、控制台应用程序基础 **案例1**:基于控制台的...

    2021-2022计算机二级等级考试试题及答案No.13540.docx

    - Web应用程序开发,如使用Node.js进行后端开发。 - JavaScript还具备良好的跨平台兼容性,能够在多种浏览器和设备上运行。 这些知识点涵盖了计算机基础知识、编程语言、数据库管理等多个方面,对于准备计算机二级...

    《计算机科学概论》课后答案

    1. **问题一**:哪位法国数学家建造并销售了第一台齿轮驱动的机械计算机来执行加减法运算? - **答案**:B. Pascal(帕斯卡) - **解析**:布莱兹·帕斯卡是一位著名的法国数学家、物理学家、哲学家及神学家,他...

    java 计算器 小程序(精简版)

    它具有丰富的类库和强大的跨平台能力,适用于开发桌面应用、Web应用和移动应用等多种类型项目。 2. **计算器设计**:计算器通常包含数字键盘、运算符键以及清除、等于等辅助键。在Java中,这些功能可以通过控制台...

    C#实验计算器代码案例

    C#是一种面向对象的、类型安全的、现代的编程语言,广泛应用于Windows平台、Web开发以及游戏开发等领域。通过这个实验,你可以深入理解C#的基础语法、事件处理以及控制台应用程序的开发。 首先,让我们来了解C#中的...

    C#完全手册(PDF格式 )

    这使得C#成为了开发各种类型应用(包括Web应用、桌面应用和移动应用)的理想选择。 #### 二、.NET框架深入理解 **2.1 .NET结构** - **CLR(公共语言运行时)**:负责执行托管代码,提供内存管理、线程管理和安全...

    深入理解计算机系统英文版

    - **应用场景**:在数据库应用、Web服务器等领域中,合理设计缓存策略可以显著提升系统响应速度。 ##### 1.6 存储设备形成层次结构 - **核心概念**:不同类型的存储设备根据其访问速度和成本被安排在层次结构中。 ...

Global site tag (gtag.js) - Google Analytics