apache开源项目-- Turbine

简介:

1. 缘起

Jetspeed是Apache Jakarta小组的开放源码门户系统。它使得最终用户可以通过WAP手机、浏览器、PDA等各种设备来使用各种各样的网络资源(比如应用程序、数据以及这之外的任何网络资源)。在这里,Jetspeed扮演了一个处于信息和用户间的hub的角色。

1999 年左右,Jetspeed立项并开始运作。很快,Jetspeed的发展就超越了最初立项时的目标,以任何人都难以想象的速度发展。用Jakarta小组 自己的话说,就是:“The only problem is that this was beyond the scope of this project.”。

现在,Jetspeed逐渐演变成了一个基于Turbine(也是Jakarta小组的杰作)这个网络应用框架(Frameworks)的Web应用引擎。

1.1 Jetspeed

简单的看,Jetspeed就是添加了门户组件的Turbine。它本身既是Portlet容器,又包含了大量的实用Portlet。在Jetspeed中,Portlet的管理主要由以下两种文件完成:

l        .xreg注册文件

l        .psml配置文件

.xreg文件一般放置在webapp-name/WEB-INF/conf目录下,文件名不限。一个Portlet必须通过.xreg文件注册才能在Jetspeed中使用。每一个Portlet组件都是能够被系统实例化,用于输出特定Web文档的Java类。

.psml文件一般放置在webapp-name/WEB-INF/psml目录下,文件名不限。.psml设定了页面内容的显示模式,比如:一个页面如何布局,分为多少列、每列能有多少个窗格、各个窗格的内容是由哪个Portlet输出的等等内容。

2. 概述

Turbine是一个基于Servlet的Web Application Frameworks,使得java开发者可以快速、安全的构建自己的网络应用。

Turbine是一个完全的MVC应用框架,主要由以下几个部分组成:

l        表述层:Velocity(又是Jakarta小组的杰作,一个基于Java的模版引擎)或JSP

l        数据层:Torque和Peers

l        控制层:Turbine

l        HTML Form Validation:Intake

l        日志:Log4j和Turbine2中的Logging Service

l        Service Frameworks:Turbine (在Turbine3中,此部分被称为Fulcrum)

本文主要介绍Turbine中的控制层,其余部分请参考各自的文档或参考资料中提到的站点。

3. 基石

Turbine主要由五部分组成,如下图所示:

turbine - 展翅高飞 - 爪哇谷

我们先对这五个部分进行单独介绍,再介绍Turbine的详细流程。

3.1 Action

Action是一个执行特定事务的模块,Turbine中的SessionValidator就是一个典型的Action。

在 用户提交一个HTML表单的时候,其中有一个隐含的字段就包含了将要被执行的Action的信息。Action机制使得java开发者更容易的处理用户提 交的数据。例如,对于“Logout”这个事务,在系统的多个地方都可能被调用;因此,将Logout的事务处理流程写成一个可重用的模块,使得这个事务 可以被更方便的调用。这个可重用的模块就是一个Action。通过系统中多种多样的Action,每个Action处理用户数据中不同的信息,这样,整个 系统就显得更加简单明快,更易编写、扩充与维护。

并且,Turbine通过Action机制中,还可以使程序流程更加灵活多变。例如,在Page的处理过程中,可以通过执行特定的Action,帮助判断其后将要显示哪个Screen。这时,Action的执行结果就可以作为以后程序的判断依据。

Action是系统中可重用的事务处理组件,Action机制使得Turbine拥有灵活、清晰的事务处理流程。

3.2 Page

Page模块是在页面生成过程中最先被执行的一个模块,它可以被认为是Action、Layout、Screen、Navigation之间的协调者和组织者。

一 般情况下,Page先执行用户请求中的指定的Action(如果有的话);然后,根据其后要装载的Screen来选择并执行相应Layout。请注意,在 这个时候,究竟是执行哪一个Screen,可能会因为Action执行结果的不同而改变。并且,Screen的Layout也可能因为 TurbineResources.properties配置文件中对DefaultLayout的设置不同而改变。

3.3 Screen

Screen模块从根本上说,是网页的“躯干”。这也是生成网页中的HTML代码的地方。Screen是整个Turbine中最主要的表述(View)部分。

Screen是由Layout调用的。

请注意:此时,你完全可以调用各种外部模块,比如EJB,来获得数据以构建你的HTML页面。也可以通过JSP,甚至是使用Blog来构建页面内容^_^。

