问题描述
当我发送PUT请求时,控制台中显示405。
triggerPutRequest(id,stringDate,isDone,title)
.then((data) => {
console.log(data);
})
.catch((error) => {
alert(error);
});
function triggerPutRequest(isDone,id,title) {
return new Promise((resolve,reject) => {
$.ajax({
type: 'PUT',// http method
url: window.location + "api/tasks",//endpoint on our backend
contentType: "application/json; charset=utf-8",dataType: 'json',data: JSON.stringify({
"id": id,"title": title,"dueDate": convertDatetoString(new Date(datepicker.value)),"done": isDone,}),success: function (data) {
resolve(data)
},error: function () {
reject("string")
}
});
})
}
在Spring Boot中,我有一个简单的Task模型对象,其中省略了不相关的字段:
public class Task {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id",unique = true,nullable = false)
private int id;
@Column(name = "due_date",unique = false,nullable = false)
@JsonFormat(shape = JsonFormat.Shape.STRING,pattern = "dd-MM-yyyy")
private LocalDate dueDate;
@NotEmpty(message = "cannot be empty string")
@Column(name = "title",nullable = false)
private String title;
@Column(name = "done",nullable = false)
private boolean done;
}
Spring Boot中的控制器类和用于更新的终结点方法如下:
@RestController
@RequestMapping(value="/api/tasks")
public class TaskController {
@PutMapping(value="/",consumes="application/json")
public ResponseEntity<Task> updateTask(@RequestBody Task taskToBeUpdated){
//update object logic
return new ResponseEntity<Task>(newlyAddedTask,HttpStatus.OK);
}
}
解决方法
您的问题是这个
Could not resolve parameter [0] in public org.springframework.http.ResponseEntity<com.marbleit.todo.model.Task> com.marbleit.todo.controllers.TaskController.updateTask; HttpMessageNotReadableException: JSON parse error: Cannot deserialize value of type int from String "20-08-2020": not a valid Integer
您要发送的第一个值是一个字符串,并且您试图将其放入一个int。因此,您应该从客户端打印请求正文。
您在代码中混合了变量顺序:
triggerPutRequest(id,stringDate,...
function triggerPutRequest(isDone,id,...
也。
通常的做法是将针对客户端的api与针对数据库的api分开。
那是什么意思?好吧,这意味着,例如,如果您要更改数据库中的某些内容,由于直接将序列化/反序列化到数据库实体中,这将对客户端产生连锁反应。这使客户端与数据库紧密耦合。
因此,应避免从客户端获取数据并将其直接放入数据库实体中,而应使用间歇性对象来实例化TaskRequest
。然后从中获取数据并放入您的实体,以便客户端api和数据库api都可以彼此独立地发展。
啊...这是错误。.
在我的课堂上,我有这个:
public class Task {
...
@Column(name = "due_date",unique = false,nullable = false)
@JsonFormat(shape = JsonFormat.Shape.STRING,pattern = "yyyy-MM-dd")
private LocalDate dueDate;
...
}
不知何故,我试图在SO中以正确的方式发布消息,但是在我的代码中,这是错误的...我不知道如何实现这一目标。.一天半的时间就是浪费了。
关于托马斯的答案。.这样做不听起来有点多余吗?如果我在编辑对象时拥有了来自对象的所有数据,是否需要?为什么我不能仅仅将该对象用作新值的占位符。然后从数据库中获取具有相同ID的对象并设置新变量...