首页 > 解决方案 > 状态 400 和反序列化对象列表时出错。未找到默认构造函数

问题描述

我有这个 Spring 存储库:

public interface MessageRepository extends CrudRepository<MessageObject, String>{

public List<MessageObject> findByEmisorOrDestinatario(String emisor, String destinatario);
}

我的 DAO 是:

@Entity
@Table(name = "messages")
public class MessageObject implements Serializable{

private static final long serialVersionUID = 1L;
@Id
private String id;
private String emisor;
private String destinatario;
private String mensaje;
private String tipo;
@JsonFormat(pattern="yyyy-MM-dd")
private LocalDate fecha;
private String id_housing;

public MessageObject() {

  }

现在在我的控制器中,我想接收 Get 请求并在我的数据库中搜索:

@RestController
public class Controller {

@Autowired
private MessageRepository daoMsg;

@RequestMapping(value = "/Mensajes", method = RequestMethod.GET, produces=MediaType.APPLICATION_JSON_VALUE)
public List<MessageObject> enviados (@RequestParam("mail") String mail) {
    return daoMsg.findByEmisorOrDestinatario(mail, mail);   

}   

}

现在我可以从我的客户那里调用服务,所以:

ClientConfig config = new ClientConfig();
    Client client = ClientBuilder.newClient();

    WebTarget webResource = client.target("http://localhost:8082").path("/Mensajes").queryParam(mail);
    Invocation.Builder invocationBuilder = webResource.request(MediaType.APPLICATION_JSON);
    Response respuesta = invocationBuilder.get();
    int status = respuesta.getStatus();
    System.out.println(status);
    MessageObject[] listMessages = respuesta.readEntity(MessageObject[].class);

问题:我收到 400 状态码。反序列化 entityRead 也是一个错误。使用 Postman 执行请求不会返回错误并返回 JSON 格式的对象列表。

堆栈跟踪:

javax.ws.rs.ProcessingException: Error deserializing object from entity 
stream. Caused by: javax.json.bind.JsonbException: Can't create instance of 
a class: class [LMessages.MessageObject; 
No default constructor found. Caused by: java.lang.NoSuchMethodException: 
[LMessages.MessageObject;.<init>()

问题:我怎么知道我的代码在哪里失败?我是否很好地使用了服务调用?

我尝试过的事情:将 Mediatype 更改为 GenericType

编辑我尝试/从路径中删除,仍然获得状态 400

标签: jsonspringrestspring-bootjsonb

解决方案


Solved. Problem was I was using .queryparam without key-value structure. So changing .queryparam(mail) to .queryparam("mail", mail) solved it.


推荐阅读