1
This commit is contained in:
53
src/main/java/cn/van/business/mq/MessageConsumerService.java
Normal file
53
src/main/java/cn/van/business/mq/MessageConsumerService.java
Normal file
@@ -0,0 +1,53 @@
|
||||
package cn.van.business.mq;
|
||||
|
||||
import cn.hutool.core.util.ObjectUtil;
|
||||
import cn.hutool.http.HttpRequest;
|
||||
import cn.hutool.json.JSONUtil;
|
||||
import com.alibaba.fastjson2.JSONObject;
|
||||
import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;
|
||||
import org.apache.rocketmq.spring.core.RocketMQListener;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import static cn.van.business.util.WXUtil.WX_BASE_URL;
|
||||
|
||||
/**
|
||||
* @author Leo
|
||||
* @version 1.0
|
||||
* @create 2024/12/1 上午2:06
|
||||
* @description:
|
||||
*/
|
||||
@Service
|
||||
@RocketMQMessageListener(topic = "wx-message", consumerGroup = "${rocketmq.consumer.group}")
|
||||
public class MessageConsumerService implements RocketMQListener<JSONObject> {
|
||||
|
||||
private static final Logger logger = LoggerFactory.getLogger(MessageConsumerService.class);
|
||||
|
||||
@Override
|
||||
public void onMessage(JSONObject jsonObject) {
|
||||
// 处理消息
|
||||
try {
|
||||
String responseStr = HttpRequest.post(WX_BASE_URL)
|
||||
.body(JSONUtil.toJsonStr(jsonObject))
|
||||
.execute()
|
||||
.body();
|
||||
|
||||
if (ObjectUtil.isNotEmpty(responseStr)) {
|
||||
JSONObject response = JSONObject.parseObject(responseStr);
|
||||
if (response.getInteger("code") != 200) {
|
||||
// TODO: 如果需要处理错误,您可以在这里添加逻辑
|
||||
throw new RuntimeException("消息发送失败: " + responseStr);
|
||||
}
|
||||
logger.info("消息成功发送并得到响应:{}", response);
|
||||
} else {
|
||||
throw new RuntimeException("消息发送失败,没有收到响应");
|
||||
|
||||
}
|
||||
} catch (Exception e) {
|
||||
logger.error("处理消息时发生错误", e);
|
||||
throw e; // 重抛异常使得 RocketMQ 可以捕获到这个异常
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user