3.4 Navigation

一般情况下,网站都有自己的Top & Bottom Navigation;不过,通常情况下它们都叫做Header或Footer。同Screen一样,Navigation也是由Layout调用的。

不光是作为Header或Footer,Navigation也能以Menu或Tree View的形式出现。

3.5 Layout

Layout由Page调用,可以认为是Screen和Navigation的容器。

类似Swing和AWT中的各种容器,Layout一般定义了各个Navigation、Screen分别显示在页面的什么地方,起到一个布局管理的作用。

可以看出,Turbine中各个模块对象间的封装关系大致如下图所示:

turbine - 展翅高飞 - 爪哇谷

从 上图中,我们又可看到,Turbine中的各个元素互相封装(encapsulation),使得HTML页面以一种模板化的形式出现在了我们面前。为什 么会这样?Jakarta小组是这样对我们解释的:“This is no accident, the Turbine framework is essentially an object oriented representation of the components of an Html page.”

3.6 Loader

除了上面提到的五种组件外,Turbine中还存在着另外一种组件:Loader。

turbine - 展翅高飞 - 爪哇谷

Loader负责动态装载上面提到五种组件。这些Loader能够将上面的五种组件对象保持在内存中,以形成缓存,加快程序响应。

Loader 通过配置文件:TurbineResources.properties来识别这些组件。Loader相当于java中的ClassLoader;而 TurbineResources.properties就好像“Loader Classpath”一样,帮助Loader识别各个组件。这样,Turbine就能保证我们的Web Application总是能被正确地装载和执行。

4. 流程

行文至此,相信各位对Turbine的标准控制流程已了然于胸:

turbine - 展翅高飞 - 爪哇谷

在 基于Turbine的Web Application中,一般只有一个Servlet(Turbine Servlet),用来接收用户请求。当这个Servlet接收到请求后,通过分析其中的数据,决定load哪个Page;如果需要的话,Page去执行 指定的Action;然后,装载指定的Layout;最后,由Layout调用Screen和Navigation负责web页面的生成。

4.1 Turbine Standard System Flow

在一个常见的Turbine应用中,Turbine Servlet一般遵循下面的处理流程:

1、  当一个新请求来到时,Turbine Servlet首先检查HttpSession实例是否存在。如果不存在HttpSession实例,则直接重定向到这个网址的“HomePage”(这 个“HomePage”的默认值是Login Screen。当然,你也可以在TurbineResources.properties中将它指向任何你希望的地方)。

在重定向的过程中,Turbine还会在Cookie中为这个访问者记录一个唯一标识;如果客户端浏览器不支持Cookie,Turbine会激活“session tracking”,使以后的URLs中都会包含这个用户的标识信息。

2、  用户Session建立后,Turbine会将一部分经常用到的数据缓存到RunData实例中。

3、  接下来,Turbine Servlet会检查用户是否在尝试登录。方法是检查请求中定义的Action是否是“LoginUser”(当然,依旧可以在 TurbineResources.properties文件中进行自定义)。如果是的话,就执行这个Action操作。与其他Action不同的是,这 个“LoginUser”Action必须实现一个用于用户身分验证,并调用RunData.save()方法(表明已通过身分验证)。

4、  无论用户验证通过与否, Turbine Servlet都会调用SessionValidator Action。SessionValidator Action检查用户是否已经登录,如果有的话,更新该用户最后一次登录的时间戳;否则重定向到“Login”Page。这里有一个技巧:如果你希望你的 某些页面拥有权限保护的话,你可以在这些页面的Layout中调用SessionValidate Action。或者你的系统不需要登录的话,你可以用一个简单的仅返回null的SessionValidate Action版本来替代默认版本。

5、  接下来,Turbine Servlet会调用“DefaultPage”。“DefaultPage”会开始一连串的事务处理:调用Action(如果有的话)、执行Layout等等。

6、  当Layout处理完Screen和Navigation后,System Flow结束,Turbine Servlet返回所请求的页面信息。

5. RunData

看到此处,可能大家会有一个共同的疑问,那就是:经过这么多层的调用,那么用户请求中包含的数据究竟是怎么传递的呢?答案就是RunData。

