Как установить свойства связанного класса в spring mvc

у меня есть два класса сущностей: класс User и Address User: он имеет много других свойств плюс связанный адрес класса

Entity
@Table(name = "T_USER_DETAILS")
public class User {


//@GenericGenerator(name = "generator",strategy = "sequence-identity",parameters = { @Parameter(name = "sequence",value = "USER_ID_SEQ")} )

@GenericGenerator(name = "generator",strategy = "increment")    
@Id 
@GeneratedValue(generator = "generator")
@Column(name = "USER_ID")
private int userid;

@Column(name = "USER_FIRSTNAME")
private String firstname;
@Column(name = "USER_AGE")
private int age;


//creating many to one relationship between address class and student class
@ManyToOne(cascade = CascadeType.ALL)
@JoinColumn(name = "ADDRESS_ID")
private Address address;

вот класс адресов, который также является сущностью

@Entity
@Table(name = "T_ADDRESS_DETAILS")
public class Address {



    @GenericGenerator(name = "idgenerator", strategy = "increment")
    @Id
    @GeneratedValue(generator = "idgenerator")
    @Column(name = "ADDRESS_ID")
    private int addressId;

    @Column(name = "ADDRESS_LINE1")
    private String address_line1;

    @Column(name = "ADDRESS_LINE2")
    private String address_line2;

в моей форме я создаю командный компонент для пользовательского класса и привязываю его к своему классу контроллера как:

<form:form method = "post" action = "register.html" commandName = "newUser">

<br>
<h2><i>Create new account</i></h2>
<br>
Enter the firstname<br>
<input type = "text" size = "30" name = "firstname">
<font color = "red"> <form:errors path = "firstname" cssClass = "error"/></font><br>
Enter the lastname<br>
<input type = "text" size = "30" name = "lastname">
<font color = "red"> <form:errors path = "lastname" cssClass = "error"/></font><br>
Enter the password<br>
<input type = "password" size = "30" name = "password">
<font color = "red"> <form:errors path = "password" cssClass = "error"/></font><br>
Enter the Email Id<br>
<input type = "text" size = "30" name = "emailId">
<font color = "red"><form:errors path = "emailId" cssClass = "error"/><br></font>
Enter the phone number<br>
<input type = "text" size = "30" name = "phonenumber">
<font color = "red"><form:errors path = "phonenumber" cssClass = "error"/></font><br>
Enter the age<br>
<input type  = "text" size = "30" name = "age"/>
<font color = "red"><form:errors path = "age" cssClass = "error"/></font><br><br>

Enter the Address<br>
<input type = "textbox" name = "address" size = "30">
<font color = "red"><form:errors path = "address" cssClass = "error"/></font><br>

<div align = "center">



<input type = "submit" name = "submit" value = "submit">

контроллер:

@RequestMapping(method = RequestMethod.POST)
public String register(@ModelAttribute("newUser") User user,BindingResult result,Model model,HttpSession session,HttpServletRequest request) //retrieve the backing bean with in the user attribute 
{
..
}

моя проблема заключается в том, как я могу назначить свойства класса адреса, которые я хочу отправить из формы, такой как город, штат, страна... какие изменения мне нужно сделать на моей странице jsp и в моем классе контроллера. Пожалуйста помоги.


person shashi    schedule 16.04.2013    source источник


Ответы (2)


Вы также можете использовать тег <form:input с ассоциациями свойств объединенного класса, как показано ниже:

<form:form commandName="person" method="post" action="${formAction}">
    <div class="form">
        <p>User</p>
            <form:input path="firstname" />
            <form:input path="address.address_line1" />

            <input type="submit" class="btn btn-primary" />
    </div>
</form:form>

Помните, ключ в том, чтобы использовать входной путь формы для соответствия свойствам объединенного класса. Затем вы можете использовать этот метод для всех других ассоциаций, используемых в компоненте формы.

person blackpanther    schedule 16.04.2013

Вы должны изменить bean-компонент адреса, чтобы добавить свойства для города, штата и т. д. (среди прочего обеспечивает хорошую проверку также с использованием аннотаций). После этого вам придется разделить ввод по одному для каждого свойства адресного компонента; Затем вы можете использовать тег sping:bind с обозначением address.city

<form:form commandName="person" method="POST" action = "register.html">

   <spring:bind path="address.city">
    <input type = "textbox" name = "address.city" size = "30">
   </spring:bind>

   ...
   ...
</form:form>
person Anadi Misra    schedule 16.04.2013