2015-11-04 78 views
0

我可以为一个模型设置一个单独的路径名,但是如果我尝试为另一个模型内的模型设置路径,则会引发错误。我坚持这种友好给我一个解决方案,如果你详细说明我要去哪里工作,并且最好的地方在哪里了解更多,这将是非常慷慨的。如何在另一个模型中设置模型属性的形式:路径

我想和大家分享我的代码把它解决

THIS IS MY控制器

@RequestMapping(value="contact", method=RequestMethod.GET) 
public String contactability(HttpServletRequest request, HttpServletResponse response, Model model, @ModelAttribute("contactDetails") ContactDetails contactDetails){ 
    try{ 
     if(contactDetails==null){ 
      contactDetails= new ContactDetails(); 
     } 
     model.addAttribute("contactabality", contactDetails); 

    }catch(Exception e){ 
     e.printStackTrace(); 
    } 

    return "contactabality"; 

} 

这都是我的模型

我有两个型号involed

  1. 联系方式是代码

    @Entity 
    @Table(name="TB_CONTACT_DETAILS") 
    public class ContactDetails implements Serializable { 
    
    @Id 
    @GeneratedValue 
    @Column(name="CONTACT_ID") 
    private Long contactId; 
    
    @Column(name="IS_PERM_COMM_SAME") 
    private Integer isPermCommSame; 
    
    @OneToMany(fetch=FetchType.EAGER,cascade=CascadeType.ALL, mappedBy="contactDetails") 
    private Set<AddressDetails> addressDetails = new HashSet<AddressDetails>(); 
    
    public ContactDetails() { 
        // TODO Auto-generated constructor stub 
    } 
    
    public Long getContactId() { 
        return contactId; 
    } 
    
    public void setContactId(Long contactId) { 
        this.contactId = contactId; 
    } 
    
    public Integer getIsPermCommSame() { 
        return isPermCommSame; 
    } 
    
    public void setIsPermCommSame(Integer isPermCommSame) { 
        this.isPermCommSame = isPermCommSame; 
    } 
    
    public Set<AddressDetails> getAddressDetails() { 
        return addressDetails; 
    } 
    
    public void setAddressDetails(Set<AddressDetails> addressDetails) { 
        this.addressDetails = addressDetails; 
    } 
    

    }

  2. 是地址模式,下面是它

    @Entity 
    @Table(name="TB_ADDRESS_DETAILS") 
    public class AddressDetails implements Serializable{ 
    
    @Id 
    @GeneratedValue 
    @Column(name="ADDRESS_ID") 
    private Long addrId; 
    
    @ManyToOne(fetch=FetchType.EAGER, cascade=CascadeType.DETACH) 
    @JoinColumn(name="ADDR_TYPE") 
    private AddressTypeMaster addressType; 
    
    @Column(name="ADDRESS_COL1") 
    private String addrCol1; 
    
    @Column(name="ADDRESS_COL2") 
    private String addrCol2; 
    
    @Column(name="ADDRESS_COL3") 
    private String addrCol3; 
    
    @ManyToOne(fetch=FetchType.EAGER,cascade=CascadeType.DETACH) 
    @JoinColumn(name="CITY") 
    private CityMaster city; 
    
    @Column(name="PINCODE") 
    private String pincode; 
    
    @ManyToOne(fetch=FetchType.EAGER,cascade=CascadeType.DETACH) 
    @JoinColumn(name="STATE") 
    private StateMaster state ; 
    
    @ManyToOne(fetch=FetchType.EAGER,cascade=CascadeType.ALL) 
    @JoinColumn(name="CONTACT_ID") 
    private ContactDetails contactDetails; 
    
    @Column(name="ADDR_STATUS") 
    private String addrStatus; 
    
    @OneToOne(fetch=FetchType.EAGER,cascade=CascadeType.ALL,mappedBy="addressDetails") 
    private EmployeeDetails employeeDetails; 
    
    public AddressDetails() { 
        // TODO Auto-generated constructor stub 
    } 
    
    public Long getAddrId() { 
        return addrId; 
    } 
    
    public void setAddrId(Long addrId) { 
        this.addrId = addrId; 
    } 
    
    public AddressTypeMaster getAddressType() { 
        return addressType; 
    } 
    
    public void setAddressType(AddressTypeMaster addressType) { 
        this.addressType = addressType; 
    } 
    
    
    public String getAddrCol1() { 
        return addrCol1; 
    } 
    
    public void setAddrCol1(String addrCol1) { 
        this.addrCol1 = addrCol1; 
    } 
    
    public String getAddrCol2() { 
        return addrCol2; 
    } 
    
    public void setAddrCol2(String addrCol2) { 
        this.addrCol2 = addrCol2; 
    } 
    
    public String getAddrCol3() { 
        return addrCol3; 
    } 
    
    public void setAddrCol3(String addrCol3) { 
        this.addrCol3 = addrCol3; 
    } 
    
    public CityMaster getCity() { 
        return city; 
    } 
    
    public void setCity(CityMaster city) { 
        this.city = city; 
    } 
    
    public String getPincode() { 
        return pincode; 
    } 
    
    public void setPincode(String pincode) { 
        this.pincode = pincode; 
    } 
    
    public StateMaster getState() { 
        return state; 
    } 
    
    public void setState(StateMaster state) { 
        this.state = state; 
    } 
    
    public ContactDetails getContactDetails() { 
        return contactDetails; 
    } 
    
    public void setContactDetails(ContactDetails contactDetails) { 
        this.contactDetails = contactDetails; 
    } 
    
    public String getAddrStatus() { 
        return addrStatus; 
    } 
    
    public void setAddrStatus(String addrStatus) { 
        this.addrStatus = addrStatus; 
    } 
    
    public EmployeeDetails getEmployeeDetails() { 
        return employeeDetails; 
    } 
    
    public void setEmployeeDetails(EmployeeDetails employeeDetails) { 
        this.employeeDetails = employeeDetails; 
    } 
    

    }

