一旦表格提供,另一个简单的struts动作来处理结果:
package demo;
/**
* copyright 2004, james m. turner.
* all rights reserved
*
* a struts action that sends the new comments to the console
*/
import java.io.ioexception;
import javax.servlet.servletexception;
import javax.servlet.http.*;
import org.apache.struts.action.*;
import org.apache.struts.validator.dynavalidatorform;
public class processformaction extends action {
public actionforward execute(actionmapping mapping,
actionform form,
httpservletrequest request,
httpservletresponse response)
throws servletexception, ioexception {
dynavalidatorform df = (dynavalidatorform) form;
person[] p = (person[]) df.get("people");
for (int i = 0; i < p.length; i++) {
system.out.println(p[i].getfirstname() + " " + p[i].
getlastname() + ":" + p[i].getcomment());
}
return mapping.findforward("success");
}
}
在实际的应用中,这就是数据写回到数据库的地方。在这种情况下,他只将数据倒在控制台上所以我们可以看到他是正确收到的。假设我们为每个演员都填充了恰当的值,我们在控制台上会看到下列内容:
harrison ford:indiana jones
carrie fisher:postcards from the edge
mark hamill:wing commander
正如我在文章开头提到的一样,还有另一个方法可以解决这个问题,而且它不需要使用会话期范围内的表格。这个方法就是使用hashmaps 来存储行。我们来看看使用hashmaps编写的同一段代码:
首先,我们添加一个新表格到struts-config.xml:
现在,我们不使用beans的排列,改为使用hashmap 来存储每个人的数据。另外,我们需要一个新的hashmap 来存储注释,原因我稍后再解释。我们也需要一个新的动作来填充数据:
package demo;
/**
* copyright 2004, james m. turner.
* all rights reserved
*
* a struts action that sets up a dynaform which is globally scoped
*/
import java.io.ioexception;
import java.util.hashmap;
import javax.servlet.servletexception;
import javax.servlet.http.*;
import org.apache.struts.action.*;
import org.apache.struts.validator.dynavalidatorform;
public class setuphashformaction extends action {
public actionforward execute(actionmapping mapping,
actionform form, httpservletrequest request,
httpservletresponse response)
throws servletexception, ioexception {
dynavalidatorform df = (dynavalidatorform) form;
hashmap hm = (hashmap) df.get("people");
person p = new person();
p = new person();
p.setdateofbirth("07/13/1942");
p.setlastname("ford");
p.setfirstname("harrison");
p.setgender("m");
hm.put("1", p);
p = new person();
p.setdateofbirth("10/21/1956");
p.setlastname("fisher");
p.setfirstname("carrie");
p.setgender("f");
hm.put("2", p);
p = new person();
p.setdateofbirth("09/25/1951");
p.setlastname("hamill");
p.setfirstname("mark");
p.setgender("m");
hm.put("3", p);
return mapping.findforward("success");
}
}
基本上,这段代码与前面的代码相同,除了我们将person 对象存储到hashmap 中,而不是排列中之外。我们也不需要创建hashmap,因为它可以作为表格初始化的一部分来动态实现。
在jsp本身中相应的技巧部分为:
copyright 2004, james m turner.
all rights reserved
-->
<%@ taglib uri="/web-inf/struts-html.tld" prefix="html" %>
<%@ taglib uri="/web-inf/struts-html-el.tld" prefix="html-el" %>
<%@ taglib uri="/web-inf/struts-tiles.tld" prefix="tiles" %>
<%@ taglib uri="/web-inf/c.tld" prefix="c" %>
<%@ taglib prefix="fmt" uri="/web-inf/fmt.tld" %>
start wars actor fact page
last name first name
date of birth comment
记住:在初始化时填充的hashmap 值,只要表格显示就会消失,因为表格是请求范围的,而不是会话期范围的。特别是对于我们来说这就意味着所有的person 对象都会消失。所以,如果我们粘贴文本域到person bean 的注释属性上,在提交表格时我们将得到一个空的指针异常,因为person 对象不再位于hashmap 内(实际上,我们得到的是一个全新的空的hashmap.)。所以,我们需要将注释存储在一个单独的并行hashmap 内,它将注释当作简单的字符串来存储。
在上述的代码中还须注意几件事情。首先,因为现在正迭代hashmap条,来自c:foreach 标记的值实际上是用于堆栈条的占位符,同时具有两个属性。key 属性的值用来访问堆栈(在我们的例子中如字符"1", "2", "3"等等),value 属性的值存储在关键字之下。所以,在这种情况下,我们必须使用value 属性来得到person bean 的实属性。
而且,我们需要构造一个用于文本框的有效的struts属性域。在html-el 标记库中使用jstl 扩展就可以实现。在这种情况下,我们通过一个由演员的最后一个名字、逗号和第一个名字组成的字符串来存储注释。
最后,我们需要一个新的动作来处理结果:
package demo;
/**
* copyright 2004, james m. turner.
* all rights reserved
*
* a struts action that sends the new comments to the console
*/
import java.io.ioexception;
import java.util.hashmap;
import java.util.iterator;
import javax.servlet.servletexception;
import javax.servlet.http.*;
import org.apache.struts.action.*;
import org.apache.struts.validator.dynavalidatorform;
public class processhashformaction extends action {
public actionforward execute(actionmapping mapping,
actionform form, httpservletrequest request,
httpservletresponse response)
throws servletexception, ioexception {
dynavalidatorform df = (dynavalidatorform) form;
hashmap hm = (hashmap) df.get("comments");
iterator it = hm.keyset().iterator();
while (it.hasnext()) {
string key = (string) it.next();
string comment = (string) hm.get(key);
system.out.println(key + ":" + comment);
}
return mapping.findforward("success");
}
}
同样,这里最大的差别是数据都是作为hashmaps 来存储的。代码获取关键字(lastname,firstname),然后显示关键字和在控制台
last name first name date of birth comment
记住:在初始化时填充的hashmap 值,只要表格显示就会消失,因为表格是请求范围的,而不是会话期范围的。特别是对于我们来说这就意味着所有的person 对象都会消失。所以,如果我们粘贴文本域到person bean 的注释属性上,在提交表格时我们将得到一个空的指针异常,因为person 对象不再位于hashmap 内(实际上,我们得到的是一个全新的空的hashmap.)。所以,我们需要将注释存储在一个单独的并行hashmap 内,它将注释当作简单的字符串来存储。
在上述的代码中还须注意几件事情。首先,因为现在正迭代hashmap条,来自c:foreach 标记的值实际上是用于堆栈条的占位符,同时具有两个属性。key 属性的值用来访问堆栈(在我们的例子中如字符"1", "2", "3"等等),value 属性的值存储在关键字之下。所以,在这种情况下,我们必须使用value 属性来得到person bean 的实属性。
而且,我们需要构造一个用于文本框的有效的struts属性域。在html-el 标记库中使用jstl 扩展就可以实现。在这种情况下,我们通过一个由演员的最后一个名字、逗号和第一个名字组成的字符串来存储注释。
最后,我们需要一个新的动作来处理结果:
package demo;
/**
* copyright 2004, james m. turner.
* all rights reserved
*
* a struts action that sends the new comments to the console
*/
import java.io.ioexception;
import java.util.hashmap;
import java.util.iterator;
import javax.servlet.servletexception;
import javax.servlet.http.*;
import org.apache.struts.action.*;
import org.apache.struts.validator.dynavalidatorform;
public class processhashformaction extends action {
public actionforward execute(actionmapping mapping,
actionform form, httpservletrequest request,
httpservletresponse response)
throws servletexception, ioexception {
dynavalidatorform df = (dynavalidatorform) form;
hashmap hm = (hashmap) df.get("comments");
iterator it = hm.keyset().iterator();
while (it.hasnext()) {
string key = (string) it.next();
string comment = (string) hm.get(key);
system.out.println(key + ":" + comment);
}
return mapping.findforward("success");
}
}
同样,这里最大的差别是数据都是作为hashmaps 来存储的。代码获取关键字(lastname,firstname),然后显示关键字和在控制台
闽公网安备 35060202000074号