在Form提交后的变量,很多情况是要展现在jsp页面中,这时Action到Render的变量传递就非常有用。

例如,您在数据库中添加了学生的详细信息。

为了实现这一需求,先创建Form表单(学生的细节,如姓名、出生日期等,通过action url来实现)。

当用户提交表单时,这些数据(学生信息)会在你执行CRUD操作的action方法添加。

添加完成后,需要把一些信息展现到jsp页面。

和v6.2不同的是,action方法里不需要写类似这样的语句:

actionResponse.setRenderParameter("XXX", 变量名);
actionRequest.setAttribute("XXX", 变量名);

举例说明

在Action阶段,我们提交了name变量,然后需要在Render阶段展现在JSP

Java代码

package com.lifiti.portlet;

import com.liferay.portal.kernel.log.Log;
import com.liferay.portal.kernel.log.LogFactoryUtil;
import com.liferay.portal.kernel.portlet.bridges.mvc.MVCPortlet;
import com.liferay.portal.kernel.util.ParamUtil; import java.io.IOException;
import java.util.ArrayList;
import java.util.List; import javax.portlet.ActionRequest;
import javax.portlet.ActionResponse;
import javax.portlet.Portlet;
import javax.portlet.PortletException;
import javax.portlet.ProcessAction;
import javax.portlet.RenderRequest;
import javax.portlet.RenderResponse; import org.osgi.service.component.annotations.Component; @Component(immediate = true, property = { "com.liferay.portlet.display-category=category.sample",
"com.liferay.portlet.instanceable=true", "javax.portlet.requires-namespaced-parameters=false",
"javax.portlet.display-name=com.lifiti.parts Portlet", "javax.portlet.init-param.template-path=/",
"javax.portlet.init-param.view-template=/view.jsp", "javax.portlet.resource-bundle=content.Language",
"javax.portlet.security-role-ref=power-user,user" }, service = Portlet.class)
public class FirstPortlet extends MVCPortlet {
private static final Log _log = LogFactoryUtil.getLog(FirstPortlet.class.getName()); @Override
public void render(RenderRequest request, RenderResponse response) throws PortletException, IOException {
String peopleName = ParamUtil.get(request, "name", "");
String age = ParamUtil.get(request, "age", "");
_log.info("peopleName by ParamUtil in render ==>" + peopleName);
_log.info("age by ParamUtil in render ==>" + age);
_log.info("age By RenderParameter in render ==>" + request.getAttribute("ageBySetParameter")); request.setAttribute("peopleName", peopleName); super.render(request, response);
} @ProcessAction(name = "send")
public void ReceiveData(ActionRequest actionRequest, ActionResponse actionResponse) throws Exception {
String name = ParamUtil.getString(actionRequest, "name");
String age = ParamUtil.getString(actionRequest, "age");
String phone = ParamUtil.getString(actionRequest, "phone"); actionRequest.setAttribute("phone", phone);
//actionResponse.setRenderParameter("ageBySetParameter", age);
List<String> list = new ArrayList<String>();
list.add("tom");
list.add("cat");
list.add("ketty");
actionRequest.setAttribute("personList", list); _log.info(" 开始接收数据");
System.out.println("FirstPortlet.java name = " + name);
System.out.println("FirstPortlet.java age = " + age);
System.out.println("FirstPortlet.java phone = " + phone);
}
}

jsp

<%@page import="com.liferay.portal.kernel.portlet.LiferayPortletMode"%>
<%@page import="com.liferay.portal.kernel.portlet.LiferayWindowState"%>
<%@ include file="/init.jsp" %> <p>
<b><liferay-ui:message key="com_lifiti_parts_ComLifitiPartsmvcportlet.caption"/></b>
</p> <c:set var="submit"><liferay-ui:message key="com_lifiti_parts_ComLifitiPartsmvcportlet.submit"/></c:set> <c:if test="${not empty phone }">
Phone: ${phone} added successfully.
</c:if> <c:if test="${not empty peopleName }">
PeopleName: ${peopleName} added successfully.
</c:if>
<c:forEach var="x" items="${personList}">
  <br> ${x}<br>        
</c:forEach>
<portlet:actionURL var="sendURL" name="send">
</portlet:actionURL> <form action="${sendURL}" method="post" name="fm">
<aui:input name="name" label="Name" id="name"/>
<aui:input name="age" label="Age" id="age"/>
<input type="text" name="<portlet:namespace/>phone" />
<input type="submit" value="${submit}"></input>
</form>

log:

FirstPortlet.java name = 王昕
FirstPortlet.java age = 1
FirstPortlet.java phone = 123
16:16:59,946 INFO [http-nio-8080-exec-7][FirstPortlet:32] peopleName by ParamUtil in render ==>王昕
16:16:59,947 INFO [http-nio-8080-exec-7][FirstPortlet:33] age by ParamUtil in render ==>1
16:16:59,947 INFO [http-nio-8080-exec-7][FirstPortlet:34] age By RenderParameter in render ==>null

v7.0中这种语句可以不用写:

actionRequest.setAttribute("phone", phone);
actionResponse.setRenderParameter("ageBySetParameter", age);

实际上,只需要2句就能完成数值传递:

String peopleName = ParamUtil.get(request, "name", "");
request.setAttribute("peopleName", peopleName);

直接使用ParamUtil很方便

