【问题标题】:Getting Null Value from Form Submission从表单提交中获取空值
【发布时间】:2020-03-11 00:03:16
【问题描述】:

在我当前的项目中,我正在尝试实现一个用户注册表单,但是每次我尝试将用户数据提交到服务器时,模型对象都保持空值。

这是我的表格:

<form class="form-container" id="form" method="post" th:object="${command}" th:action="@{/usuario/register}">
  <div class="form-row">
    <div class="col-75">
      <input type="text" th:field="*{username}" placeholder="Login"/>
    </div>
  </div>

  <div class="form-row">
    <div class="col-75">
      <input type="password" th:field="*{password}" placeholder="Senha"/>
    </div>
  </div>

  <div class="form-row">
    <div class="col-75">
      <input type="text" th:field="*{firstName}" placeholder="Nome"/>
    </div>
  </div>

  <div class="form-row">
    <div class="col-75">
      <input type="text" th:field="*{lastName}" placeholder="Sobrenome"/>
    </div>
  </div>

  <div class="form-row">
    <div class="col-75">
      <input type="email" th:field="*{email}" placeholder="E-mail"/>
    </div>
  </div>

  <div class="form-row">
    <div class="col-75">
      <button type="button" class="button" onclick="register();">Cadastre-se</button>
    </div>
  </div>

  <div class="alert-ok" id="ok" style="display: none;">
    <span class="closebtn" onclick="this.parentElement.style.display='none';">&times;</span>
    <strong>Sucesso!</strong> Cadastro realizado com sucesso.
  </div>

  <div class="alert-error" id="error" style="display: none;">
    <span class="closebtn" onclick="this.parentElement.style.display='none';">&times;</span>
    <strong>Erro!</strong> Não foi possivel realizar o cadastro.
  </div>
</form>

在我拥有的控制器中:

  @RequestMapping(value = "/register", method=RequestMethod.GET)
  public String formRegister(Model model) {
    model.addAttribute("command", new Usuario());
    return "register";
  }

  @RequestMapping(value = "/register", method=RequestMethod.POST)
  @ResponseBody
  public void doRegister(@ModelAttribute("usuario") Usuario object) throws Exception {
    this.serv.register(object);
  }

(我也试过:doRegister(@Valid Usuario object, BindingResult result) 但也不起作用 - 同样的问题)

在我的服务类中,我得到了这个代码:

  public void register(Usuario novo) throws Exception {
    novo.setEnabled(true);
    novo.setLocked(false);
    novo.setCredenciais(new HashSet<Credencial>());
    Credencial credencial = credencialDao.findBy("nome", "web");
    novo.getCredenciais().add(credencial);
    this.dao.insert(novo);
  }

我的模型类:

@Entity
public class Usuario extends Model implements UserDetails {
  @Id
  @GeneratedValue(strategy=GenerationType.IDENTITY)
  private Integer id;

  @Column
  private String username;

  @Column
  private String password;

  @Column
  private String firstName;

  @Column
  private String lastName;

  @Column
  private String email;

  @OneToMany(fetch = FetchType.EAGER)
  private Set<org.loja.model.credencial.Credencial> credenciais;

  @Column
  private Date dataExpiracao;

  @Column
  private Boolean enabled;

  @Column
  private Boolean locked;

  @OneToOne(fetch = FetchType.EAGER)
  private org.loja.model.cesta.Cesta cesta;

  @OneToMany(fetch = FetchType.EAGER, mappedBy = "usuario")
  private Set<org.loja.model.pedido.Pedido> pedidos;
}

任何人都可以看到这里有什么问题吗?我被这个问题困了几个小时,但不明白是什么导致了这个问题。我认为该代码与我在网上搜索的处理相同操作的其他代码看起来非常相似。

更新

function register() {
  var formData = new FormData(document.getElementById("form"));
  var url = document.getElementById("form").action;

  var xhr = new XMLHttpRequest();
  xhr.open("POST", url);
  xhr.onload = function(event) {
    event.preventDefault();
    var result = this.responseText;
    if(result == "")
      document.getElementById("ok").style.display = 'block';
    else
      document.getElementById("error").style.display = 'block';
  };
  xhr.send(formData);
}

【问题讨论】:

  • 您好,能否附上更多信息? JavaScript register() 函数除了提交表单还有什么作用?您是否检查过您的浏览器网络控制台,以便确定您在 POST 请求正文中向服务器发送了哪些数据?你检查过e。 G。 spring.io/guides/gs/handling-form-submission 比较?取而代之的是一个简单的输入提交按钮 - 您是否也尝试过该变体?
  • @PetrBodnár 添加了处理表单提交的 javascript 函数。是的,我检查了浏览器网络控制台,所有参数都正确显示在那里。
  • 另外,您是否 100% 确定“模型对象保持为空值”。不是它的字段保持为空(“...具有空值s”)吗?那么你的问题的答案大概就在这里:*.com/questions/40896217/….
  • @PetrBodnár 不。我单独检查每个参数(使用 BindingResult)和对象本身(在控制器中)。两者都收到一个空值。
  • @PetrBodnár 关于你告诉我的链接,我的所有模型层都有一个带有 PropertyEditorSupport 类的 InitBinder 方法。

标签: spring forms spring-boot form-submit modelattribute


【解决方案1】:

我设法通过更改参数解决了这个问题:

@ModelAttribute("usuario") Usuario object

到:

@ModelAttribute("command") Usuario object

以某种方式使 ModelAttribute 的名称与方法 public String formRegister(Model model) 中使用的名称相同。

【讨论】: