<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Terry.Li-彬

    虛其心,可解天下之問;專其心,可治天下之學;靜其心,可悟天下之理;恒其心,可成天下之業。

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      143 隨筆 :: 344 文章 :: 130 評論 :: 0 Trackbacks
     

    先前的文章提到/c/*的請求都是交給MainServlet處理的,現在分析對于不同的/c/*,例如/c/layout或者/c/update_layout等請求是怎么傳遞到不同的action去的呢。

    下面以顯示 Add Content 為例進行分析,Add Content 窗口其實是一個在 portlet-custom.xml 中定義的名為87的portlet。點擊Add Content鏈接會產生一個Reqest,開始整個處理的流程。

    1. Request的生成。

    當時頁面的源文件中有關的代碼為:
    <li class="add-content">
    <a href="javascript: void(0);" onclick="LayoutConfiguration.toggle('10102', '87', '');">Add Content</a>
    </li>

    點擊add content調用的是LayoutConfiguration.toogle()。

    layout_configuratioin.js
    var LayoutConfiguration = {
      toggle : function (plid, ppid, doAsUserId) {
      var url = themeDisplay.getPathMain() + "/portal/render_portlet?p_l_id=" + plid + "&p_p_id=" +ppid + "&doAsUserId=" + doAsUserId + "&p_p_state=exclusive";
      AjaxUtil.update(url, popup, {onComplete: function(){
                   LayoutConfiguration.init();
                   Liferay.Util.addInputType();
                   Liferay.Util.addInputFocus();}
      });};
      /*總之是會生成一個Ajax請求發送到服務器,過程以后可以分析 */

    用Wireshark捕捉到的Request數據如下,知道請求中含有/c/portal/render_portlet字段,那自然會送入 MainServlet處理了。

    2. MainServlet.service()

    /* 這里是Request首先到達的地方*/

    ServletContext ctx = getServletContext();
    req.setAttribute(WebKeys.CTX, ctx);
    PortletRequestProcessor portletReqProcessor = PortletRequestProcessor.getInstance(this, moduleConfig);
    ctx.setAttribute(WebKeys.PORTLET_STRUTS_PROCESSOR, portletReqProcessor);
    callParentService(req, res);
    /* 調用ActionServlet.service(),由于在ActionServlet中沒有覆蓋service方法,所以 MainServlet 的super.service() 追溯到HttpServlet 的service方法 */

    3. HttpServlet.service()

    if (method.equals(METHOD_GET)) { ,,,
    } else if (method.equals(METHOD_POST)) {
      doPost(req, resp);
    } else if (method.equals(METHOD_PUT)) {
      doPut(req, resp); 
    } else if (method.equals(METHOD_DELETE)) {
      doDelete(req, resp);
    } else if (method.equals(METHOD_OPTIONS)) {
      doOptions(req,resp);
    } else if (method.equals(METHOD_TRACE)) {
      doTrace(req,resp);
    }

    /* 在 service 中,根據http的類型,分別調用 doPost, doGet, doPut, ...,由于ActionServlet中實現了doPost等方法,所以MainServlet.service()方法會傳遞到 ActionServlet中的doPost等方法。*/

    4. ActionServlet.doPost()

    process(request, response);

    /* 在另外ActionServlet的不同方法中,例如doGet(),doPut(),都調用了process()方法。*/


    5. ActionServlet.process()

    ModuleConfig config = getModuleConfig(request);
    RequestProcessor processor = getProcessorForModule(config);
    if (processor == null) {
      processor = getRequestProcessor(config);
    }
    processor.process(request, response);

    /* 最終傳遞到對應的Request Processor 的process()方法中去,也就是PortalRequestProcessor.process() */


    6. PortalRequestProcessor.process()

    public void process(HttpServletRequest req, HttpServletResponse res)
      throws IOException, ServletException {
      String path = super.processPath(req, res); //path = “/portal/render_portlet”
      ActionMapping mapping = (ActionMapping)moduleConfig.findActionconfig(path);
      super.process(req, res);
      /*由于TilesRequestProcessor中沒有定義process()方法,所以調用 RequestProcessor.process() */
    }


    7. RequestProcessor.process()

    public void process(HttpServletRequest request, HttpServletResponse response)
      throws IOException, ServletException {

      String path = processPath(request, response);
      //這里path = “/portal/render_portlet”.

      ActionMapping mapping = processMapping(request, response, path);
      //這里找到在struts-config.xml中定義的關于上面path的mapping.

      Action action = processActionCreate(request, response, mapping);
      //這里生成了RenderPortletAction.

      ActionForward forward = processActionPerform(request, response, action, form, mapping);

      processForwardConfig(request, response, forward);
    }

    至此,每個由 MainServlet 傳遞來的 Request 都能到達對應的 Action,例如 LayoutAction,RenderPortletAction,UpdateLayoutAction,由這些 Action 最終完成 Layout 和 Portlet 的呈現。這里對應的action是RenderPortletAction(由下面的struts-config.xml中定義)。

    下面以RenderPortletAction為例說明進一步的action過程。在struts-config.xml這個文件中定義了action class, forward path。

    <action path="/portal/layout" type="com.liferay.portal.action.LayoutAction">
      <forward name="portal.layout" path="portal.layout" />
    </action>

    <action path="/portal/update_layout" type="com.liferay.portal.action.UpdateLayoutAction" />

    <action path=“/portal/render_portlet” type=“com.liferay.portal.action.RenderPortletAction”>
      <forward name=“/portal/render_portlet” path=“/portal/render_portlet.jsp”/>
    </action>
    <!-- 這里定義了由RenderPortletAction來處理”/portal/render_portlet”,而且最后要forward到” /portal/render_portlet.jsp”。所以最后會把render_portlet.jsp包含到response的頁面當中-- >

    那render_portlet.jsp又是如何實現最終把add content這個portlet顯示出來的呢,下回接著分析。


     

    Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=2177383

    posted on 2008-03-14 14:12 禮物 閱讀(1170) 評論(0)  編輯  收藏 所屬分類: Liferay
    主站蜘蛛池模板: 免费一区二区无码东京热| 免费人成大片在线观看播放| 国内精品一级毛片免费看| 亚洲综合色成在线播放| 一区二区三区在线免费观看视频| 妞干网手机免费视频| 亚洲av无码日韩av无码网站冲| 暖暖免费高清日本一区二区三区| 亚洲av日韩精品久久久久久a| 狼友av永久网站免费观看 | 亚洲精品成人网站在线播放| 在线看无码的免费网站| 国产亚洲sss在线播放| 妞干网在线免费观看| 免费人成动漫在线播放r18| 久久久久亚洲AV无码专区网站| a级毛片免费在线观看| 亚洲国产精品lv| 三年片在线观看免费大全| 激情无码亚洲一区二区三区 | 妞干网免费视频在线观看| 美女被爆羞羞网站免费| 国产亚洲一区二区三区在线| 在线观看免费中文视频| 亚洲1区2区3区精华液| 亚洲精品自产拍在线观看| 2021久久精品免费观看| 国产亚洲综合一区二区三区| 亚洲精品制服丝袜四区| 国产精品色拉拉免费看| 香港一级毛片免费看| 亚洲网站在线观看| 免费观看四虎精品国产永久| 国产免费一区二区视频| avtt天堂网手机版亚洲| 国产精品亚洲mnbav网站| 3344免费播放观看视频| 日韩成人毛片高清视频免费看| 亚洲短视频男人的影院| 四虎永久在线精品免费影视| 嫩草在线视频www免费观看|