我有一个关于从用于填充选择表单的列表中检索对象的问题。
控制器:
@RequestMapping(value="listStaffMembers", method=RequestMethod.GET)
public String listStaffMembers(Model model){
model.addAttribute("staffList", this.personManager.getAllStaff());
Person person = new Person();
model.addAttribute("staffMember", person);
model.addAttribute("staffListSize", this.personManager.getAllStaff().size());
for (Person persons : this.personManager.getAllStaff())
System.out.println("Query Name:" + persons.getName() + " Id:"+persons.getId());
return "staffList";
}
未接收Person对象的控制器:
@RequestMapping(value="staffMemberCRUD",
method=RequestMethod.POST)
//ModelAndView
public String staffMemberCRUD(@ModelAttribute("staffMember")Person person, Model model){
if(person!=null){
model.addAttribute("staffMember", person);
String name = person.getName();
int id = person.getId();
System.out.println("id: "+ id);
System.out.println("name: "+ name);
return "staffForm";
}else{
System.out.println("Person not saved, no entry, throwing null pointer exception");
throw new NullPointerException();
}
}
人类:
@Entity(name="STAFF")
@NamedQuery(name="staffDetails.byId", query="from STAFF")// where userId = ?, then use position 0, then value
public class Person {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private int id;
@Column(name="NAME")
private String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Person(int personId, String name){
setId(personId);
setName(name);
}
public Person(String name){
setName(name);
}
public Person(int Id){
setId(Id);
}
public Person(){
}
}
以下表单如何检索对象,其中id出现在person的name变量中,尽管没有id值。
<FORM ACTION="staffMemberCRUD" METHOD=POST ><!-- onSubmit="return dropdown(this.gourl) -->
<table>
<tr>
<td>
<select name="staffMember">
<option value="">Choose</option>
<c:forEach items="${staffList}" var="prod">
<option value ="${prod.id}"><c:out value="${prod.id}"></c:out><c:out value="${prod.name}"></c:out></option>
</c:forEach>
</select>
</td>
</tr>
</table>
<INPUT TYPE=SUBMIT VALUE="Go">
</FORM>
Person类也用于使用hibernate填充数据库,这会混淆这个问题吗?
当测试listStaffMembers下拉列表时,它只是当前没有工作的帖子。 我已经查看了Spring的文档并且它让我到目前为止,任何帮助都非常感激,因为到目前为止我已经过了3天而没有任何积极的结果。非常感谢,Dean
Latest Update:
更新的表单:选择,注意选择路径现在发布'id',并且正确的表单:表单标签,POST后的下一个视图中的人物对象现在填充了一个id字段,这比一个hack少了之前提到再次从数据库中找到它们:
<form:form action="staffMemberCRUD" commandName="staffMember"><!-- onSubmit="return dropdown(this.gourl) -->
<table>
<tr>
<td>
<form:select path="id">
<form:option value="-1">Select your Staff Member</form:option>
<form:options items="${staffList}" itemLabel="name" itemValue="id" />
</form:select>
</td>
</tr>
</table>
<INPUT TYPE=SUBMIT VALUE="Go">
</form:form>
我知道PropertyEditor仍然是前进的方向,当发生这种情况时,我会再次更新。