自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

liferay與portlet之間的通信

開發(fā) 后端
從我做Liferay到現(xiàn)在,這個問題一直都存在著,直到最近我才算是找到了一個可靠的方案,能夠滿足各種需求,從我最開始做到現(xiàn)在一共用到了四種方案,從低到高,我們一個一個的講。

從我做Liferay到現(xiàn)在,這個問題一直都存在著,直到最近我才算是找到了一個可靠的方案,能夠滿足各種需求,從我最開始做到現(xiàn)在一共用到了四種方案,從低到高,我們一個一個的講。

一、通過URL傳值

這個是我在項目中***次遇到這樣的問題,找出的一個方案,原理就是A把B需要的參數(shù)加在自已生成的URL后面,然后再把整個頁面view一次,B根據(jù)取得的參數(shù)再做相應的處理,取URL參數(shù)代碼如下:

Java代碼

 

 

  1. public class CurrentURLUtil {     
  2.     
  3. public static Log log = LogFactory.getLog(CurrentURLUtil.class);     
  4.     
  5. public static int contain(String currentURL, String param) {     
  6.     return currentURL.indexOf(param);     
  7. }     
  8.     
  9. public static String getString(String currentURL, String param) {     
  10.     
  11.     try {     
  12.         int paramIndex = contain(currentURL, param);     
  13.     
  14.         if (paramIndex == -1) {     
  15.             // log.warn("CurrentURL don't contain the parameter that name     
  16.             // is:"+param+",and method will return a blank");     
  17.             return "";     
  18.         } else {     
  19.             int afaterParamSperatorIndex = currentURL.indexOf("&", paramIndex+1);     
  20.     
  21.             if (afaterParamSperatorIndex == -1) {     
  22.                 return currentURL.substring(paramIndex + param.length() + 1);     
  23.             } else    
  24.                 return currentURL.substring(paramIndex + param.length() + 1,     
  25.                         afaterParamSperatorIndex);     
  26.         }     
  27.     } catch (RuntimeException e) {     
  28.         // TODO Auto-generated catch block     
  29.         return "";     
  30.     }     
  31. }     
  32.     
  33.     
  34. public static String getString(String currentURL, String param, String defaultStr) {     
  35.          
  36.     String value = getString(currentURL, param);     
  37.          
  38.     if(Validator.isNull(value))     
  39.         return defaultStr;     
  40.     else    
  41.         return value;     
  42.          
  43. }     
  44.     
  45. public static long getLong(String currentURL, String param) {     
  46.     String value = getString(currentURL, param);     
  47.     if (null == value || value.trim().equals("")) {     
  48.         return 0;     
  49.     } else if(Validator.isNumber(value))     
  50.         return Long.parseLong(value);     
  51.     else    
  52.         return 0;     
  53. }    

 

這種方法有比較多的缺陷,比如傳的參數(shù)只能是string,如果是map,list,大數(shù)據(jù)就不可行了,另外還有一個問題,安全性不高,你無法預料到這個頁面上有多少portlet,每個portlet會有多少操作,而每個操作都會產(chǎn)生一個url,會不會出現(xiàn)相同key?出錯的機率較高。

二、通過session傳值

這種方式和***種方式原理都是相同的,只不過要安全一些。A觸發(fā)一個action,在action里面把自已要處理的工作做完了后,把B需要的東西放在session里面,B在render里面去取這些東西,然后來完成自已的工作,或者就在JSP里面完成這些工作。但是這樣就出現(xiàn)了一個問題,你無法知道A先處理完還是B先處理完,解決的這個問題的方法有兩個,一個是讓B在處理之間等待一段時間,這個時間A一定能把工作完成,另外一個方法是用鎖的方式來解決,建一個static map,A負責開鎖,B負責鎖上,兩個千萬不能搞錯,當鎖為空或false時,B就去等侍,直到鎖打開。但是一定要記得在B處理完成后把鎖銷毀。這種方式,我也只在項目中用過一次。

三、通過模擬B的PortletURL

后面兩種方式也是我最近半年來才學會的,應該是安全的。先上一段代碼是模擬B的PortletURL的關(guān)鍵

Java代碼

 

 

  1. private static long _getPlidFromPortletId(HttpServletRequest request, long groupId,      
  2.             boolean isPrivate, String portletId, Entry... entry) {     
  3.              
  4.         long plid = 0;     
  5.         if (entry == null) {     
  6.             plid = PortalUtil.getPlidFromPortletId(groupId, isPrivate, portletId);     
  7.             if(Validator.isNull(plid))     
  8.                 plid = Long.valueOf(0);     
  9.         } else {     
  10.             try {     
  11.                 List layouts = LayoutLocalServiceUtil.getLayouts(groupId, isPrivate, LayoutConstants.TYPE_PORTLET);     
  12.                 for (Layout layout : layouts) {     
  13.                     LayoutTypePortlet layoutTypePortlet =     
  14.                         (LayoutTypePortlet)layout.getLayoutType();     
  15.     
  16.                     if (layoutTypePortlet.hasPortletId(portletId)) {     
  17.                         if (PortalUtil.getScopeGroupId(layout, portletId) == groupId) {     
  18.                             plid = layout.getPlid();     
  19.                                  
  20.                             List list = PortletPreferencesLocalServiceUtil     
  21.                                 .getPortletPreferences(plid, portletId);     
  22.                             if (Validator.isNotNull(list)) {     
  23.                                 for (PortletPreferences pre : list) {     
  24.                                          
  25.                                     int i = 0;     
  26.                                     if (entry.length < 1){     
  27.                                         plid = pre.getPlid();     
  28. //                                      _plidCache.put(key, plid);     
  29.                                         return plid;     
  30.                                     }     
  31.                                          
  32.                                     javax.portlet.PortletPreferences jpre = PortletPreferencesSerializer     
  33.                                             .fromXML(PortalUtil.getCompanyId(request), pre     
  34.                                                     .getOwnerId(), pre.getOwnerType(), plid,     
  35.                                                     portletId, pre.getPreferences());     
  36.                                     for (; i < entry.length; i++) {     
  37.                                         Entry en = entry[i];     
  38.                                         if (!jpre.getValue(en.getKey().toString(),     
  39.                                                 StringPool.BLANK).equals(     
  40.                                                 en.getValue().toString()))     
  41.                                             break;     
  42.                                     }     
  43.                                     if (i == entry.length){     
  44.                                         plid = pre.getPlid();     
  45. //                                      _plidCache.put(key, plid);     
  46.                                         return plid;     
  47.                                     }     
  48.                                 }     
  49.                             }     
  50.                         }     
  51.                     }     
  52.                 }     
  53.             } catch (SystemException e) {     
  54.                 // TODO Auto-generated catch block     
  55.                 e.printStackTrace();     
  56.             }     
  57.         }     
  58.         return plid;     
  59.     }     
  60.     
  61.     public static PortletURL getPortletURL(long groupId, String portletId,     
  62.             HttpServletRequest request, Entry... entry) {     
  63.     
  64.         long plid = _getPlidFromPortletId(request, groupId, false, portletId, entry);     
  65.         return new PortletURLImpl(request, portletId, plid,     
  66.                 PortletRequest.RENDER_PHASE);     
  67.     }     
  68.          
  69.     public static PortletURL getPortletURL(long groupId, long plid, String portletId,     
  70.             HttpServletRequest request, Entry... entry) {     
  71.         return new PortletURLImpl(request, portletId, plid,     
  72.                 PortletRequest.RENDER_PHASE);     
  73.     }    

 

根據(jù)上面代碼能看出,最關(guān)鍵是要取得plid,如果你兩個需要通信的portlet在一個頁面上,那就省了大事了,不然你就要去調(diào)用_getPlidFromPortletId這個,***一個參數(shù)是為了匹配這個portlet的configartion信息,因為一個網(wǎng)站有十幾個頁面,可能其中三個頁面會有這一個portlet,增加這個參數(shù)能提高準確性,但是影響性能。PortletURL得到了,那后面的事就好辦了,如果你是A只是為了傳信息本身不做任何處理,把參數(shù)放到PortletURL里,然后用就可以了,如果A要做完自已的工作再傳,那就以Action里面做完自已的工作,然后sendRedirect到PortletURL.toString()就可以了。這種方式應該是比較安全可靠的,并且我在幾個項目中都已經(jīng)實施過了。注意 :此方案僅能支持B屬性false的portlet

四、通過jQuery.ajax異步通信

這個是***的一個方案,目前正在進行的項目我用了這個方案,其基本思想是:A后臺通知B去工作,然后A前臺讓B顯示工作結(jié)果,這個方案比較酷。具體實現(xiàn)如下:

1.A通過jQuery.ajax去請求B的jsonAction(參照前面Liferay異步提交文章)

2.然后根據(jù)返回結(jié)果讓B顯示處理結(jié)果(參照前面Liferay異步刷新文章中的第二種類型)

注:如果你A也要處理工作,那就讓A先處理然后根據(jù)結(jié)果再調(diào)用B的jsonAction,***讓A和B都分別顯示各自的工作結(jié)果。當然你也可以把A和B要做的工作都放在一個jsonAction里面

【編輯推薦】

  1. 在Liferay中使用Hibernate
  2. Liferay Portal中的jBPM配置
  3. 開源Portal工具Liferay Portal 4.0發(fā)布
  4. hibernate中update與saveOrUpdate的區(qū)別
  5. Hibernate模糊查詢參數(shù)化的問題
責任編輯:金賀 來源: JavaEye博客
相關(guān)推薦

2009-11-23 20:10:31

ibmdwPortlet

2012-12-24 14:40:54

iosjs

2019-06-25 10:53:06

AndroidFlutter通信

2009-12-03 18:15:04

Linux

2011-08-31 13:22:37

PhoneGapAndroidjavascript

2012-12-21 09:19:29

Google GO

2009-06-25 16:49:24

Hibernate

2010-03-18 19:06:35

Java socket

2012-12-03 13:54:15

IBMdW

2021-11-08 07:48:50

管道流通信數(shù)據(jù)

2009-09-10 11:26:59

C# form

2009-06-23 15:49:00

Liferay Por

2018-10-11 05:07:19

物聯(lián)網(wǎng)通信IOT

2021-12-16 16:20:57

GoWebSocketLinux

2020-07-06 07:52:10

Kubernetes網(wǎng)絡(luò)通信

2016-09-14 21:44:50

JavascriptreactJsjsx

2009-11-04 15:54:20

Portlet入門企業(yè)門戶

2021-02-14 21:05:05

通信消息系統(tǒng)

2021-08-02 08:22:33

BlazorEventCallba通信

2012-05-31 14:54:59

Hadoop大數(shù)據(jù)
點贊
收藏

51CTO技術(shù)棧公眾號