Liferay7 BPM门户开发之40: Form表单的Action到Render的数据传递的更多相关文章

  1. Liferay7 BPM门户开发之39: Form表单提交的ProcessAction处理

    在v6.2开始后,需要设置<requires-namespaced-parameters>false</requires-namespaced-parameters>  来避免 ...

  2. Liferay7 BPM门户开发之9: 流程表单数据动态映射体系

    设计目的: 每个流程表单涉及不同的表单变量.比如请假流程有3个任务节点,分别是 Task1:开始流程,填写请假人.请假原因.请假开始时间.请假结束时间: Task2:上级审批,填写是否同意,审批意见: ...

  3. Liferay7 BPM门户开发之10: 通用流程实现从Servlet到Portlet(Part1)

    开发目的: 实现通用流程自动化处理(即实现不需要hardcode代码的bpm统一处理后台,仅需要写少量前端html form代码和拖拽设计BPM定义) 既可独立运行或可依托于Liferay或依托其它门 ...

  4. Liferay7 BPM门户开发之17: Portlet 生命周期

    Portlet 生命周期 init() =〉 render() =〉 processAction() =〉 processEvent() =〉 serveResource() =〉destroy() ...

  5. Liferay7 BPM门户开发之37: Liferay7下的OSGi Hook集成开发

    hook开发是Liferay客制扩展的一种方式,比插件灵活,即可以扩展liferay门户,也能对原有特性进行更改,Liferay有许多内置的服务,比如用hook甚至可以覆盖Liferay服务. 可作为 ...

  6. Liferay7 BPM门户开发之11: Activiti工作流程开发的一些统一规则和实现原理(完整版)

    注意:以下规则是我为了规范流程的处理过程,不是Activiti公司的官方规定. 1.流程启动需要设置启动者,在Demo程序中,“启动者变量”名统一设置为initUserId 启动时要做的: ident ...

  7. Liferay7 BPM门户开发之2: BPMN 2.0 规范入门 (Activiti BPMN extensions)

    Liferay最大的问题是BPM弱,如果做企业开发,BPM必不可少,所以直入主题,做个BPMN2入门. 本文参考地址:http://activiti.org/userguide/index.html# ...

  8. Liferay7 BPM门户开发之23: 了解内置工作流(Kaleo Workflow)

    Liferay内置的工作流是企业版的功能,虽然简单粗糙,但依然不支持社区版.既然要用更强大的Activiti来替代它,那就非常有必要学习一下内置工作流的一些思想,以便借鉴. 它的特点: 实体的工作流操 ...

  9. Liferay7 BPM门户开发之15: Liferay开发体系简介

    Liferay SDK 开发体系 主要分6种: Portlet Hook Theme Layout Templates Web Modules Ext Portlet :类似于servlet的web组 ...

随机推荐

  1. 中国UTM分区

    高斯-克吕格投影是“等角横切圆柱投影”,投影后中央经线保持长度不变,即比例系数为1: UTM投影是“等角横轴割圆柱投影”,圆柱割地球于南纬80度.北纬84度两条等高圈,投影后两条割线上没有变形,中央经 ...

  2. ArcGIS10.1 api for Flex开发用于ArcGIS 9.3时QueryTask 'Error #2032'错误的解决方案

    因客户GIS软件需求,将应用降级到低版本ArcGIS9.3,不仅数据有些样式.配色.字符有些问题,API也要相应“降级”,解决如下: 利用9.3+flex做QueryTask时候出现了[RPC Fau ...

  3. 「2014-4-13」Think twice before starting the adventure

    杂文一篇. 1. 取名字真心是一件特别困难的事情.这位独立开发者花了将近两天的时间,给他的私人项目取了个名字:这篇博客<为何我不鸟你的开源项目>里显然还忽视了一个原因,就是名字取得太烂以至 ...

  4. protobuf坑1

    或者说特性吧,没仔细看protobuf代码,也许我还理解不够. 按照陈硕大牛的这篇帖子的介绍,“它包含了程序编译的时候所链接的全部 protobuf Message types” 实际开发过程中发现必 ...

  5. javascript练习-定义子类

    function defineSubclass(superclass, //父类的构造函数 constructor, //新的子类的构造函数 methods, //实例方法:复制至原型中 static ...

  6. 学习django之python中os模块的函数

    os.sep可以取代操作系统特定的路径分隔符.windows下为 “\\” os.name字符串指示你正在使用的平台.比如对于Windows,它是'nt',而对于Linux/Unix用户,它是'pos ...

  7. strncpy和memcpy的区别

    今天不小心在该用memcpy的时候,用了strncpy使自己吃了亏,所以写出这个博文. memcpy就是纯字节拷贝,而strncpy就不同了,字符串是以'\0'结尾的.如果一个字符buffer长度为6 ...

  8. oracle 11g install linux

    #!/bin/bash#Purpose:Create and config oracle install.#Usage:Log on as the superuser('root') #1.creat ...

  9. Swift语言的基础详解

    1.1.关于swift · Swift 是一种适用于 iOS 和 OS X 应用的全新编程语言,它建立在最好的 C 和 Objective-C 语言之上,并且没有 C 语言的兼容性限制.Swift 采 ...

  10. Mroonga 3.0.8 发布,MySQL 存储引擎

    Mroonga 3.0.8 支持 REPAIR TABLE 支持损坏的 groonga 数据库. Mroonga 是一个 MySQL 存储引擎,基于 Groonga,提供完整的全文搜索引擎.