表单不发布值,“浏览器编辑和重新发送”正在运行

时间:2017-01-07 17:57:13

标签: html spring-mvc model-view-controller controller spring-web

我正在使用Spring mvc web提交表单。表单呈现正常但是当我提交此表单时,我得到http状态代码400,但是如果我使用firefox的“编辑并重新发送”功能,它会触及相应的控制器方法(当我提交此表单时不会发生来自HTML)。但是再次出现另一个问题,当我检查我的modelAttribute对象时,在该控制器方法中,我发现此对象中的所有内容都为null。但由于我在此表单中提交值,情况并非如此。

    <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
    <%@ include file="include.jsp"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
    <title>${message}</title>
    </head>
    <body>
        General:
<br>
<form:form modelAttribute="initialMatchConfiguration" action="../match/configure" method="post" >
    Date and time:
    <form:input path="dateAndTimeOfMatch" type="text" />
    <br> Match Type:
    <form:select path="matchType">
        <option value="friendly">friendly</option>
        <option value="international">international</option>
        <option value="domestic">domestic</option>
        <option value="local">local tournament</option>
    </form:select>
    <br> Match Rules Configuration:
    <form:select path="matchConfigurationId">
        <option value="0">Random</option>
        <option value="1">T20</option>
        <option value="2">One Day</option>
        <option value="3">Test</option>
    </form:select>
    <button type="button">Create a new rule configuration</button>
    <br> Tournament:
    <form:input type="text" path="tournament" />
    <form:hidden path="tournamentId"/>
    <button type="button">Create a new Tournament</button>
    <br> Played at Stadium:
    <form:input type="text" path="stadium" />
    <form:hidden path="stadiumId"/>
    <button type="button">Create a new stadium</button>
    <br> <input type="submit" value="Save" />
</form:form>
    </body>
    </html>

以下方法是渲染表格:

    @RequestMapping(value = "/match/create", method = RequestMethod.GET)
public String  createMatch(Model model){
    model.addAttribute("initialMatchConfiguration", new InitialMatchConfiguration());
    return "config-match-initial";
}

以下方法是提交表格:

@RequestMapping(value = "/match/configure", method = RequestMethod.POST)
public String  configureMatch(@ModelAttribute("initialMatchConfiguration") InitialMatchConfiguration initialMatchConfig, Model model){
    System.out.println(initialMatchConfig);
    return "config-match-team";
} 

InitialMatchConfiguration类

public class InitialMatchConfiguration {
private Date dateAndTimeOfMatch;
private String matchType;
private Long matchConfigurationId;
private Long tournamentId;
private Long stadiumId;
private String tournament;
private String stadium;
public Date getDateAndTimeOfMatch() {
    return dateAndTimeOfMatch;
}
public void setDateAndTimeOfMatch(Date dateAndTimeOfMatch) {
    this.dateAndTimeOfMatch = dateAndTimeOfMatch;
}
public String getMatchType() {
    return matchType;
}
public void setMatchType(String matchType) {
    this.matchType = matchType;
}
public Long getMatchConfigurationId() {
    return matchConfigurationId;
}
public void setMatchConfigurationId(Long matchConfigurationId) {
    this.matchConfigurationId = matchConfigurationId;
}
public Long getTournamentId() {
    return tournamentId;
}
public void setTournamentId(Long tournamentId) {
    this.tournamentId = tournamentId;
}
public Long getStadiumId() {
    return stadiumId;
}
public void setStadiumId(Long stadiumId) {
    this.stadiumId = stadiumId;
}
public String getTournament() {
    return tournament;
}
public void setTournament(String tournament) {
    this.tournament = tournament;
}
public String getStadium() {
    return stadium;
}
public void setStadium(String stadium) {
    this.stadium = stadium;
}

}

从firefox编辑并重新发送工具时触发请求:

请求标题:

POST http://localhost:8090/scoreboard.web/score/match/configure

Host: localhost:8090
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:51.0) Gecko/20100101    Firefox/51.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
Referer: http://localhost:8090/scoreboard.web/score/match/create
Connection: keep-alive
Upgrade-Insecure-Requests: 1
Cache-Control: max-age=0

请求正文:

Content-Type: application/x-www-form-urlencoded
Content-Length: 107

dateAndTimeOfMatch=&matchType=friendly&matchConfigurationId=0&tournament=&tournamentId=&stadium=&stadiumId=

1 个答案:

答案 0 :(得分:1)

根本原因: 将dateAndTimeOfMatch的类型从文本更改为日期

<强>

并在FORM类中:

    @DateTimeFormat(iso = DateTimeFormat.ISO.DATE)
    private Date dateAndTimeOfMatch;

表格:

 <form:form modelAttribute="initialMatchConfiguration" action="../match/configure" method="post" >
Date and time:
<form:input path="dateAndTimeOfMatch" type="date" />
<br> Match Type:
<form:select path="matchType">
    <option value="friendly">friendly</option>
    <option value="international">international</option>
    <option value="domestic">domestic</option>
    <option value="local">local tournament</option>
</form:select>
<br> Match Rules Configuration:
<form:select path="matchConfigurationId">
    <option value="0">Random</option>
    <option value="1">T20</option>
    <option value="2">One Day</option>
    <option value="3">Test</option>
</form:select>
<button type="button">Create a new rule configuration</button>
<br> Tournament:
<form:input type="text" path="tournament" />
<form:hidden path="tournamentId"/>
<button type="button">Create a new Tournament</button>
<br> Played at Stadium:
<form:input type="text" path="stadium" />
<form:hidden path="stadiumId"/>
<button type="button">Create a new stadium</button>
<br> <input type="submit" value="Save" />

InitialMatchConfiguration.java:

 public class InitialMatchConfiguration {

@DateTimeFormat(iso = DateTimeFormat.ISO.DATE)
private Date dateAndTimeOfMatch;
private String matchType;
private Long matchConfigurationId;  
private Long tournamentId;
private Long stadiumId;
private String tournament;
private String stadium;

 //getters and setters

}

控制器:

@RequestMapping(value = "/match/configure", method = RequestMethod.POST)
    public String  configureMatch(@ModelAttribute("initialMatchConfiguration") InitialMatchConfiguration initialMatchConfig, Model model){
        System.out.println(initialMatchConfig.toString());

        return "config-match-team";
    } 

回应:

** InitialMatchConfiguration [dateAndTimeOfMatch = Tue Jan 10 05:30:00 IST 2017,matchType = international,matchConfigurationId = 2,tournamentId = null,stadiumId = null,tournament = sa,stadium =] **