深入浅出Liferay Portal (13)

本文介绍如何在Liferay Portal中定制Action,包括分析现有Action、新增自定义Action及测试过程。通过具体实例展示了如何创建并部署AjaxPollingAction。

1. 已有的Action分析

观察Liferay Portal的源代码,可看到其中有一个目录为"portal-impl",进一步浏览到"portal-impl/src/com/liferay/portal/action",发现其中有一些重要的Action实现的源文件,如:LayoutAction.java, UpdateLayoutAction.java, RenderPortletAction.java。前面我们分析过这几个Action的重要性。诸如"/c/portal/update_layout", "/c/portal/render_portlet"等URL请求会经过MainServlet分发到这几个Action。其中关联的定义是在struts-config.xml中定义的,例如:

<action path="/portal/render_portlet" type="com.liferay.portal.action.RenderPortletAction">
    <forward name="/portal/render_portlet" path="/portal/render_portlet.jsp" />
</action>

2. 增加新的Action

利用我们前面已经生成过的EXT开发环境,对Liferay Portal系统进行定制。浏览到"ext/ext-impl/src/com/ext",其中已有portlet目录,存放需要定制的portlet。在这个".../com/ext"目录下创建一个"/portal/action"子目录,在这个子目录中创建一个需要实现的Action的java文件,例如:AjaxPollingAction.java。内容如下:

package com.ext.portal.action;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;


public class AjaxPollingAction extends Action {
 public ActionForward execute(
  ActionMapping mapping, ActionForm form, HttpServletRequest req,
   HttpServletResponse res) throws Exception {
  return null;
  //或者经过进一步的处理传递到某个view jsp页面
  //return mapping.findForward("portal.layout");
 }
}

这个AjaxPollingAction.java文件会在后面deploy到tomcat过程中自动编译打包。

另外需要到struts-config.xml中增加一项action-mapping内容,好让MainServlet能够更具这项mapping将Request转发到AjaxPollingAction。除了已有的Reports的mapping外,内容如下:

<action path="/portal/ajax_polling" type="com.ext.portal.action.AjaxPollingAction" />

<!-- 如果需要传递到jsp,则还需要定义
 <forward name="portal.ajax_polling" path="portal.ajax_polling" />
        然后到tiles-defs.xml中定义path到jsp文件
-->

然后到EXT目录下运行 ant clean deploy。经过若干秒钟后,EXT下的webapp就配置到了Tomcat中去,可以进行测试了。

3. 测试

找一段一定会在Portal上显示的HTML代码,加入下面的测试代码。随后点击"Start Ajax Polling",就会弹出一个空的对话框,说明AjaxPollingAction的确被调用到了。

<script type="text/javascript">
var ajaxPolling = function startAjaxPolling() {
 var url = "/c/portal/ajax_polling";
 if (window.XMLHttpRequest) {
  req = new XMLHttpRequest();
 }else if (window.ActiveXObject){
  req = new ActiveXObject("Microsoft.XMLHTTP");
 }

 if(req){
  alert("going to send Ajax Request");
  req.open("GET",url, true);
  req.onreadystatechange = complete;
  req.send(null);
 }
}

function complete(){
 if (req.readyState == 4) {
  if (req.status == 200) {
   alert(req.responseText);
  }
 }
}

</script>

<a href="javascript:startAjaxPolling();"> Start Ajax Polling </a>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值