使用spring MVC进行Thymeleaf表单验证

时间:2015-08-30 17:34:34

标签: spring spring-mvc thymeleaf

这已被问过几次,但所有人都没有回答我的问题。我一直在尝试使用不同的功能与Thymeleaf合作两天,并且非常不成功。我只能使用spring-boot来工作,但是现在我正在使用spring-MVC。

首先,我将向您展示我的依赖

1

<%@ taglib prefix="sf" uri="http://www.springframework.org/tags/form" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html xmlns:th="http://www.thymeleaf.org" xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>Create a New Account</title>
    <link th:href="@{/resources/css/loginForm.css}" href="/resources/css/loginForm.css" rel="stylesheet"
          type="text/css"/>
</head>
<body>

<form action="#" th:action="@{/createNewAccount}" th:object="${user}" method="post">
    <table>
        <tr>
            <td>Name:</td>
            <td><input type="text" th:field="*{username}" /></td>
            <td th:if="${#fields.hasErrors('name')}" th:errors="*{username}">Name Error</td>
        </tr>
        <tr>
            <td>Password:</td>
            <td><input type="text" th:field="*{password}" /></td>
            <td th:if="${#fields.hasErrors('age')}" th:errors="*{password}">Password Error</td>
        </tr>
        <tr>
            <td><button type="submit">Submit</button></td>
        </tr>
    </table>
</form>

</body>
</html>

现在,您可以看到我的intellij IDE显示的错误:

2

User.java

package com.practice.domain;

import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;

/**
 * Created by DrewJocham on 8/30/15.
 */

public class User {

    @NotNull
    @Size(min = 2, max = 30)
    private String username;
    @NotNull
    private String password;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Override
    public String toString() {
        return "User{" +
                "username='" + username + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}

1 个答案:

答案 0 :(得分:2)

您调用hasErrors的字段名称需要与对象中的字段名称匹配。像这样:

<td th:if="${#fields.hasErrors('username')}" th:errors="*{username}">Name Error</td>

请注意,hasErrors('name')成为hasErrors('username'),并且:

<td th:if="${#fields.hasErrors('password')}" th:errors="*{password}">Password Error</td>

请注意hasErrors('age')成为hasErrors('password')

至于Intellij中突出显示的错误,我认为它们具有误导性,并且与这个未解决的问题有关:https://youtrack.jetbrains.com/issue/IDEA-132738