在使用rabbitmq的时候出现消息反序列化失败,如下异常:
Fatal message conversion error; message rejected; it will be dropped or routed to a dead letter exchange, if so configured
经过定位分析,原因是在MQ消息的生产端,设置了序列化转换Jackson2JsonMessageConverter,而默认的序列化类为SimpleMessageConverter。且在消费端没有设置反序列化转换。
解决方法:
因为消息是json串,使用String接收参数,再使用json工具类转化为对象;
@RabbitListener(bindings = @QueueBinding(
value = @Queue(value = MqConst.QUEUE_SMS, durable = "true"),
exchange = @Exchange(value = MqConst.EXCHANGE_DIRECT_SMS),
key = {MqConst.ROUTING_SMS}
))
public void send(String json,Message message, Channel channel) {
try {
//把json串转化为对应的对象
SmsVo smsVo = (SmsVo) JSONUtils.deserializeObject(json, SmsVo.class);
System.out.println(smsVo);
} catch (IOException e) {
e.printStackTrace();
}
}