代码THIS IS MY JSP

<%@ page language="java" contentType="text/html; charset=UTF-8" 
    pageEncoding="UTF-8"%> 
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%> 

<meta charset="utf-8"> 
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> 
<title>Generic Tool For Employee</title> 
<meta name="description" content=""> 
<meta name="viewport" content="width=device-width, initial-scale=1"> 
<!-- Place favicon.ico and apple-touch-icon.png in the root directory --> 

<link rel="stylesheet" href="layout/css/bootstrap.min.css"> 
<link rel="stylesheet" href="layout/css/validator/screen.css"> 
<link rel="stylesheet" href="layout/datepicker/css/bootstrap-datepicker3.min.css"> 
<link rel="stylesheet" href="layout/css/index.css"> 

    <div class="container-fluid"> 
     <h2>Contact Details</h2> 
     <form:form commandName="contactabality" class="form-horizontal" id="contactDetailsForm" role="form" method="POST" action="persDetails"> 
      <div class="panel panel-default"> 
       <div class="panel-heading"> 
        <h4 class="panel-title">Address Details</h4> 
       </div> 
       <div class="panel-body"> 
        <div class="col-sm-6"> 
       <!--COMMUNICATION ADDRESS DETAILS--> 
        <h3 class="page-header">COMMUNICATION ADDRESS DETAILS</h3> 
         <div class="form-group"> 
          <label class="col-sm-4 control-label">Address 1<span class="mandatoryRed">*</span></label> 
          <div class="col-sm-8"> 
           <form:input path="addressDetails.addrCol1" type="text" class="form-control" placeholder="Address 1" name="commAddr1" id="commAddr1"/> 
          </div> 
         </div> 
     <%--     <div class="form-group"> 
          <label class="col-sm-4 control-label">Address 2</label> 
          <div class="col-sm-8"> 
           <form:input path="addressDetails.addrCol2" type="text" class="form-control" placeholder="Address 2" name="commAddr2" id="commAddr2"/> 
          </div> 
         </div> 
         <div class="form-group"> 
          <label class="col-sm-4 control-label">Address 3</label> 
          <div class="col-sm-8"> 
           <form:input path="addressDetails.addrCol3" type="text" class="form-control" placeholder="Address 3" name="commAddr3" id="commAddr3"/> 
          </div> 
         </div> 
         <div class="form-group"> 
          <label class="col-sm-4 control-label">City<span class="mandatoryRed">*</span></label> 
          <div class="col-sm-8"> 
           <form:select path="addressDetails.city.cityId" class="form-control" name="commAddrCity" id="commAddrCity"> 
            <form:options items="${cities}"/> 
           </form:select> 
          </div> 
         </div> 
         <div class="form-group"> 
          <label class="col-sm-4 control-label">State<span class="mandatoryRed">*</span></label> 
          <div class="col-sm-8"> 
           <form:select path="addressDetails.state.stateId" class="form-control" name="commAddrState" id="commAddrState"> 
            <form:options items="${states}" /> 
           </form:select> 
          </div> 
         </div> 
         <div class="form-group"> 
          <label class="col-sm-4 control-label">Pincode<span class="mandatoryRed">*</span></label> 
          <div class="col-sm-8"> 
           <form:input path="addressDetails.pincode" type="text" class="form-control" placeholder="Pincode" name="commAddrPincode" id="commAddrPincode" maxlength="6"/> 
          </div> 
         </div> 
        </div> 
        <!--PERMANENT ADDRESS DETAILS--> 
        <div class="col-sm-6"> 
         <h4 class="page-header">PERMANENT ADDRESS DETAILS</h4> 
         <div class="form-group"> 
          <label class="col-sm-9">Is your permanent address same as communication address<span class="mandatoryRed">*</span></label> 
          <div class="col-sm-2"> 
           <div class="toggle-switch toggle-switch-success"> 
            <label> 
             <form:checkbox path="isPermCommSame" id="PermAddrCheck" type="checkbox" value="2"/> 
             <div class="toggle-switch-inner"></div> 
             <div class="toggle-switch-switch"><i class="fa fa-check"></i></div> 
            </label> 
           </div> 

          </div> 
         </div> 
         <div class="row permAddrClss"> 
          <div class="form-group"> 
           <label class="col-sm-4 control-label">Address 1<span class="mandatoryRed">*</span></label> 
           <div class="col-sm-8"> 
            <form:input path="addressDetails.addrCol1" type="text" class="form-control" placeholder="Address 1" name="PermAddr1" id="PermAddr1"/> 
           </div> 
          </div> 
          <div class="form-group"> 
           <label class="col-sm-4 control-label">Address 2</label> 
           <div class="col-sm-8"> 
            <form:input path="addressDetails.addrCol2" type="text" class="form-control" placeholder="Address 2" name="PermAddr2" id="PermAddr2"/> 
           </div> 
          </div> 
          <div class="form-group"> 
           <label class="col-sm-4 control-label">Address 3</label> 
           <div class="col-sm-8"> 
            <form:input path="addressDetails.addrCol3" type="text" path="addressDetails.addrCol3" class="form-control" placeholder="Address 3" name="PermAddr3" id="PermAddr3"/> 
           </div> 
          </div> 
          <div class="form-group"> 
           <label class="col-sm-4 control-label">City<span class="mandatoryRed">*</span></label> 
           <div class="col-sm-8"> 
            <form:select path="addressDetails.city.cityId" class="form-control" name="PermAddrCity" id="PermAddrCity"> 
             <form:options items="${cities}" /> 
            </form:select> 
           </div> 
          </div> 
          <div class="form-group"> 
           <label class="col-sm-4 control-label">State<span class="mandatoryRed">*</span></label> 
           <div class="col-sm-8"> 
            <form:select path="addressDetails.state.stateId" class="form-control" name="PermAddrState" id="PermAddrState"> 
             <form:options items="${states}"/> 
            </form:select> 
           </div> 
          </div> 
          <div class="form-group"> 
           <label class="col-sm-4 control-label">Pincode<span class="mandatoryRed">*</span></label> 
           <div class="col-sm-8"> 
            <form:input path="addressDetails.pincode" type="text" class="form-control" placeholder="Pincode" name="PermAddrPincode" id="PermAddrPincode" maxlength="6"/> 
           </div> 
          </div> 
         </div> 
        </div> 
       </div> 
      </div>--%> 
      <p> 
       <input class="submit btn btn-default" type="submit" value="Submit"> 
      </p> 
     </form:form> 
    </div> 

    <!-- SCRIPTS --> 
    <script src="layout/js/vendors/jquery-1.9.1.min.js"></script> 
    <script src="layout/js/vendors/jquery.validate.min.js"></script> 
    <script src="layout/js/vendors/bootstrap-3.3.5.js"></script> 
    <script src="layout/datepicker/js/bootstrap-datepicker.min.js"></script> 
    <script src="layout/js/index.js"></script> 
    <script src="layout/js/contactabality.js"></script> 

