中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

liferay與portlet之間如何通信

發布時間:2021-12-27 13:54:16 來源:億速云 閱讀:138 作者:小新 欄目:編程語言

這篇文章主要介紹了liferay與portlet之間如何通信,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一、通過URL傳值

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

Java代碼

public class CurrentURLUtil {         public static Log log = LogFactory.getLog(CurrentURLUtil.class);         public static int contain(String currentURL, String param) {         return currentURL.indexOf(param);     }         public static String getString(String currentURL, String param) {             try {             int paramIndex = contain(currentURL, param);                 if (paramIndex == -1) {                 // log.warn("CurrentURL don't contain the parameter that name                 // is:"+param+",and method will return a blank");                 return "";             } else {                 int afaterParamSperatorIndex = currentURL.indexOf("&", paramIndex+1);                     if (afaterParamSperatorIndex == -1) {                     return currentURL.substring(paramIndex + param.length() + 1);                 } else                    return currentURL.substring(paramIndex + param.length() + 1,                             afaterParamSperatorIndex);             }         } catch (RuntimeException e) {             // TODO Auto-generated catch block             return "";         }     }             public static String getString(String currentURL, String param, String defaultStr) {                  String value = getString(currentURL, param);                  if(Validator.isNull(value))             return defaultStr;         else            return value;              }         public static long getLong(String currentURL, String param) {         String value = getString(currentURL, param);         if (null == value || value.trim().equals("")) {             return 0;         } else if(Validator.isNumber(value))             return Long.parseLong(value);         else            return 0;     }

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

二、通過session傳值

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

三、通過模擬B的PortletURL

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

Java代碼

private static long _getPlidFromPortletId(HttpServletRequest request, long groupId,                  boolean isPrivate, String portletId, Entry... entry) {                          long plid = 0;             if (entry == null) {                 plid = PortalUtil.getPlidFromPortletId(groupId, isPrivate, portletId);                 if(Validator.isNull(plid))                     plid = Long.valueOf(0);             } else {                 try {                     List layouts = LayoutLocalServiceUtil.getLayouts(groupId, isPrivate, LayoutConstants.TYPE_PORTLET);                     for (Layout layout : layouts) {                         LayoutTypePortlet layoutTypePortlet =                             (LayoutTypePortlet)layout.getLayoutType();                             if (layoutTypePortlet.hasPortletId(portletId)) {                             if (PortalUtil.getScopeGroupId(layout, portletId) == groupId) {                                 plid = layout.getPlid();                                                                  List list = PortletPreferencesLocalServiceUtil                                     .getPortletPreferences(plid, portletId);                                 if (Validator.isNotNull(list)) {                                     for (PortletPreferences pre : list) {                                                                                  int i = 0;                                         if (entry.length < 1){                                             plid = pre.getPlid();     //                                      _plidCache.put(key, plid);                                             return plid;                                         }                                                                                  javax.portlet.PortletPreferences jpre = PortletPreferencesSerializer                                                 .fromXML(PortalUtil.getCompanyId(request), pre                                                         .getOwnerId(), pre.getOwnerType(), plid,                                                         portletId, pre.getPreferences());                                         for (; i < entry.length; i++) {                                             Entry en = entry[i];                                             if (!jpre.getValue(en.getKey().toString(),                                                     StringPool.BLANK).equals(                                                     en.getValue().toString()))                                                 break;                                         }                                         if (i == entry.length){                                             plid = pre.getPlid();     //                                      _plidCache.put(key, plid);                                             return plid;                                         }                                     }                                 }                             }                         }                     }                 } catch (SystemException e) {                     // TODO Auto-generated catch block                     e.printStackTrace();                 }             }             return plid;         }             public static PortletURL getPortletURL(long groupId, String portletId,                 HttpServletRequest request, Entry... entry) {                 long plid = _getPlidFromPortletId(request, groupId, false, portletId, entry);             return new PortletURLImpl(request, portletId, plid,                     PortletRequest.RENDER_PHASE);         }                  public static PortletURL getPortletURL(long groupId, long plid, String portletId,                 HttpServletRequest request, Entry... entry) {             return new PortletURLImpl(request, portletId, plid,                     PortletRequest.RENDER_PHASE);         }

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

四、通過jQuery.ajax異步通信

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

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

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

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

感謝你能夠認真閱讀完這篇文章,希望小編分享的“liferay與portlet之間如何通信”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

正蓝旗| 灵璧县| 英吉沙县| 新晃| 阿拉善左旗| 浦东新区| 沙雅县| 无为县| 陇西县| 墨竹工卡县| 平塘县| 五大连池市| 辽中县| 晋宁县| 互助| 香河县| 安陆市| 哈巴河县| 奉贤区| 鄱阳县| 许昌县| 三穗县| 张掖市| 武清区| 临猗县| 赞皇县| 旬阳县| 龙州县| 杨浦区| 兴海县| 卢氏县| 环江| 海南省| 金坛市| 望都县| 高雄市| 宜宾县| 汝州市| 吐鲁番市| 武夷山市| 梓潼县|