在Spark / Java

时间:2016-02-29 21:48:53

标签: java postgresql http velocity spark-framework

utI有一个Spark / Velocity模板应用程序,我正在尝试使用PUT路由遵循良好的REST约定来更新我的数据库中的记录。

在我的HTML表单中,我获得了在postgres DB中更新记录所需的信息:

<form action="/tasks/$editTask.getId()">
  <input id="description" name="description" type="text" value="$editTask.getDescription()">
  <input type="date" name="duedate" value="$editTask.getDueDate()">
  <button type="submit">Edit task</button>
</form>

但我很困惑如何在我的应用程序中捕获它。 java的。如果我改变方法method="PUT"没有任何反应。以下是我的PUT路线:

post("/tasks/:id", (request,response) -> {
    HashMap<String, Object> model = new HashMap<String, Object>();
    int id = Integer.parseInt(request.params("id"));
    Task editTask = Task.find(id);
    String newDescription = request.queryParams("description");
    String newDueDate = request.queryParams("duedate");

    editTask.update(newDescription, newDueDate);
    model.put("editTask", editTask);
    model.put("template", "templates/tasks.vtl");
    return new ModelAndView(model, layout);
}, new VelocityTemplateEngine());

我尝试添加隐藏的输入字段:

<input type="hidden" name="_method" value="put">到我的表单但它没有做任何事情。当我尝试访问put路径时,我没有遇到任何错误,只是没有任何反应。我已经测试了我的代码以更新POST路由上的记录,并且它可以毫无障碍地工作。

非常感谢您关于如何使用PUT的任何指示 我想使用DELETE等会遇到同样的问题。

0 个答案:

没有答案