Liferay 6.2 portlet中的Ajax调用

时间:2014-08-06 12:46:17

标签: ajax liferay alloy-ui liferay-aui

我是Liferay的初学者,我想做一个ajax电话。我正在做的是: - 我有一个按钮在jsp页面中进行ajax调用 变量在javascript代码中初始化,并在每次用户单击按钮时递增。此变量将传输到服务器以用作函数的参数。

代码段

aui_ajax.jsp:

<input type="button" value = "Ajouter un projet" onClick="<portlet:namespace/>Test();return false;">
<div id="usersTable">
  <input type="button" value = "Ajouter un projet" onClick="   <portlet:namespace/>Test();return false;">
</div>
<div id="wait" style="display:none; width: 69px; height: 89px; border: 1px solid black; position: absolute; top: 50%; left: 50%; padding: 2px;">
 <img src='http://www.w3schools.com/jquery/demo_wait.gif' width="64" height="64" />  <br>Loading..
</div>

<script>
var i=1

function <portlet:namespace/>Test() {
    var i=1;
    AUI().use('aui-base','aui-io-request', function(A){
        i++;
        A.one('#wait').setStyle('display', 'block');
        var allRows=A.one('#usersTable').getHTML();

        var querystring = 'message:' + '1';

        //aui ajax call to get updated content
        A.io.request('<%=updaContentURL%>',{
        dataType: 'json',
        method: 'GET',
        data: querystring,
        on: {
             success: function() {
                var data=this.get('responseData');
                A.Array.each(data, function(obj, idx){


                    var tableRow=obj.firstName;
                    //allRows=allRows.trim()+tableRow.trim();



                    //A.one('#usersTable').empty();
                    //A.one('#usersTable').setHTML(tableRow.trim());
                  A.one('#usersTable').append(tableRow.trim());

                    A.one('#wait').setStyle('display','none');
                });
            }
        }
        });
        });
  }
</script>

ContentAutoUpdateAction.java

public class ContentAutoUpdateAction extends MVCPortlet {


public void serveResource(ResourceRequest resourceRequest,
        ResourceResponse resourceResponse)
    throws  IOException, PortletException {

    try {
        System.out.println("====serveResource========");
        JSONObject jsonUser=null;
        JSONArray usersJsonArray=JSONFactoryUtil.createJSONArray();

        resourceRequest.getParameter("message");
        int i=Integer.parseInt(message);    
        i++;
        System.out.println(i);



        //}
        PrintWriter out=resourceResponse.getWriter();
        System.out.println(usersJsonArray.toString());
        out.print(usersJsonArray.toString());
    }
    catch (Exception e) {
        e.printStackTrace();
    }
}

问题是我无法在ContentAutoUpdateAction.java中获取参数“message”

3 个答案:

答案 0 :(得分:1)

虽然一个老问题但想回答。

您必须为portlet启用ajax。

<ajaxable>true</ajaxable>

在liferay-portlet.xml中

其次,您可以使用

在ajax中传递参数
data: {
paramName1: paramValue,
paramName2: paramValue2
}

如果要将其连接为查询字符串,则可以使用

var ajaxURL = "<portlet:resourceURL/>";
ajaxURL = ajaxURL + "&message=1";

然后使用ajaxURL作为ajax请求的url。

答案 1 :(得分:0)

我听到的信息是这是一个已知的错误。 我知道一个解决方法:

HttpServletRequest httpReq = PortalUtil.getHttpServletRequest(resourceRequest);

param = PortalUtil.getOriginalServletRequest(httpReq).getParameter("name");

希望它有所帮助。

答案 2 :(得分:0)

不确定:

var querystring = 'message:' + '1';

您正在构建GET请求字符串,因此我将其更改为:

var querystring = '&message=' + '1';

此外,这不是将参数传递给ajax请求的唯一方法,您也可以尝试这种方式:

A.io.request('<%=updaContentURL%>',{
        dataType: 'json',
        method: 'POST',
        data: {message: '1'}