上一篇文章我们讲了如何简单的springboot集成rocketmq(建议先看上一篇,此篇实在上一篇的基础上改进的),但在实际应用中,往往不会只有一个消息处理类,MessageProcessorImpl。消费者会收到不同topic,不同tag的的消息,这里我们来对我们的consumer类和消息处理类进行扩展一下。
一、修改我们的MessageProcessor接口。
改造一下:
package com.lw.study.rocketmq.message;
import com.lw.study.utils.JsonUtil2;
/**
* @author:
* @Date: 19:25 2019/1/15
*/
public interface MessageProcessor<T> {
boolean handleMessage(T message);
Class<T> getClazz();
default T transferMessage(String message) {
return JsonUtil2.fromJson(message, getClazz());
}
}
JsonUtil2-jackson序列化工具类,实现如下
package com.lw.study.utils;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
import java.io.IOException;
import java.io.InputStream;
/**
* @author
* jackson序列化工具
*/
public class JsonUtil2 {
public static final ObjectMapper MAPPER = new ObjectMapper();
/**
* 将对象转为json
* @param obj
* @return
*/
public static String toJson(Object obj) {
try {
return MAPPER.writeValueAsString(obj);
} catch (JsonProcessingException e) {
throw new RuntimeException(e);
}
}
/**
* 反序列化
* @param json
* @param clazz
* @param <T>
* @return
*/
public static <T> T fromJson(String json, Class<T> clazz) {
try {
return MAPPER.readValue(json, clazz);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
public static <T> T fromJson(String json, TypeReference<T> valueTypeRef) {
try {
return MAPPER.readValue(json, valueTypeRef);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
public static <T> T fromJson(InputStream stream, Class<T> clazz) {
try {
return MAPPER.readValue(stream, clazz);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
看一下整体的目录结构:
二、MessageProcessor实现类,这里我们列举的两个实现类做栗子,要更多的以此类推。
UserProcessorImpl.java
package com.lw.study.rocketmq.message.impl;
import com.lw.study.entity.User;
import com.lw.study.rocketmq.message.MessageProcessor;
import org.springframework.stereotype