Liferay Portal系統(tǒng)架構點滴原文地址: http://www.liferay.com/web/guest/documentation/architecture目錄Liferay Portal系統(tǒng)架構點滴?1目錄?1I、綜述?1II、Portlet 應用接口(JSP168)?2III、Struts 和 Tiles?2IV、Session EJBs、Spring和Hibernate?3V、SAOP、RMI和Tunneling?5VI 應用服務器?6
I、綜述用戶可以通過傳統(tǒng)的或者無線網(wǎng)絡的方式訪問portal。開發(fā)者可以通過SOAP、RMI和自己定義的通道類訪問暴露的API來操作portal。?II、Portlet 應用接口(JSP168)Liferay設計成為部署符合(JSP168)Portlet 應用接口的Portlet。很多有用的Portlet(比如郵件、Liferay文檔、日立、公告版和其他)已經(jīng)跟portal綁定,而且可以作為添加自定義的Portlet的范例。III、Struts 和 Tiles所有的HTTP和WAP請求都通過MainServlet響應,MailServlet擴展了Struts基類ActionServlet。 MainServlet處理所有的請求,使得每個請求都路由到合適的PortletAction。 想要更好的理解portal的web框架請參考Struts。Portal的布局信息通過定制的模板管理。想要更好的理解Tiles如何管理布局的,請參考Tile的相關文章。IV、Session EJBs、Spring和HibernateLiferay不再依賴EBJ,可以部署在標準的servlet容器中。所有的業(yè)務邏輯都集中在可以被Spring查找和實例化的POJO實現(xiàn)中。這些實現(xiàn)都可以通過Spring的AOP和IOC修改或者強化。Portal 企業(yè)版使用Session EJB包裝POJO實現(xiàn),以為大型網(wǎng)站提供所需的重量級擴展和事務支持。Portal 專業(yè)版調用POJO實現(xiàn)以提供輕量級的一致的外觀(fa?ade)。所有的數(shù)據(jù)都使用Hibernate持久化,供POJO實現(xiàn)調用。 Liferay原來使用CMP技術構建持久化, 因為Hibernate優(yōu)秀的速度和彈性而轉換為Hibernate。 Liferay不依賴特定的數(shù)據(jù)庫,可以在多種流行的數(shù)據(jù)庫上運行。Liferay使用JAAS Web安全機制,當用戶登錄的時候,他們的信息會被傳送到相應的Servlet和EJB節(jié)點。遠程的Session EJB可以利用這一點,在EJB層級確認安全性和授權,防止它在其他地方被復制。本地Session EJB向其他Session EJB暴露業(yè)務邏輯,不需要明確的確認安全性,因為它們不會被遠程調用。信息也會被傳送到作為遠程Session EJB基礎類的POJO實現(xiàn)上。企業(yè)版使用Session EJB,允許部署者將Web服務器、EJB服務器、數(shù)據(jù)庫服務器分開,構建三層的架構。這是真正的N層部署,因為沒有人再關注單層的群,而且可以為大企業(yè)提供最大程度的彈性。大部分的EJB、HBM和Model都是用/portal-ejb目錄下service。xml中的ant任務build-service生成的。每個持久化數(shù)據(jù)的Portlet都有自己的service。xml。(搜索/portal-ejb目錄,你就可以得到一個列表)。當我們想要為portlet產(chǎn)生持久類的時候就可以復制這些文件到/portal-ejb目錄。這是一個構建在Xdoclet引擎上面的內(nèi)部工具。比如,在讀取Bookmarks Portlet的service。xml時,下列模型類被生成。每個模型類映射數(shù)據(jù)庫中的一個表。不要編輯BookmarksEntryModel,要通過編輯BookmarksEntry來增加手工維護的代碼。BookmarksEntry一次性生成,擴展了BookmarksEntryModel。這樣允許我們輕松的生成代碼,而且具備手工維護的彈性。com.liferay.portlet.bookmarks.model.BookmarksEntrycom.liferay.portlet.bookmarks.model.BookmarksEntryModelcom.liferay.portlet.bookmarks.model.BookmarksFoldercom.liferay.portlet.bookmarks.model.BookmarksFolderModelHibernate類生成針對各個模型類的映射。這樣當模型類跨層配置而Hibernate不是的時候允許一個N層的架構。com.liferay.portlet.bookmarks.service.persistence.BookmarksEntryHBMcom.liferay.portlet.bookmarks.service.persistence.BookmarksFolderHBM添加、更新、刪除、查找、移動和計算Hibernate entries的持久方法作為默認的持久化機制被生成。com.liferay.portlet.bookmarks.service.persistence.BookmarksEntryPersistencecom.liferay.portlet.bookmarks.service.persistence.BookmarksFolderPersistence生成的幫助類調用持久化方法。默認的,幫助類調用Hibernate持久化方法來更新數(shù)據(jù)庫。你可以在portal。properties中重寫,而且只要擴展了默認的持久化類就可以設置自己的持久化類。這意味著可以自定義在哪里保存你的數(shù)據(jù)。它可以是一個傳統(tǒng)的數(shù)據(jù)庫,或者LDAP服務器,或者其他。com.liferay.portlet.bookmarks.service.persistence.BookmarksEntryUtilcom.liferay.portlet.bookmarks.service.persistence.BookmarksFolderUtil池類也被創(chuàng)建成最小的對象,行為也可以在portal。properties中修改。com.liferay.portlet.bookmarks.service.persistence.BookmarksEntryPoolcom.liferay.portlet.bookmarks.service.persistence.BookmarksFolderPool擴展了PrincipalBean的POJO實現(xiàn)持有業(yè)務邏輯,確認調用者信息,可以被遠程調用。調用getUserId()返回當前用戶id。調用getUser()返回代表當前用戶的用戶模型。擴展POJO實現(xiàn)的Session EJB實現(xiàn)了PrincipalSessionBean。比如,這些類允許你刪除一個書簽入口或者文件夾,當且僅當你是這個入口或者文件夾的創(chuàng)建者。這些類只有在它們不存在的時候才能被生成。com.liferay.portlet.bookmarks.service.impl.BookmarksEntryServiceImplcom.liferay.portlet.bookmarks.service.impl.BookmarksFolderServiceImpl幫助類是基于POJO實現(xiàn)生成的。它們幫助保存開發(fā)者的時間和顯示錯誤(polluted)的代碼。與其寫好幾行代碼來尋找合適的Session EJB包裝或者POJO實現(xiàn),你可以簡單的使用BookmarksEntryServiceUril。addEntry來調用BookmarksEntryServiceImpl。addEntry中的等價方法。BookmarksEntryServiceUril 調用BookmarksFolderServiceFactory來查找實現(xiàn)BookmarksEntryService的類。BookmarksFolderServicesFactory根據(jù)Spring和portal。properties的配置來決定是否加載Session EJB包裝或者POJO實現(xiàn)。Session EJB擴展了POJO實現(xiàn)。com.liferay.portlet.bookmarks.service.ejb.BookmarksEntryServiceEJBcom.liferay.portlet.bookmarks.service.ejb.BookmarksEntryServiceEJBImplcom.liferay.portlet.bookmarks.service.ejb.BookmarksEntryServiceHome
com.liferay.portlet.bookmarks.service.spring.BookmarksEntryServicecom.liferay.portlet.bookmarks.service.spring.BookmarksEntryServiceFactorycom.liferay.portlet.bookmarks.service.spring.BookmarksEntryServiceUtil
com.liferay.portlet.bookmarks.service.ejb.BookmarksFolderServiceEJBcom.liferay.portlet.bookmarks.service.ejb.BookmarksFolderServiceEJBImplcom.liferay.portlet.bookmarks.service.ejb.BookmarksFolderServiceHome
com。Liferay.portlet.bookmarks.service.spring.BookmarksFolderServicecom。Liferay.portlet.bookmarks.service.spring.BookmarksFolderServiceFactorycom。Liferay.portlet.bookmarks.service.spring.BookmarksFolderServiceUtil通道(Tunneling)類使得開發(fā)者可以通過80端口調用POJO實現(xiàn)。本文檔的V部分針對這個給出了一個例子。com.liferay.portlet.bookmarks.service.http.BookmarksEntryServiceHttpcom.liferay.portlet.bookmarks.service.http.BookmarksFolderServiceHttpSoap類被生成,以便開發(fā)者通過80端口調用POJO實現(xiàn)。Soap比通道(tunneling)慢,因為tunneling請求流是二進制格式的。Soap比tunneling靈活,因為客戶端類不局限于Java。com.liferay.portlet.bookmarks.service.http.BookmarksEntryServiceSoapcom.liferay.portlet.bookmarks.service.http.BookmarksFolderServiceSoap沒有擴展PrincipalBean的POJO實現(xiàn)類用來持有業(yè)務邏輯,不用確認調用者的信息,可以被本地調用。這些類的存在使得業(yè)務邏輯可以很容易的被其他工程集成。這些類只有在先前不存在的情況下才會被生成。com.liferay.portlet.bookmarks.service.impl.BookmarksEntryLocalServiceImplcom.liferay.portlet.bookmarks.service.impl.BookmarksFolderLocalServiceImpl幫助類也一并生成。com.liferay.portlet.bookmarks.service.ejb.BookmarksEntryLocalServiceEJBcom.liferay.portlet.bookmarks.service.ejb.BookmarksEntryLocalServiceEJBImplcom.liferay.portlet.bookmarks.service.ejb.BookmarksEntryLocalServiceHome
com.liferay.portlet.bookmarks.service.spring.BookmarksEntryLocalServicecom.liferay.portlet.bookmarks.service.spring.BookmarksEntryLocalServiceFactorycom.liferay.portlet.bookmarks.service.spring.BookmarksEntryLocalServiceUtil
com.liferay.portlet.bookmarks.service.ejb.BookmarksFolderLocalServiceEJBcom.liferay.portlet.bookmarks.service.ejb.BookmarksFolderLocalServiceEJBImplcom.liferay.portlet.bookmarks.service.ejb.BookmarksFolderLocalServiceHome
com.liferay.portlet.bookmarks.service.spring.BookmarksFolderLocalServicecom.liferay.portlet.bookmarks.service.spring.BookmarksFolderLocalServiceFactorycom.liferay.portlet.bookmarks.service.spring.BookmarksFolderLocalServiceUtil有一些用戶需要遠程調用本地的Service類,所以遠程Service類的本地副本也一并被生成。com.liferay.portlet.bookmarks.service.ejb.BookmarksEntryRemoteServiceEJBcom.liferay.portlet.bookmarks.service.ejb.BookmarksEntryRemoteServiceEJBImplcom.liferay.portlet.bookmarks.service.ejb.BookmarksEntryRemoteServiceHome
com.liferay.portlet.bookmarks.service.spring.BookmarksEntryRemoteServicecom.liferay.portlet.bookmarks.service.spring.BookmarksEntryRemoteServiceFactorycom.liferay.portlet.bookmarks.service.spring.BookmarksEntryRemoteServiceUtil
com.liferay.portlet.bookmarks.service.ejb.BookmarksFolderRemoteServiceEJBcom.liferay.portlet.bookmarks.service.ejb.BookmarksFolderRemoteServiceEJBImplcom.liferay.portlet.bookmarks.service.ejb.BookmarksFolderRemoteServiceHome
com.liferay.portlet.bookmarks.service.spring.BookmarksFolderRemoteServicecom.liferay.portlet.bookmarks.service.spring.BookmarksFolderRemoteServiceFactorycom.liferay.portlet.bookmarks.service.spring.BookmarksFolderRemoteServiceUtil很多人刻意避免Session EJB因為它很重和需要大量的編碼。我們的構建腳本證明你可以在復用中保持Session EBJ的優(yōu)勢,這樣可以在付出和回報上保持很好平衡。Spring給予Liferay額外的彈性。 開發(fā)者利用Liferay Portal,可以在一個Servlet容器中測試他們的POJO實現(xiàn);而利用Liferay Portal企業(yè)版,可以在一個應用服務器部署成產(chǎn)品。V、SAOP、RMI和Tunneling所有的遠程POJO實現(xiàn)都通過SOAP、RMI和我們自己的通道(Tunneling)類暴露給外部世界。我們并不是簡單的這樣做因為Web Service還是一個困頓(buzz)的世界,但是我們發(fā)現(xiàn)它確實對集成有用。接下來是一個公司平衡這些資源的例子。3 sixteen是一家將快速創(chuàng)建和運作的T恤公司。他們看到Liferay,想利用集成的購物 portlet。但是他們認為Liferay作為一個處于時尚前沿的T恤公司站點太難看了。為了解決這個問題,他們決定將他們的網(wǎng)站分為兩個站點:一個手冊站點和一個購物站點。www。3sixteen。com 成為一個構建在Flash上面的漂亮的站點。my。3sixteen。com則是使用Liferay分發(fā)的購物站點。這兩個站點分別放在不同的Linux系統(tǒng)主機上,所有的目的放在不同的宿主上。他們還需要構建一個郵件列表來收集所有感興趣的客戶的郵件地址。為實現(xiàn)這個,他們再Flash站點增加了一個JSP彈出窗口(pop up box),這樣可以告訴Portal服務器在Address Book Portlet中將郵件地址增加到聯(lián)系列表(contact)。下面是一個JSP片斷,顯示3sixteen的用戶如何利用ABContactServiceHttp增加一個聯(lián)系列表。?ABContactServiceHttp調用ABContactServiceUtil的addContact。這個調用通過80端口發(fā)送,被http://my。3sixteen。com/tunnel/servlet/AuthTunnelServlet接收。應用服務器確認認證匹配,然后處理ABContactServiceUtil,就好像ID為joe_bloggs的用戶在調用addContact。然后ABContactServiceUtil調用ABContactServiceImpl來完成實際工作。你可以通過查看JavaDocs里面的源代碼來查看這個邏輯。現(xiàn)在Joe Bloggs可以登錄到portal,在Address Book portlet可以看到他已經(jīng)有一個新的聯(lián)系列表。所有被包含的portlet都有這個性能因為這些幫助類已經(jīng)生成。這意味著你可以撰寫applet或者任何Java應用來操作那些包含你的業(yè)務邏輯的Session EJB。假如有人持有你的密碼那么這會是一個安全問題,所以你可以通過修改配置文件portal。properties來限制通道(Tunnel)Servlet只監(jiān)聽特定的端口。你也可以通過SOAP和RMI操作Session EJB。我們將盡快提交更多這方面的例子。VI 應用服務器Liferay是從底層構建的,可以被應用服務器所用。下面是一個Portal例子列表,顯示portal連接數(shù)據(jù)庫以及展示Liferay的性能。http://demo.liferay.nethttp://my.ccuc.nethttp://my.3sixteen.comhttp://portal.liferay.comhttp://www.gatewayfriends.orghttp://www.jasonandiris.com每個Portal中的用戶在其他Portal中沒有信息保留。他們用域名分隔開,根據(jù)公司編號存在于各自的空間內(nèi)。查看Multiple Portal獲取細節(jié)信息,了解如何在一臺機器上部署多個Portal實例。
作者 : eamoi @ Aljoin SoftwareDev2dev ID: educhina Blog地址:http://spaces.msn.com/members/eamoi/http://blog.sina.com.cn/u/1183534285http://www.aygfsteel.com/eamoi/
進日有臺灣的朋友反映《Ajax開發(fā)精要》繁體版源碼無法下載,經(jīng)核實,繁體版的下載地址正確為:http://www.pcuser.com.tw/download/2AI109/code.zip ,也可以從本站下載:http://www.aygfsteel.com/Files/eamoi/tran-code.zip 。由此給您帶來的不便,還請見諒。
轉載本站文章,請保留原始鏈接和署名,尊重原作者的勞動成果。
對Ajax應用有疑問的朋友,可以在“Ajax應用問題匯總”帖中跟帖。建議大家一起研究,促進國內(nèi)Ajax應用的開展。
關于Portal的問題,朋友們可以到QQ群13097018咨詢。由于工作關系,我經(jīng)常不能及時回答問題。還請見諒。
個人簡介
工作地點:福建廈門研究方向:J2EE、Web系統(tǒng)設計、企業(yè)運算聯(lián)系電郵:eamoi@163.com