gpt4 book ai didi

java - 无法在 Spring boot 中反序列化嵌套对象 "Role"

转载 作者:行者123 更新时间:2023-11-30 05:45:59 29 4
gpt4 key购买 nike

我是 Spring 启动新手。尝试从员工集合中获取与某些角色关联的所有文档。当尝试使用 mongo 存储库中的“findAll()”方法获取所有员工文档时,我得到了空角色,如下所示的输出。

Note : Roles are associated with each employee in MongoDB. 

enter image description here

REST 调用的输出

[
{
"id": 0,
"name": null,
"organization": null,
"email": null,
"password": null,
"roles": null,
"enabled": false,
"skills": null
},
{
"id": 123,
"name": "Harry",
"organization": "Hollywood",
"email": "harry@demo.com",
"password": "HarryMovie",
"roles": [],
"enabled": true,
"skills": [
"Performer",
"Entertainer",
"Actor",
"Producer"
]
},
{
"id": 1902,
"name": "Harry",
"organization": "Hollywood",
"email": "harry@demo.com",
"password": "HarryMovie",
"roles": [],
"enabled": true,
"skills": [
"Performer",
"Entertainer",
"Actor",
"Producer"
]
}
]

员工.class

package com.app.TestSecurityApp.Pojo;

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.DBRef;
import org.springframework.data.mongodb.core.mapping.Document;

import java.io.Serializable;
import java.util.List;
import java.util.Set;

@Document(collection="employee")
public class Employee implements Serializable {

@Id
private int id;
private String name;
private String organization;
private String email;
private String password;
@DBRef
private List<Role> roles;
private boolean enabled;
private List <String> skills;



public Employee() {
}


public List <Role> getRoles() {
return roles;
}

public void setRoles(List <Role> roles) {
this.roles = roles;
}

public boolean isEnabled() {
return enabled;
}

public void setEnabled(boolean enabled) {
this.enabled = enabled;
}

public String getPassword() {
return password;
}

public void setPassword(String password) {
this.password = password;
}



public String getEmail() {
return email;
}

public void setEmail(String email) {
this.email = email;
}


public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public String getorganization() {
return organization;
}

public void setorganization(String organization) {
this.organization = organization;
}

public List <String> getSkills() {
return skills;
}

public void setSkills(List <String> skills) {
this.skills = skills;
}



@Override
public String toString() {
return "Employee{" +
"id=" + id +
", name='" + name + '\'' +
", organization='" + organization + '\'' +
", email='" + email + '\'' +
", password='" + password + '\'' +
", roles=" + roles +
", enabled=" + enabled +
", skills=" + skills +
'}';
}
}

角色.class

package com.app.TestSecurityApp.Pojo;

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.index.IndexDirection;
import org.springframework.data.mongodb.core.index.Indexed;
import org.springframework.data.mongodb.core.mapping.Document;

import java.io.Serializable;


@Document(collection = "role")
public class Role{


@Id
private int id;

@Indexed(unique = true, direction = IndexDirection.DESCENDING, dropDups = true)
private String role;

public Role(String role) {
this.id = id;
this.role = role;
}

public Role() {
}

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

public Role(int id, String role) {
this.id = id;
this.role = role;
}

public String getRole() {
return role;
}

public void setRole(String role) {
this.role = role;
}

@Override
public String toString() {
return "Role{" +
"id=" + id +
", role='" + role + '\'' +
'}';
}
}

Spring Controller :

package com.app.TestSecurityApp.controllers;


import com.app.TestSecurityApp.Pojo.Employee;
import com.app.TestSecurityApp.Pojo.Role;
import com.app.TestSecurityApp.repository.EmployeeRepsitory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import java.lang.invoke.MethodType;
import java.util.ArrayList;
import java.util.List;

@RestController
@RequestMapping(value = "/employee")
public class EmployeeAccessControllers {

@Autowired
EmployeeRepsitory employeeRepsitory;


@RequestMapping(value = "/get", method = RequestMethod.GET,produces = MediaType.APPLICATION_JSON_VALUE)
public List<Employee> getEmployeeList() {
return employeeRepsitory.findAll();

}

@RequestMapping(value = "/set", method = RequestMethod.POST,produces = MediaType.APPLICATION_JSON_VALUE)
public Employee setEmployee(@RequestBody Employee employee) {

employeeRepsitory.save(employee);
return employee;

}


}

最佳答案

它没有正确序列化,因为它没有实现标记接口(interface)。将 public class Role 更改为 public class Role Implements Serialized

也不需要@DBRef,它用于将父级和子级作为单独的文档与引用一起存储在数据库中。向所有类添加序列化,使文档嵌入。

关于java - 无法在 Spring boot 中反序列化嵌套对象 "Role",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54841386/

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