在System Flow一节的描述中,我们可以看到RunData通过RunData.save()方法记录了一个用户登录与否的信息。实际上,RunData主要起到在整个框架中传递参数的作用。RunData实例中可以保存数据库连接、GET/POST/PATH_INFO (GPP) 数据、Action和Screen的名字以及输出HTML的Document实例。并且,你也可以在RunData中保存需要持久化的信息。


本文转自二郎三郎博客园博客,原文链接:http://www.cnblogs.com/haore147/p/5105202.html,如需转载请自行联系原作者

相关文章
|
3月前
|
SQL 数据可视化 大数据
【开源项目推荐】Apache Superset——最优秀的开源数据可视化与数据探索平台
【开源项目推荐】Apache Superset——最优秀的开源数据可视化与数据探索平台
123 1
|
3月前
|
Dubbo 应用服务中间件 Apache
恭喜 Apache Dubbo 和 Nacos 荣获开放原子“2023年度生态开源项目”
恭喜 Apache Dubbo 和 Nacos 荣获开放原子“2023年度生态开源项目”
|
11月前
|
消息中间件 自然语言处理 Cloud Native
最高等级!Apache RocketMQ 入选可信开源项目星云象限领导型象限
最高等级!Apache RocketMQ 入选可信开源项目星云象限领导型象限
|
自然语言处理 Dubbo 搜索推荐
又一国产开源项目走向世界,百度RPC框架Apache bRPC正式成为ASF顶级项目
Apache bRPC的前身是百度内部的一个RPC框架,采用C++语言编写,号称工业级别,在百度内部众多基础和业务系统中得到大规模的应用,是属于实战出来的,有很好的落地效果和"底子"。
347 0
|
消息中间件 存储 运维
第一次尝试为Apache顶级开源项目贡献代码
第一次尝试为Apache顶级开源项目贡献代码
第一次尝试为Apache顶级开源项目贡献代码
|
Cloud Native Linux Apache
生态建设对开源项目的重要性 | Apache APISIX Summit Asia 2022 圆桌回顾
2022 年 5 月 21 日,Apache APISIX Summit ASIA 2022 开启第二天的议程。围绕“生态建设对开源项目的重要性”这一主题,王晔倞(API7.ai 合伙人兼技术副总裁,Apache APISIX Committer)担任主持人,与周小四(青云科技容器事业部负责人)、王宇博(亚马逊云科技开发者关系总监)、吴晟(Tetrate 创始工程师,Apache SkyWalking 创始人)三位嘉宾展开了一场圆桌讨论,讨论话题包括:“社区、用户、开发者对于开源项目的意义”、“完善的开源生态系统对于开发者和用户的意义”、“开源生态发展在国内大环境下的态势与挑战”。
194 0
|
消息中间件 SQL 数据采集
解决研发数据分析瓶颈,开源项目 DevLake 加入 Apache 软件基金会孵化器 | InfoQ 专访
每一位开源参与者、每一个开源项目都可以成为舞台上的主角。
218 0
解决研发数据分析瓶颈,开源项目 DevLake 加入 Apache 软件基金会孵化器 | InfoQ 专访
|
存储 SQL 分布式计算
全票通过!微众开源项目 Linkis 进入 Apache 孵化
全票通过!微众开源项目 Linkis 进入 Apache 孵化
全票通过!微众开源项目 Linkis 进入 Apache 孵化
|
消息中间件 自然语言处理 Cloud Native
Apache RocketMQ 荣获 2021 中国开源云联盟优秀开源项目
伴随着云原生时代的到来以及实时计算的兴起, 生于云、长于云的 RocketMQ 5.0 应运而生,阿里云消息队列 RocketMQ 全新升级为云原生消息、事件、流融合处理平台 RocketMQ 5.0,帮助用户更轻松地构建下一代事件驱动和流处理应用。
Apache RocketMQ 荣获 2021 中国开源云联盟优秀开源项目
|
Dubbo Cloud Native 应用服务中间件
参与 Apache 顶级开源项目的 N 种方式,Apache Dubbo Samples SIG 成立!
一说到参与开源项目贡献,一般大家的反应都是代码级别的贡献,总觉得我的代码被社区合并了,我才算一个贡献者,这是一个常见的错误认知。其实,在一个开源社区中有非常多的角色是 non-code contributor,一个开源社区中的很多关键职责被大家给忽略了。
参与 Apache 顶级开源项目的 N 种方式,Apache Dubbo Samples SIG 成立!

热门文章

最新文章

推荐镜像

更多