表单在提交时给出Null

时间:2016-08-30 07:00:51

标签: java spring-mvc thymeleaf

我正在使用Spring MVC + thymeleaf,当我提交表单时,它会在绑定结果中一直给出验证错误(Null)。任何建议将不胜感激!谢谢!

错误消息

"Field error in object 'createForm' on field 'authorId': rejected value [null]; codes [NotNull.createForm.authorId,NotNull.authorId,NotNull]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [createForm.authorId,authorId]; arguments []; default message [authorId]]; default message [may not be null]"
@NotNull
@Size(min= 2, max = 100, message = "your title should be between 2 and 100 symbols")
private String title;

@NotNull
@Size(min = 2, message = "Please fill your message")
private String content;

@DateTimeFormat(pattern = "yyyy-mm-dd")
private Date date;

@NotNull
private String authorId;



public String getTitle() {
    return title;
}

public void setTitle(String title) {
    this.title = title;
}

public String getContent() {
    return content;
}

public void setContent(String content) {
    this.content = content;
}

public Date getDate() {
    return date;
}

public void setDate(Date date) {
    this.date = date;
}

public String getId() {
    return authorId;
}

public void setId(String authorId) {
    this.authorId = authorId;
}
}

我的HTML

<form id="create-form" method="post" th:object="${createForm}">
    <div><label for="title">Title:</label></div>
    <input id="title" type="text" name="title" th:value="*{title}"/>
    <span class="formError" th:if="${#fields.hasErrors('title')}" th:errors="*{title}">Invalid title</span>
    <div><label for="content">Content:</label></div>
    <textarea name="content" rows="30" cols="100" id="content" th:value="*{content}"></textarea>
    <span class="formError" th:if="${#fields.hasErrors('content')}" th:errors="*{content}">Invalid content</span>
    <div><label for="date">Date:</label></div>
    <input id="date" type="date" name="date" th:value="*{date}"/>
    <span class="formError" th:if="${#fields.hasErrors('date')}" th:errors="*{date}">Invalid date</span>
    <div><label for="authorId">Author ID:</label></div>
    <input id="authorId" type="text" name="authorId" th:value="*{authorId}"/>
    <span class="formError" th:if="${#fields.hasErrors('id')}" th:errors="*{authorId}">Invalid id</span>

    <br/>
    <br/>
    <div><input type="submit" value="Create"/></div>
</form>

1 个答案:

答案 0 :(得分:1)

如问题评论中所述:

注释null不会保护您免受AuthorTO的攻击。这是你自己和你和其他开发代码的开发人员签订的合同,那里不能为空。

这意味着您必须自己验证数据。有两种方法。您可以创建允许null的{​​{1}},然后创建Author当且仅当前端没有意外null或验证时才会创建invoiceNumber