Portal技术原理

Portal技术原理
  advanceroot 发表于 2005-8-8 22:29:00
  JSR168将Portal 的组成分为三部份 (1) Portal Server (2) Portlet Container (3) Portlet。
  Portal Server的定义
  建立在HTTP Server上。负责接收HTTP请求,调用Portlet,并将Portlet产生的内容聚集到Portal页面返回给用户。(Portal Server有时简称Portal)
  
  Portlet Container 的定义
  Portal Container:管理Portlet的生命周期并且提供其运行所需要的必要环境。同时也提供Portlet相关信息的存储。一个Portlet container 接收到来自Portal 的请求后,接着将这个请求传递给存在Container 的Portlet 执行。Portlet Container 没有义务去组合Portlets 产生的信息內容,这个工作必须由Portal (即Portal Server)来处理。Portal 和Portlet Container 可以放在一起视为同一个系统的组件,或者分开成为两个独立的组件。
  
  Portlet的定义
  一个 Portlet 是以 Java 技术为技术的 Web 组件,由 Portlet Container 所管理,专门处理客户的 request 以及产生各种动态的信息内容。Portlets 为可插式 ( pluggable ) 的客户界面组件,提供呈现层成为一个信息系统。
  这些由 portlet 产生的内容也被称为片段 (fragment),而片段是具有一些规则的Markup( HTML、XHTML、WML ),而且可以和其他的片段组合而成一个复杂的文件。而 Portlet 中的内容正常来说是与其他 Portlet 的内容聚合而成为一个 Portal 网页。而 Portlet 的生命周期是被 Portlet Container 所管理控制的。
  
  客户端和 portlets 的互动是由 portal 通过典型的 request/response 方式实现,正常来说,客户会和 portlets 所产生的内容互动,举例来说,根据下一步的连接或者是确认送出的表单,结果 portal 将会接收到 portlet 的动作,将这个处理状况转向到目标 portlet。这些 portlet 内容的产生可能会因为不同的使用者而有不同的变化,完全是根据客户对于这个 portlet 的设置。
  
  Portlet生命周期
  Portlet接口的四个方法构成一个完整的生命周期:
  public void init(PortletConfig config) throws PortletException;
   由Portlet容器调用,在将Portlet放入服务区前调用。Portlet容器在初始Portlet后,直接调用这个方法。
  public void processAction (ActionRequest request, ActionResponse response) throws PortletException, java.io.IOException;
   由Portlet容器调用,用来处理action request。
  public void render (RenderRequest request, RenderResponse response) throwsPortletException, java.io.IOException;
   由Portlet容器调用,用来生成输出。
  public void destroy() ;
   将Portlet从服务区中删除。
  
  
  一个Portal处理流程
  
  1. 一个客户端(例如:一个web浏览器)在被验证之后向Portal发出HTTP请求;
  
  2. Portal(或称为Portal Server)接收到请求;
  
  3. Portal判断请求是否包含与组成门户网站网页的portlet有关的动作;
  
  4. 如果存在与某个portlet相关的动作,Portal请求portlet容器调用portlet处理动作;
  
  5. Portal通过portlet容器调用portlet,获得被包含在产生的门户网站网页中的内容片段;
  
  6. Portal将portlet产生的结果聚集于门户网站的网页,然后将网页返回至客户端。
  
  在下图中需要注意的是Portal服务器是建立在Http服务器的基础上的。Portal服务器不可独立的运行。
  
  
  
  http://www.blog.edu.cn/user2/34856/archives/2005/260777.shtml
  
  
  
  1.Portal用例
  读者可以在下面三个网站上注册自己的用户,体会Portal的功能。
  http://my.msn.com
  http://my.yahoo.com
  http://my.liferay.com
  
  My MSN的功能最灵活强大,用户可以任意拖放操作栏目(column)和内容版块(content)的位置和个数。
  My Liferay只能选择固定的栏目(column)布局,但可以在本栏目(column)内移动内容版块(content)的位置。
  My Yahoo只能选择固定的栏目(column)布局,而且不能移动内容版块(content)的位置。
  
  Portal的结构分为三层。
  (1) Page
  (2) Column,或者称为Pane
  (3) Content,或者称为Portlet
  
  我们来看看Portal的整个操作流程。
  (1) 每个Column的下方都有一个[Add Content]按钮,让用户选择加入自己喜欢的内容。
  从这里,我们知道,Portal系统里面有一个公用的Common Portlet Repository,供用户选用。
  
  JSR168 Portlet规范里面定义了Portlet Deployment Discriptor。Common Portlet Repository以这个Portlet Deployment Discriptor的格式存放。
  
  开源项目JetSpeed的XReg文件用来存放Common Portlet Repository的定义。
  
  (2) 加入Content之后,用户的Page和Column里面就多了这个Content。下次用户登陆的时候,就会看到自己订制的Portal版面。
  从这里,可以看出,Portal系统会纪录用户的个人Portal配置信息 – User Portal Config。
  
  开源项目JetSpeed的PSML文件用来存放User Portal Config的定义。
  
  ------- 综上。
  Add Content的整个流程为:
  Common Portlet Repository --> Add Content --> Personal Portal Config
  
  Display Portal的整个流程为:
  从Personal Portal Config读取用户配置的Portlet ID --> 根据Portlet ID,从Common Portlet Repository查找详细的Portlet定义 --> 根据这个详细的Portlet定义显示这个Portlet。
  
  2.Portal实现
  我们考虑如何用Java来实现Portal。
  
  2.1 Dynamic Include
  首先,我们采用最简单的思路,我们用100个JSP文件(1.jsp, 2.jsp, 3.jsp, … 100.jsp等),代表100个Portlet。
  用户页面MyPage.jsp包含用户选定的多个Portlet。
  现在,假设用户选取的Portlet为1.jsp, 3.jsp, 7.jsp等3个Portlet,那么我们如何在MyPage.jsp中显示这些Portlet?最直观的做法是,用jsp:include。比如:
  
  
  
  
  

  
  

  
  

  
  

  由于只能指定固定的jsp文件名,不能动态指定jsp文件名。我们需要把翻译为Java code – RequestDispatcher.include();
  下面我们换成这种写法。
  java代码:
  
  
  
  
  
  
  

  <% request.getRequestDispatcher(”1.jsp”).include(request, response); />
  

  <% request.getRequestDispatcher(”3.jsp”).include(request, response); />
  

  <% request.getRequestDispatcher(”7.jsp”).include(request, response); />
  

  
  
  
  进一步改进MyPage.jsp。
  java代码:
  
  
  <% String[] fileNames = {“1.jsp”, “3.jsp”, “7.jsp”}; %>
  
  <% for(int i = 0; i < fileNames.length; i++) {
   String fileName = fileName s[i]; %>
  
  <% } // end for %>
  

  <% request.getRequestDispatcher(fileName).include(request, response); />
  

  
  
  
  其中的fileNames的内容可以各种各样,只要RequestDispatcher能够处理。
  比如Velocity,fileNames = {“1.vm”, “3.vm”, “7.vm”};
  比如URL,fileNames = {“/portlet1.do”, “/portlet3.do”, “/portlet4.do”};
  我们可以看到,如果我们从用户配置中读取fileNames的内容,这就是一个简单的Portal实现。
  java代码:
  
  
  <% String[] fileNames = (String[])session.getAttribute(“portlets.config”); %>
  
  <% for(int i = 0; i < fileNames.length; i++) {
   String fileName = fileNames[i]; %>
  
  <% } // end for %>
  

  <% request.getRequestDispatcher(fileName).include(request, response); />
  

  
  
  
  2.2 Portlet Interface
  下面我们来扩展这个例子。
  假设每个Portlet都规定实现一个Portlet接口。
  java代码:
  
  
  interface Portlet {
   void render(request, response);
  };
  
  MyPage.jsp如下:
  
  <% String[] portletClassNames = (String[])session.getAttribute(“portlets.config”); %>
  
  <% for(int i = 0; i < portletClassNames.length; i++) {
   String className = portletClassNames[i];
   Portlet portlet = (Portlet)Class.forName(className).newInstance(); %>
  
  <% } // end for %>
  

  <% portlet. render (request, response); />
  

  
  Portlet类的示例代码如下:
  public class Portlet7{
   public void render(request, response){
   request.getRequestDispatcher(“7.jsp”).include(request, response);
   }
  };
  
  
  
  上述代码是Portal显示Portlet的核心流程的一个简化版本。
  JSR168 Portlet规范里面定义了真正的Portlet接口定义。
  
  2.3 Portlet Action
  Portlet的操作包括,最大化/最小化/恢复/关闭/编辑/帮助/上下移动,等等。
  这些操作都有对应的Action类。
  开源项目JetSpeed的module/actions/controls目录下面包含Maximize, Minimize, Close等Action类。
  开源项目Liferay的portal/action目录下面包含Maximize, Minimize, Close等Action类。
  
  Portal的操作不仅包括上述Portlet的操作,而且包括其它更高级别的操作。
  比如,Add/Move Page, Add/Move Column, 换Layout, 换Skin,之类。
  
  2.4 Portlet Cache
  我们操作Portlet的时候,往往只操作某个特定的Portlet,或者只是变化Portlet的位置。这时候,页面中大多数的Porlet的内容是不变的,只有一小块Portlet变化。
  我们需要把Portlet的内容缓存起来。Portlet接口有一个render(request, response)方法,我们可以订制定制response类,截获portlet的输出,保存到Portal系统的内容Cache当中。
  比如,前面提到liferay开源项目,其StringServletResponse类把Portlet的输出保存到一个String当中。
  
  http://forum.javaeye.com/viewtopic.php?t=5506&highlight=Portal
  http://forum.javaeye.com/viewtopic.php?t=4413&highlight=Portal
  http://forum.javaeye.com/viewtopic.php?t=4413&highlight=Portal
  http://forum.javaeye.com/viewtopic.php?t=5159&highlight=Portal
  
  欢迎应用、研究、实现Portal的程序员一起讨论研究Portal实现的原理,Patteren, Best Practice.
  
  
  
  主流企业门户应用性能评测
  http://www2.ccw.com.cn/04/0430/d/0430d31_1.asp
  
  几种Portal技术的比较与评述
  http://www.ccw.com.cn/cio/research/info/htm2004/20040813_13UNG.asp
  
  4款EIP软件评测揭晓
  http://www.zdnet.com.cn/bizstrategy/eb/tech/story/0,3800029745,39156043,00.htm
  
  How the portals scored
  http://www.infoworld.com/article/04/04/30/18FEportalbl_1.html
  
  Enterprise Portals Suites
  Portal Power
  http://www.networkcomputing.com/shared/article/printFullArticle.jhtml?articleID=18900467
---------------
jsr 168:
http://jcp.org/en/jsr/detail?id=168
---------------
转自 http://blog.tianya.cn/blogger/post_show.asp?BlogID=423541&PostID=5310210

你可能感兴趣的:(portlet 原理)