我得到的误差是

4:46:。。34916 ERROR [org.apache.catalina.core.ContainerBase [jboss.web] [缺省主机] [/ EOB-幅] [JSP ]](http-localhost/127.0.0.1:8080-5)JBWEB000236:servlet jsp的Servlet.service()抛出异常:org.springframework.beans.NotReadablePropertyException:bean类[com.rectrix的无效属性'addressDetails.addrCol1' .eob.models.ContactDetails]:Bean属性 'addressDetails.addrCol1' 不是可读或有一个无效getter方法:是否返回类型

AND

14:46:34,922错误[org.apache.catalina.core.ContainerBase。[jboss.web]。[default-host]。[/ eob-web]。[jsp]](http-localhost/127.0.0.1 :8080-5)JBWEB000236:servlet jsp的Servlet.service()抛出异常:org.apache.tiles.util.TilesIOException:包含路径'/WEB-INF/views/jsp/contactabality.jsp'的JSPException。

请帮我弄清楚这一点。 谢谢

回答

1
private Set<AddressDetails> addressDetails = new HashSet<AddressDetails>(); 

是你的问题。我相信你会在上面的列表中只存储两种地址,我建议你绑定永久通讯地址详细信息作为单独的属性,而不是绑定为列表。

一些东西像ContactDetails@Transient private AddressDetails commAddressDetails@Transient private AddressDetails permAddressDetails创建两个以上Transient属性和对应的setter /吸气。

在你的Jsp中使用这些属性的各个字段之前,坚持写自己的逻辑来构造one-to-many的关系。如果你有静态的地址数量,这将工作。

+0

我很感谢你帮助我的时间,谢谢你。我的其他模型也以相同的方式开发,例如。我有employeeExp模型,其中包含我有公司名称的pastExp属性。所以用户试图从employee exp设置的名字应该放在pastExp的公司名称中。为此在employeeExp的jsp中,我给出了一个公司名称为pastExp.companyName的路径。在这种情况下,我需要这样做,但我得到了上面显示的相同错误。如何解决这个问题。 –

+0

在这种情况下,您的视图设计如何? - 这个答案可能对你有帮助。 http://stackoverflow.com/questions/33015654/how-to-bind-data-to-list-in-spring-form/33148339#33148339 – Lovababu

+0

谢谢-Lovababu。我认为那就是我想要做的。我需要在模型中绑定我的模型。为此,我用pastExp.companyName作为路径。但我得到了同样的错误 –

相关问题