gpt4 book ai didi

java - Spring HATEOAS/Jackson 与资源和资源组装器

转载 作者:行者123 更新时间:2023-12-01 09:44:34 26 4
gpt4 key购买 nike

由于我的两个 JPA 实体(任务和作业)的双向关系中存在嵌套循环,我收到了 Jackson 错误。我开始研究并部分设法使用 @JsonManagedReference 和 @JsonBackReference 注释来解决此问题,但此方法仅在我在实体中使用注释时才有效,最终 JSON 序列化跳过我的 JobResource/JobResourceAssembler 和 TaskResource/TaskResourceAssembler,得到HATEOASless 和 HALless json 响应。

有没有办法让我的资源管理此序列化/反序列化?

一些代码(这样我得到了一个 json 响应,但交换了 HATEOASless 和 HALless):

@Entity
public class Task {

@Id
@GeneratedValue
private Long id;

@OneToMany(mappedBy="task")
@JsonManagedReference
private List<Job> job = new ArrayList<Job>();

//constructors, getter, setter...

@Entity
public class Job {

@Id
@GeneratedValue
private Long id;

@ManyToOne
@JsonBackReference
@JoinColumn(name = "task_id", updatable = true, insertable = true, nullable = true)
private Task task;

//constructor, setter, getter.

HATEOASless 响应(职位应该有链接)

{
"_embedded": {
"tasks": [
{
"name": "Task",
"description": "Task Description",
"createdAt": 1467583658749,
"updatedAt": null,
"deletedAt": null,
"isActive": true,
"estimatedStartDate": null,
"startDate": null,
"estimatedDateEnd": null,
"dateEnd": null,
"ids": 1,
"risk": null,
"job": [
{
"id": 2,
"name": "Job",
"description": "Job Description",
"createdAt": 1467583673859,
"updatedAt": null,
"deletedAt": null,
"isActive": true
},
{
"id": 3,
"name": "Job2",
"description": "Job Description",
"createdAt": 1467583676138,
"updatedAt": null,
"deletedAt": null,
"isActive": true
},
{
"id": 4,
"name": "Job3",
"description": "Job Description",
"createdAt": 1467583679339,
"updatedAt": null,
"deletedAt": null,
"isActive": true
}
],
"_links": {
"self": {
"href": "http://127.0.0.3:7890/api/v1/tasks/1"
},
"task": {
"href": "http://127.0.0.3:7890/api/v1/tasks/1"
}
}
}
]

最佳答案

我和我的同事解决了这个问题。首先:问题是 Jackson 直接序列化我们的相关实体,忽略了 Spring HATEOAS 的资源。这是因为我们的资源是由对象列表提供的,而不是资源列表,所以我们改变了这一点:

@Relation(collectionRelation = "tasks")
public class TaskResource extends ResourceSupport {

private List<JobResource> job = new ArrayList<JobResource>();

现在,我的资源列表是由资源而不是常规实体提供的,我们创建了一项服务,可以用常规作业填充列表作业。由于实体拥有自己的资源且基本相同,因此开发过程相当快:

public List<JobResource> findJobsFromTask(Long id) {

Task task = taskRepository.findOne(id);
List<Job> jobs = task.getJob();
List<JobResource> jobResourceList = new ArrayList<JobResource>();

for (Job job : jobs) {
jobResourceList.add(new JobResourceAssembler().toResource(job));
}
return jobResourceList;
}

有了这个,我们只需要修复汇编器,这样它就会添加新的 JobResource:

@Override
public TaskResource toResource(Task task) {
taskResource.setJob(taskService.findJobsFromTask(task.getId()));
}

这就是我们的解决方案。如果有更好的,请留下评论或其他答案来讨论。

编辑:当有 3 个以上嵌套资源时,可能需要手动将所有内容添加到资源中。假设我们有 3 种资源:项目 -> 任务 -> 工作。如果我们采用前面的方法,那么它将以嵌套空错误结束。服务:

@Override
public List<TaskResource> findTaskFromProject(Long id) {

Project project = projectRepository.findOne(id);
List<Task> tasks = project.getTask();
List<TaskResource> taskResourceList = new ArrayList<TaskResource>();

for (Task task : tasks) {
TaskResource taskResource = new TaskResource();
taskResource.setName(task.getName());
taskResource.setDescription(task.getDescription());
taskResource.setCreatedAt(task.getCreatedAt());
taskResource.setUpdatedAt(task.getUpdatedAt());
taskResource.setDeletedAt(task.getDeletedAt());
taskResource.setIsActive(task.getIsActive());
taskResource.setRisk(task.getRisk());
//taskResource.setDocumentState(task.getDocumentState());
taskResource.setEstimatedStartDate(task.getEstimatedStartDate());
taskResource.setStartDate(task.getStartDate());
taskResource.setEstimatedDateEnd(task.getEstimatedDateEnd());
taskResource.setDateEnd(task.getDateEnd());
taskResource.setIds(task.getId());
taskResource.setJob(taskService.findJobsFromTask(task.getId()));
taskResource.add(linkTo(TaskController.class).slash("").slash(task.getId()).withSelfRel());
taskResource.add(linkTo(TaskController.class).slash("").slash(task.getId()).withRel("task"));

taskResourceList.add(taskResource);
}

return taskResourceList;
}

这样,我们获得了一个项目 -> 任务 -> 作业 JSON 响应完整的 hatoas/hal。

关于java - Spring HATEOAS/Jackson 与资源和资源组装器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38174732/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com