Spring MVC表单:选择在POST操作中不返回Object

时间:2012-10-15 21:50:48

标签: forms spring jsp post annotations

我有一个关于从用于填充选择表单的列表中检索对象的问题。

控制器:

@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仍然是前进的方向,当发生这种情况时,我会再次更新。

0 个答案:

没有答案