使用Thymeleaf和Spring MVC,Form参数为null

Pau*_*mes 6 java model-view-controller spring spring-mvc thymeleaf

我遇到了Thymeleaf和Spring MVC的问题.

我正在关注spring.io网站http://spring.io/guides/gs/handling-form-submission/上的一个教程,当我试图扩展本教程时,我遇到了一个问题.

如果我在模型类中添加另一个参数(在我的例子中,我添加了一个Date参数和一个long参数),而不是将它们放在我的视图上(想象一下这个日期参数是我的最后修改日期和这个长参数是一个随机值),当我提交这个值时,它会使我的方法中的这2个参数为null.

这是我的一些代码.

我的模特班

public class Greeting {

    private long id;
    private String content;
    private Date hour;
    private long longNumber;
.... getters and setters ....
}
Run Code Online (Sandbox Code Playgroud)

我的控制器

@Controller
public class GreetingController {

@RequestMapping(value="/greeting", method=RequestMethod.GET)
public String greetingForm(Model model) {

    Greeting greeting = new Greeting();
    greeting.setHour(new Date());
    greeting.setLongNumber(1234L);
    System.out.println(greeting.toString());
    model.addAttribute("greeting", greeting);
    return "greeting";
}

@RequestMapping(value="/greeting", method=RequestMethod.POST)
public String greetingSubmit(@ModelAttribute Greeting greeting, Model model) {
    System.out.println(greeting.toString());
    model.addAttribute("greeting", greeting);
    return "result";
}
}
Run Code Online (Sandbox Code Playgroud)

我的表格

<!DOCTYPE HTML>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <title>Getting Started: Handing Form Submission</title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
<body>
    <h1>Form</h1>
    <form action="#" th:action="@{/greeting}" th:object="${greeting}" method="post">
        <p>Id: <input type="text" th:field="*{id}" /></p>
        <p>Message: <input type="text" th:field="*{content}" /></p>
        <p><input type="submit" value="Submit" /> <input type="reset" value="Reset" /></p>
    </form>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)

结果页面

<!DOCTYPE HTML>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <title>Getting Started: Handing Form Submission</title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
<body>
    <h1>Result</h1>
    <p th:text="'id: ' + ${greeting.id}" />
    <p th:text="'content: ' + ${greeting.content}" />
    <p th:text="'Date: ' + ${greeting.hour}" />
    <a href="/greeting">Submit another message</a>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)

这是我的模型类的控制台打印

Greeting [id=0, content=null, hour=Sun Apr 26 22:29:25 GMT-03:00 2015, longNumber=1234]
Greeting [id=0, content=aaaa, hour=null, longNumber=0]
Run Code Online (Sandbox Code Playgroud)

如您所见,我的视图中的两个参数在帖子(第二行)之后变为空,在第一行之后,它们具有值.我不明白为什么,因为我来自另一个好的框架(JSF),我没有那样的问题.只是要知道,我正在使用spring 4,就像在教程中一样,为什么我有一个不在我视图中的参数?因为这些参数中的一些将保存一些数据,就像上次寄存器更新日期一样,最后一位用户更新了寄存器和我的应用程序ID.

任何人都可以帮我找到答案吗?

编辑:

经过一段时间和实验,我找到了解决问题的方法.按照我的代码片段,它的工作原理如下:

@Controller
@SessionAttributes({"obj"})
public class MyController {

    @RequestMapping(value = "/path", method = RequestMethod.GET)
    public ModelAndView myGet() {       
        ModelAndView modelAndView = new ModelAndView("view");
        MyClass object = new MyClass();
        modelAndView.addObject("obj", object );     
        return modelAndView;
    }

    @RequestMapping(value = "/path", method = RequestMethod.POST)
    public ModelAndView myPost(@ModelAttribute("obj") @Validated MyClass object, BindingResult result){

        ModelAndView modelAndView = new ModelAndView("view");       
        if(result.hasErrors())
            modelAndView.addObject("obj",object);
        else 
            service.save(object);
        return modelAndView;
    }   
}
Run Code Online (Sandbox Code Playgroud)

Gar*_*ero 6

这是预期的行为。你有modelresponse进入您的问候,同时view,但只要是http request/response做,它不存在了。您将把这些值保留在<form>标记中,并且需要在上提供这些值form submit

意思是,如果要发回这些值,则需要添加2个隐藏inputs来保存这两个值。

<form action="#" th:action="@{/greeting}" th:object="${greeting}" method="post">
    <p>Id: <input type="text" th:field="*{id}" /></p>
    <p>Message: <input type="text" th:field="*{content}" /></p>
    <input type="hidden" th:field="*{hour}" />
    <input type="hidden" th:field="*{longNumber}" />
    <p><input type="submit" value="Submit" /> <input type="reset" value="Reset" /></p>
</form>
Run Code Online (Sandbox Code Playgroud)