窗体:错误没有显示错误

问题描述:

当验证对象控制器只是刷新页面,而不是通过窗体显示错误:错误,你能告诉我问题在哪里。我客人需要从结合的结果出现错误,并将其插入到页面中,而不是控制器只是清爽页面窗体:错误没有显示错误

控制器:

@PreAuthorize("hasRole('ROLE_ADMIN')") 
@RequestMapping(value = "/create", method = RequestMethod.POST) 
public String createProduct(MultipartFile image, Model model,@ModelAttribute @Valid ProductDto product, BindingResult bindingResult) throws IOException { 
    productValidator.validate(product,bindingResult); 
    if (bindingResult.hasErrors()){ 
     return "admin/create"; 
    } else { 
     return "index"; 
    } 

} 

@PreAuthorize("hasRole('ROLE_ADMIN')") 
@RequestMapping(value = "/create", method = RequestMethod.GET) 
public String createProduct(Model model) { 
    model.addAttribute("product", new ProductDto()); 
    model.addAttribute("categories", categoryService.findAll()); 
    return "admin/create"; 
} 

验证:

@Override 
public boolean supports(Class<?> aClass) { 
    return ProductDto.class.equals(aClass); 
} 

@Override 
public void validate(Object o, Errors errors) { 

    ProductDto product = (ProductDto) o; 

    if (product.getTitle().isEmpty() || product.getTitle() == null) { 
     errors.rejectValue("title", "product.title", "Product title cant be empty"); 
    } 
    if (product.getDescription().isEmpty() || product.getDescription() == null) { 
     errors.rejectValue("description", "product.description", "Product description cant be empty"); 
    } 
    if (product.getPrice() == null || product.getPrice()<=0) { 
     errors.rejectValue("price", "product.price", "Product price is not valid"); 
    } 
    if (product.getCategoryId()==null) { 
     errors.rejectValue("category", "product.category", "Product category is not valid"); 
    } 

} 

JSTL页:

      <spring:url value="/product/create" var="formUrl"/> 
         <form:form modelAttribute="product" action="${formUrl }" method="post" enctype="multipart/form-data"> 
          <div class="form-group"> 
           <label>Title</label> 
           <form:input id="title" 
              cssClass="form-control" path="title"/> 
           <form:errors path="title"/> 
          </div> 
          <div class="form-group"> 
           <label>Description</label> 
           <form:textarea id="description" rows="10" 
               cssClass="form-control" path="description"/> 
          </div> 
          <div class="form-group"> 
           <label>Price</label> 
           <form:input id="price" type="number" 
              cssClass="form-control" path="price"/> 
           <form:errors path="description"/> 
          </div> 
          <div class="form-group"> 
           <label for="sel1">Select category</label> 
           <form:select id="sel1" cssClass="form-control" path="categoryId"> 
            <form:options items="${categories}" itemValue="id" itemLabel="title"/> 
           </form:select> 
          </div> 
          <label class="btn btn-default btn-file"> 
           Image <input type="file" multiple accept='image/*' ng-file-select="onFileSelect($files)" name="image" style="display: block;"> 
          </label> 
          <br><br> 
          <div class="text-center"> 
           <button type="submit" class="btn btn-lg btn-success text-center"><span 
             class="fa fa-check"></span> Submit 
           </button> 
           <a href="/" class="btn btn-danger btn-lg text-center"><span 
             class="fa fa-times"></span> Cancel 
           </a> 
          </div> 
         </form:form> 

我认为你的product模型属性在y中有不同的名称我们的POST-处理方法。

根据documentation

默认模型属性名称是从基于非限定类名声明 属性类型(即,方法的参数类型或方法返回类型), 推断:例如“orderAddress”用于类 “mypackage.OrderAddress”或“orderAddressList”for “List <mypackage.OrderAddress>”。

因此,您的ProductDto product属性将在结果模型中具有名称productDto。但是你在模板中指product

尝试明确设置属性@ModelAttributename注释

public String createProduct(MultipartFile image, Model model, @ModelAttribute(name = "product") @Valid ProductDto product, BindingResult bindingResult) 

并确保bidning和确认实际工作,尝试登录它:

if (bindingResult.hasErrors()) { 
    System.err.println("Form has errors!"); 
}