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等会遇到同样的问题。