更新了商品类别
This commit is contained in:
parent
7b08c42c68
commit
f34a57e8cb
5
pom.xml
5
pom.xml
|
@ -185,6 +185,11 @@
|
||||||
<artifactId>gson</artifactId>
|
<artifactId>gson</artifactId>
|
||||||
<version>2.8.8</version>
|
<version>2.8.8</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<!-- rabbitmq依赖-->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-amqp</artifactId>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -7,8 +7,6 @@ import org.springframework.core.Ordered;
|
||||||
import org.springframework.web.cors.CorsConfiguration;
|
import org.springframework.web.cors.CorsConfiguration;
|
||||||
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
|
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
|
||||||
import org.springframework.web.filter.CorsFilter;
|
import org.springframework.web.filter.CorsFilter;
|
||||||
import org.springframework.web.servlet.config.annotation.CorsRegistry;
|
|
||||||
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 跨域配置
|
* 跨域配置
|
||||||
|
|
|
@ -3,7 +3,6 @@ package com.cultural.heritage.config;
|
||||||
import com.baomidou.mybatisplus.annotation.DbType;
|
import com.baomidou.mybatisplus.annotation.DbType;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
|
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
|
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
|
||||||
import org.mybatis.spring.annotation.MapperScan;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
package com.cultural.heritage.config;
|
||||||
|
|
||||||
|
import org.springframework.amqp.support.converter.DefaultClassMapper;
|
||||||
|
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
|
||||||
|
import org.springframework.amqp.support.converter.MessageConverter;
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
public class RabbitMQConfig {
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public MessageConverter jsonToMapMessageConverter() {
|
||||||
|
DefaultClassMapper defaultClassMapper = new DefaultClassMapper();
|
||||||
|
defaultClassMapper.setTrustedPackages("com.cultural.heritage.utils.MultiDelayMessage"); // trusted packages
|
||||||
|
Jackson2JsonMessageConverter jackson2JsonMessageConverter = new Jackson2JsonMessageConverter();
|
||||||
|
jackson2JsonMessageConverter.setClassMapper(defaultClassMapper);
|
||||||
|
return jackson2JsonMessageConverter;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public MessageConverter messageConverter(){
|
||||||
|
return new Jackson2JsonMessageConverter();
|
||||||
|
}
|
||||||
|
}
|
10
src/main/java/com/cultural/heritage/constant/MqConstant.java
Normal file
10
src/main/java/com/cultural/heritage/constant/MqConstant.java
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
package com.cultural.heritage.constant;
|
||||||
|
|
||||||
|
public interface MqConstant {
|
||||||
|
|
||||||
|
String DELAY_EXCHANGE = "delay.topic";
|
||||||
|
|
||||||
|
String DELAY_ORDER_QUEUE = "order.delay.queue";
|
||||||
|
|
||||||
|
String DELAY_ORDER_ROUTING_KEY = "order.key";
|
||||||
|
}
|
|
@ -0,0 +1,97 @@
|
||||||
|
package com.cultural.heritage.controller.good;
|
||||||
|
|
||||||
|
|
||||||
|
import com.cultural.heritage.annotation.AuthCheck;
|
||||||
|
import com.cultural.heritage.common.BaseResponse;
|
||||||
|
import com.cultural.heritage.common.ErrorCode;
|
||||||
|
import com.cultural.heritage.common.ResultUtils;
|
||||||
|
import com.cultural.heritage.constant.UserConstant;
|
||||||
|
import com.cultural.heritage.exception.BusinessException;
|
||||||
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
|
import jakarta.annotation.Resource;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.springframework.data.redis.core.RedisTemplate;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 节日管理接口
|
||||||
|
*/
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/festival")
|
||||||
|
@Slf4j
|
||||||
|
@Tag(name = "节日管理模块")
|
||||||
|
public class FestivalController {
|
||||||
|
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private RedisTemplate<String, Object> redisTemplate;
|
||||||
|
|
||||||
|
// 节日集合的键
|
||||||
|
private static final String FESTIVAL_KEY = "festivalList";
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Web端管理员添加节日项
|
||||||
|
* @param value 添加的节日项
|
||||||
|
*/
|
||||||
|
@GetMapping("/add")
|
||||||
|
@Operation(summary = "Web端管理员添加节日项", description = "参数:节日项名称,权限:管理员(admin, boss),方法名:addFestivalElement")
|
||||||
|
@AuthCheck(mustRole = UserConstant.ADMIN_ROLE)
|
||||||
|
public BaseResponse<Boolean> addFestivalElement(@RequestParam String value) {
|
||||||
|
if (StringUtils.isBlank(value)) {
|
||||||
|
throw new BusinessException(ErrorCode.PARAMS_ERROR);
|
||||||
|
}
|
||||||
|
if (isElementExistInList(value)) {
|
||||||
|
throw new BusinessException(ErrorCode.OPERATION_ERROR, "该节日项已存在");
|
||||||
|
}
|
||||||
|
redisTemplate.opsForList().rightPush(FESTIVAL_KEY, value);
|
||||||
|
return ResultUtils.success(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Web端管理员查询节日集合
|
||||||
|
* @return 节日列表
|
||||||
|
*/
|
||||||
|
@GetMapping("/get")
|
||||||
|
@Operation(summary = "Web端管理员查询节日集合", description = "参数:无,权限:管理员(admin, boss),方法名:getFestivalList")
|
||||||
|
@AuthCheck(mustRole = UserConstant.ADMIN_ROLE)
|
||||||
|
public BaseResponse<List<Object>> getFestivalList() {
|
||||||
|
List<Object> festivalList = redisTemplate.opsForList().range(FESTIVAL_KEY, 0, -1);
|
||||||
|
return ResultUtils.success(festivalList);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Web端管理员删除节日项
|
||||||
|
* @param value 删除的节日项
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@GetMapping("/delete")
|
||||||
|
@Operation(summary = "Web端管理员删除节日项", description = "参数:无,权限:管理员(admin, boss),方法名:deleteFestivalElement")
|
||||||
|
@AuthCheck(mustRole = UserConstant.ADMIN_ROLE)
|
||||||
|
public BaseResponse<Boolean> deleteFestivalElement(@RequestParam String value) {
|
||||||
|
if (!isElementExistInList(value)) {
|
||||||
|
throw new BusinessException(ErrorCode.OPERATION_ERROR, "该节日项不存在");
|
||||||
|
}
|
||||||
|
redisTemplate.opsForList().remove(FESTIVAL_KEY, 1, value);
|
||||||
|
return ResultUtils.success(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// 检查元素是否存在
|
||||||
|
private boolean isElementExistInList(@RequestParam String value) {
|
||||||
|
List<Object> festivalList = redisTemplate.opsForList().range(FESTIVAL_KEY, 0, -1);
|
||||||
|
return festivalList != null && festivalList.contains(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -7,6 +7,7 @@ import com.cultural.heritage.annotation.AuthCheck;
|
||||||
import com.cultural.heritage.common.BaseResponse;
|
import com.cultural.heritage.common.BaseResponse;
|
||||||
import com.cultural.heritage.common.ErrorCode;
|
import com.cultural.heritage.common.ErrorCode;
|
||||||
import com.cultural.heritage.common.ResultUtils;
|
import com.cultural.heritage.common.ResultUtils;
|
||||||
|
import com.cultural.heritage.constant.MqConstant;
|
||||||
import com.cultural.heritage.constant.OrderStatusConstant;
|
import com.cultural.heritage.constant.OrderStatusConstant;
|
||||||
import com.cultural.heritage.constant.UserConstant;
|
import com.cultural.heritage.constant.UserConstant;
|
||||||
import com.cultural.heritage.exception.BusinessException;
|
import com.cultural.heritage.exception.BusinessException;
|
||||||
|
@ -26,11 +27,13 @@ import com.cultural.heritage.service.good.GoodService;
|
||||||
import com.cultural.heritage.service.order.OrderItemService;
|
import com.cultural.heritage.service.order.OrderItemService;
|
||||||
import com.cultural.heritage.service.order.OrderService;
|
import com.cultural.heritage.service.order.OrderService;
|
||||||
import com.cultural.heritage.service.user.UserService;
|
import com.cultural.heritage.service.user.UserService;
|
||||||
|
import com.cultural.heritage.utils.MultiDelayMessage;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
import jakarta.servlet.http.HttpServletRequest;
|
import jakarta.servlet.http.HttpServletRequest;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
||||||
import org.springframework.beans.BeanUtils;
|
import org.springframework.beans.BeanUtils;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
|
@ -39,7 +42,10 @@ import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("/order")
|
@RequestMapping("/order")
|
||||||
|
@ -74,6 +80,11 @@ public class OrderController {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private RabbitTemplate rabbitTemplate;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 用户通过购物车创建订单
|
* 用户通过购物车创建订单
|
||||||
*/
|
*/
|
||||||
|
@ -174,6 +185,18 @@ public class OrderController {
|
||||||
orderMainInfoAddRequest.setTotalAmount(totalAmount);
|
orderMainInfoAddRequest.setTotalAmount(totalAmount);
|
||||||
// 创建通用订单(常规类和服务类商品)
|
// 创建通用订单(常规类和服务类商品)
|
||||||
Long orderId = orderService.createCommonOrder(orderMainInfoAddRequest, userId, false, null);
|
Long orderId = orderService.createCommonOrder(orderMainInfoAddRequest, userId, false, null);
|
||||||
|
|
||||||
|
// 延迟检查订单状态信息
|
||||||
|
MultiDelayMessage<Long> msg = new MultiDelayMessage<>(orderId,
|
||||||
|
10000L, 10000L, 10000L, 15000L, 15000L, 30000L, 30000L, 60000L, 60000L, 120000L, 300000L, 600000L, 600000L);
|
||||||
|
// 10000L, 10000L, 10000L, 15000L, 15000L, 30000L, 30000L, 60000L, 60000L, 120000L, 300000L, 600000L, 600000L
|
||||||
|
int delayValue = msg.removeNextDelay().intValue();
|
||||||
|
rabbitTemplate.convertAndSend(MqConstant.DELAY_EXCHANGE,
|
||||||
|
MqConstant.DELAY_ORDER_ROUTING_KEY, msg, message -> {
|
||||||
|
// 添加延迟消息属性
|
||||||
|
message.getMessageProperties().setDelay(delayValue);
|
||||||
|
return message;
|
||||||
|
});
|
||||||
return ResultUtils.success(orderId);
|
return ResultUtils.success(orderId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -84,10 +84,10 @@ public class WeChatLogisticsController {
|
||||||
public BaseResponse<WxAccessToken> getAccessToken(HttpServletRequest request) {
|
public BaseResponse<WxAccessToken> getAccessToken(HttpServletRequest request) {
|
||||||
userService.getLoginUser(request);
|
userService.getLoginUser(request);
|
||||||
String accessToken = (String) redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
String accessToken = (String) redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
||||||
if (accessToken == null) {
|
// if (accessToken == null) {
|
||||||
weChatLogisticsService.addAccessToken();
|
// weChatLogisticsService.addAccessToken();
|
||||||
accessToken = (String) redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
// accessToken = (String) redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
||||||
}
|
// }
|
||||||
WxAccessToken wxAccessToken = WxAccessToken.builder()
|
WxAccessToken wxAccessToken = WxAccessToken.builder()
|
||||||
.access_token(accessToken)
|
.access_token(accessToken)
|
||||||
.expires_in("7200").build();
|
.expires_in("7200").build();
|
||||||
|
@ -107,10 +107,10 @@ public class WeChatLogisticsController {
|
||||||
User loginUser = userService.getLoginUser(request);
|
User loginUser = userService.getLoginUser(request);
|
||||||
String miniOpenId = loginUser.getMiniOpenId();
|
String miniOpenId = loginUser.getMiniOpenId();
|
||||||
String accessToken = (String) redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
String accessToken = (String) redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
||||||
if (accessToken == null) {
|
// if (accessToken == null) {
|
||||||
weChatLogisticsService.addAccessToken();
|
// weChatLogisticsService.addAccessToken();
|
||||||
accessToken = (String) redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
// accessToken = (String) redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
||||||
}
|
// }
|
||||||
Long id = commonRequest.getId();
|
Long id = commonRequest.getId();
|
||||||
Order order = orderService.getById(id);
|
Order order = orderService.getById(id);
|
||||||
ThrowUtils.throwIf(order == null, ErrorCode.SYSTEM_ERROR, "订单不存在");
|
ThrowUtils.throwIf(order == null, ErrorCode.SYSTEM_ERROR, "订单不存在");
|
||||||
|
|
|
@ -0,0 +1,68 @@
|
||||||
|
package com.cultural.heritage.listener;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
||||||
|
import com.cultural.heritage.common.ErrorCode;
|
||||||
|
import com.cultural.heritage.constant.MqConstant;
|
||||||
|
import com.cultural.heritage.constant.OrderStatusConstant;
|
||||||
|
import com.cultural.heritage.exception.ThrowUtils;
|
||||||
|
import com.cultural.heritage.model.entity.Order;
|
||||||
|
import com.cultural.heritage.service.order.OrderService;
|
||||||
|
import com.cultural.heritage.utils.MultiDelayMessage;
|
||||||
|
import jakarta.annotation.Resource;
|
||||||
|
import org.springframework.amqp.rabbit.annotation.Exchange;
|
||||||
|
import org.springframework.amqp.rabbit.annotation.Queue;
|
||||||
|
import org.springframework.amqp.rabbit.annotation.QueueBinding;
|
||||||
|
import org.springframework.amqp.rabbit.annotation.RabbitListener;
|
||||||
|
import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class OrderStatusListener {
|
||||||
|
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private OrderService orderService;
|
||||||
|
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private RabbitTemplate rabbitTemplate;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@RabbitListener(bindings = @QueueBinding(
|
||||||
|
value = @Queue(MqConstant.DELAY_ORDER_QUEUE),
|
||||||
|
exchange = @Exchange(name = MqConstant.DELAY_EXCHANGE, delayed = "true"),
|
||||||
|
key = MqConstant.DELAY_ORDER_ROUTING_KEY
|
||||||
|
))
|
||||||
|
public void listenDelayMessage(MultiDelayMessage<Long> msg) {
|
||||||
|
System.out.println("\n\n\n\n\nOrderStatusListener.listenerDelayMessage msg-------------------------------->:" + msg);
|
||||||
|
//1.获取消息中的订单id
|
||||||
|
Long orderId = msg.getData();
|
||||||
|
//2.查询订单,判断状态是否为待支付
|
||||||
|
Order order = orderService.getById(orderId);
|
||||||
|
// 订单不存在或者订单已经支付
|
||||||
|
if (order == null || !order.getOrderStatus().equals(OrderStatusConstant.PENDING_PAYMENT)) {
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
//3.订单未支付,判断是否还有剩余延时时间
|
||||||
|
if (msg.hasNextDelay()) {
|
||||||
|
// 有延迟时间,需要重发延迟消息,先获取延迟时间的int值
|
||||||
|
// 发送延时消息
|
||||||
|
int delayValue = msg.removeNextDelay().intValue();
|
||||||
|
rabbitTemplate.convertAndSend(MqConstant.DELAY_EXCHANGE,
|
||||||
|
MqConstant.DELAY_ORDER_ROUTING_KEY, msg, message -> {
|
||||||
|
// 添加延迟消息属性
|
||||||
|
message.getMessageProperties().setDelay(delayValue);
|
||||||
|
return message;
|
||||||
|
});
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
// 没有剩余延时时间,说明订单超时未支付,需取消订单
|
||||||
|
UpdateWrapper<Order> updateWrapper = new UpdateWrapper<>();
|
||||||
|
updateWrapper.eq("id", orderId).set("orderStatus", OrderStatusConstant.TRANSACTION_CLOSED);
|
||||||
|
boolean update = orderService.update(updateWrapper);
|
||||||
|
ThrowUtils.throwIf(!update, ErrorCode.SYSTEM_ERROR, "订单状态更新失败");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -1,18 +1,15 @@
|
||||||
package com.cultural.heritage.test;
|
package com.cultural.heritage.test;
|
||||||
|
|
||||||
import com.cultural.heritage.mapper.GoodMapper;
|
|
||||||
import jakarta.annotation.Resource;
|
|
||||||
import org.springframework.data.redis.core.StringRedisTemplate;
|
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
@Component
|
@Component
|
||||||
public class TestRedis {
|
public class TestRedis {
|
||||||
|
|
||||||
@Resource
|
// @Resource
|
||||||
private StringRedisTemplate stringRedisTemplate;
|
// private StringRedisTemplate stringRedisTemplate;
|
||||||
|
//
|
||||||
@Resource
|
// @Resource
|
||||||
private GoodMapper goodMapper;
|
// private GoodMapper goodMapper;
|
||||||
//
|
//
|
||||||
// @PostConstruct
|
// @PostConstruct
|
||||||
// public void test() {
|
// public void test() {
|
||||||
|
|
|
@ -0,0 +1,59 @@
|
||||||
|
package com.cultural.heritage.utils;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
|
import java.io.Serial;
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
public class MultiDelayMessage<T> implements Serializable {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息体
|
||||||
|
*/
|
||||||
|
private T data;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 记录延时时间的集合
|
||||||
|
*/
|
||||||
|
private List<Long> delayMillis;
|
||||||
|
|
||||||
|
public MultiDelayMessage(T data, List<Long> delayMillis) {
|
||||||
|
this.data = data;
|
||||||
|
this.delayMillis = delayMillis;
|
||||||
|
}
|
||||||
|
|
||||||
|
public MultiDelayMessage(T data, Long...delayMillis) {
|
||||||
|
this.data = data;
|
||||||
|
this.delayMillis = new ArrayList<>(Arrays.asList(delayMillis));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取并移除下一个延迟时间
|
||||||
|
* @return 集合中第一个延迟时间
|
||||||
|
*/
|
||||||
|
public Long removeNextDelay() {
|
||||||
|
return delayMillis.remove(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否有下一个延迟时间
|
||||||
|
*/
|
||||||
|
public boolean hasNextDelay() {
|
||||||
|
return !delayMillis.isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@Serial
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -5,15 +5,31 @@ spring:
|
||||||
url: jdbc:mysql://154.8.193.216:3306/feiyi?serverTimezone=Asia/Shanghai
|
url: jdbc:mysql://154.8.193.216:3306/feiyi?serverTimezone=Asia/Shanghai
|
||||||
username: feiyi
|
username: feiyi
|
||||||
password: 123456asd
|
password: 123456asd
|
||||||
|
hikari:
|
||||||
|
maximum-pool-size: 20
|
||||||
|
max-lifetime: 120000
|
||||||
|
|
||||||
# 测试环境
|
rabbitmq:
|
||||||
|
host: 123.249.108.160
|
||||||
|
port: 5672
|
||||||
|
username: chenxinzhi
|
||||||
|
password: yuanteng
|
||||||
|
virtual-host: vhost1
|
||||||
|
listener:
|
||||||
|
simple:
|
||||||
|
prefetch: 1
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# 测试环境
|
||||||
# driver-class-name: com.mysql.cj.jdbc.Driver
|
# driver-class-name: com.mysql.cj.jdbc.Driver
|
||||||
# url: jdbc:mysql://123.249.108.160:3306/feiyi?serverTimezone=Asia/Shanghai
|
# url: jdbc:mysql://123.249.108.160:3306/feiyi?serverTimezone=Asia/Shanghai
|
||||||
# username: feiyi
|
# username: feiyi
|
||||||
# password: 123456asd
|
# password: 123456asd
|
||||||
|
|
||||||
hikari:
|
|
||||||
max-lifetime: 120000
|
|
||||||
data:
|
data:
|
||||||
redis:
|
redis:
|
||||||
port: 6379
|
port: 6379
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<select id="queryAppointmentDateDetail" resultType="com.cultural.heritage.model.vo.appointment.AppointmentDateTimePeriodVO">
|
<select id="queryAppointmentDateDetail" resultType="com.cultural.heritage.model.vo.appointment.AppointmentDateTimePeriodVO">
|
||||||
select a.id, a.specificDate, a.isAvailable, a.goodId, t.id timePeriodId, t.timeSlot, t.minNumber, t.maxNumber
|
select a.id, a.specificDate, a.isAvailable, a.goodId, t.id timePeriodId, t.timeSlot, t.minNumber, t.maxNumber
|
||||||
from appointment_date a, time_period t
|
from appointment_date a, time_period t
|
||||||
where a.id = t.appointmentDateId and a.isDelete = 0 and t.isDelete = 0
|
where a.id = t.appointmentDateId and a.isDelete = 0 and t.isDelete =
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
|
|
||||||
|
|
44
src/test/java/com/cultural/heritage/rabbit/Consumer.java
Normal file
44
src/test/java/com/cultural/heritage/rabbit/Consumer.java
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
package com.cultural.heritage.rabbit;
|
||||||
|
|
||||||
|
|
||||||
|
import org.springframework.amqp.rabbit.annotation.RabbitListener;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class Consumer {
|
||||||
|
|
||||||
|
@RabbitListener(queues = "myQueue")
|
||||||
|
public void receive(String message) {
|
||||||
|
System.out.println("接收时间:" + new Date());
|
||||||
|
System.out.println("消费者收到消息:" + message);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @RabbitListener(queues = "myQueue1")
|
||||||
|
// public void receive2(String message) {
|
||||||
|
// System.out.println("消费者接收消息:" + message);
|
||||||
|
// }
|
||||||
|
|
||||||
|
// @RabbitListener(queues = "myQueue1")
|
||||||
|
// public void receive1(String productId, Channel channel, @Header(AmqpHeaders.DELIVERY_TAG) long msgId) throws IOException {
|
||||||
|
// System.out.println(productId + "开始减少库存");
|
||||||
|
// if (productId.equals("产品编号3")) {
|
||||||
|
// int num = 10 / 0;
|
||||||
|
// }
|
||||||
|
// // 手动应答
|
||||||
|
// long deliveryTag = msgId;
|
||||||
|
// channel.basicAck(deliveryTag, false);
|
||||||
|
// System.out.println(productId + "减少库存成功!");
|
||||||
|
// }
|
||||||
|
|
||||||
|
// @RabbitListener(queues = "myQueue2")
|
||||||
|
// public void receive2(String message) {
|
||||||
|
// System.out.println("消费者2接收消息:" + message);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @RabbitListener(queues = "myQueue3")
|
||||||
|
// public void receive3(String message) {
|
||||||
|
// System.out.println("消费者3接收消息:" + message);
|
||||||
|
// }
|
||||||
|
}
|
47
src/test/java/com/cultural/heritage/rabbit/Producer.java
Normal file
47
src/test/java/com/cultural/heritage/rabbit/Producer.java
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
package com.cultural.heritage.rabbit;
|
||||||
|
|
||||||
|
import jakarta.annotation.Resource;
|
||||||
|
import org.springframework.amqp.core.Message;
|
||||||
|
import org.springframework.amqp.core.MessageBuilder;
|
||||||
|
import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class Producer {
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private RabbitTemplate rabbitTemplate;
|
||||||
|
|
||||||
|
private String exchange = "myExchange";
|
||||||
|
|
||||||
|
|
||||||
|
public void send(String routingKey, String message) {
|
||||||
|
Message msg = MessageBuilder
|
||||||
|
.withBody(message.getBytes())
|
||||||
|
.setHeader("x-delay", 5000)
|
||||||
|
.build();
|
||||||
|
System.out.println("发送时间:" + new Date());
|
||||||
|
rabbitTemplate.convertAndSend(exchange, routingKey, msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// public void send(String routingKey, String message, MessageDeliveryMode mode) {
|
||||||
|
// Message msg = MessageBuilder
|
||||||
|
// .withBody(message.getBytes())
|
||||||
|
// .setDeliveryMode(mode) // 指定消息是否持久化
|
||||||
|
// .build();
|
||||||
|
// rabbitTemplate.convertAndSend(exchange, routingKey, msg);
|
||||||
|
// }
|
||||||
|
|
||||||
|
// public void send(String message, String routingKey) {
|
||||||
|
//
|
||||||
|
// CorrelationData correlationData = new CorrelationData();
|
||||||
|
// correlationData.setId("101"); //UUID.randomUUID().toString()
|
||||||
|
// rabbitTemplate.convertAndSend(exchangeName, routingKey, message, correlationData);
|
||||||
|
//
|
||||||
|
// //rabbitTemplate.convertAndSend(exchangeName, routingKey, message);
|
||||||
|
// }
|
||||||
|
|
||||||
|
}
|
27
src/test/java/com/cultural/heritage/rabbit/TestRabbit.java
Normal file
27
src/test/java/com/cultural/heritage/rabbit/TestRabbit.java
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
package com.cultural.heritage.rabbit;
|
||||||
|
|
||||||
|
import jakarta.annotation.Resource;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
@SpringBootTest
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
public class TestRabbit {
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private Producer producer;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test() {
|
||||||
|
String routingKey = "myKey";
|
||||||
|
String message = "Hello, RabbitMQ";
|
||||||
|
producer.send(routingKey, message);
|
||||||
|
try {
|
||||||
|
Thread.sleep(30 * 1000);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
94
src/test/java/com/cultural/heritage/rabbitmq/AppTest.java
Normal file
94
src/test/java/com/cultural/heritage/rabbitmq/AppTest.java
Normal file
|
@ -0,0 +1,94 @@
|
||||||
|
package com.cultural.heritage.rabbitmq;
|
||||||
|
|
||||||
|
import com.rabbitmq.client.*;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.TimeoutException;
|
||||||
|
|
||||||
|
@RestController
|
||||||
|
public class AppTest {
|
||||||
|
|
||||||
|
// 服务器IP
|
||||||
|
private String host = "123.249.108.160";
|
||||||
|
|
||||||
|
// RabbitMQ端口
|
||||||
|
private int port = 5672;
|
||||||
|
|
||||||
|
// 用户名
|
||||||
|
private String username = "chenxinzhi";
|
||||||
|
|
||||||
|
// 密码
|
||||||
|
private String password = "yuanteng";
|
||||||
|
|
||||||
|
// 虚拟机名字
|
||||||
|
private String vhost = "vhost1";
|
||||||
|
|
||||||
|
// 交换机名字
|
||||||
|
private String exchangeName = "myExchange1";
|
||||||
|
|
||||||
|
// 队列名字
|
||||||
|
private String queueName = "myQueue1";
|
||||||
|
|
||||||
|
// 路由Key
|
||||||
|
private String routingKey = "myRouting1";
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testProducer() throws IOException, TimeoutException {
|
||||||
|
|
||||||
|
// 创建连接工厂、连接、信道
|
||||||
|
ConnectionFactory factory = new ConnectionFactory();
|
||||||
|
factory.setHost(host);
|
||||||
|
factory.setPort(port);
|
||||||
|
factory.setUsername(username);
|
||||||
|
factory.setPassword(password);
|
||||||
|
factory.setVirtualHost(vhost);
|
||||||
|
// 连接
|
||||||
|
Connection connection = factory.newConnection();
|
||||||
|
// 信道
|
||||||
|
Channel channel = connection.createChannel();
|
||||||
|
// 创建交换机:直连交换机
|
||||||
|
channel.exchangeDeclare(exchangeName, BuiltinExchangeType.DIRECT,
|
||||||
|
true, false, null);
|
||||||
|
// 创建队列
|
||||||
|
channel.queueDeclare(queueName, true, false, false, null);
|
||||||
|
// 交换机绑定
|
||||||
|
channel.queueBind(queueName, exchangeName, routingKey);
|
||||||
|
// 发送消息
|
||||||
|
String msg = "Hello, RabbitMQ";
|
||||||
|
channel.basicPublish(exchangeName, routingKey, null, msg.getBytes());
|
||||||
|
// 关闭
|
||||||
|
channel.close();
|
||||||
|
connection.close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testConsumer() throws IOException, TimeoutException {
|
||||||
|
// 创建连接工厂、连接、信道
|
||||||
|
ConnectionFactory factory = new ConnectionFactory();
|
||||||
|
factory.setHost(host);
|
||||||
|
factory.setPort(port);
|
||||||
|
factory.setUsername(username);
|
||||||
|
factory.setPassword(password);
|
||||||
|
factory.setVirtualHost(vhost);
|
||||||
|
// 连接
|
||||||
|
Connection connection = factory.newConnection();
|
||||||
|
// 信道
|
||||||
|
Channel channel = connection.createChannel();
|
||||||
|
// 获取消息
|
||||||
|
DeliverCallback deliverCallback = (consumerTag, message) -> {
|
||||||
|
String msg = new String(message.getBody());
|
||||||
|
System.out.println(msg);
|
||||||
|
};
|
||||||
|
CancelCallback cancelCallback = consumerTag -> {
|
||||||
|
|
||||||
|
};
|
||||||
|
channel.basicConsume(queueName, true, deliverCallback, cancelCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
119
src/test/java/com/cultural/heritage/rabbitmq/TestDirect.java
Normal file
119
src/test/java/com/cultural/heritage/rabbitmq/TestDirect.java
Normal file
|
@ -0,0 +1,119 @@
|
||||||
|
package com.cultural.heritage.rabbitmq;
|
||||||
|
|
||||||
|
import com.rabbitmq.client.*;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.TimeoutException;
|
||||||
|
|
||||||
|
@SpringBootTest
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
public class TestDirect {
|
||||||
|
|
||||||
|
// 服务器IP
|
||||||
|
private String host = "123.249.108.160";
|
||||||
|
|
||||||
|
// RabbitMQ端口
|
||||||
|
private int port = 5672;
|
||||||
|
|
||||||
|
// 用户名
|
||||||
|
private String username = "chenxinzhi";
|
||||||
|
|
||||||
|
// 密码
|
||||||
|
private String password = "yuanteng";
|
||||||
|
|
||||||
|
// 虚拟机名字
|
||||||
|
private String vhost = "vhost1";
|
||||||
|
|
||||||
|
// 交换机名字
|
||||||
|
private String exchangeName = "myExchange1";
|
||||||
|
|
||||||
|
// 队列名字
|
||||||
|
private String queueName1 = "myQueue1";
|
||||||
|
|
||||||
|
private String queueName2 = "myQueue2";
|
||||||
|
|
||||||
|
private String queueName3 = "myQueue3";
|
||||||
|
|
||||||
|
// 路由Key
|
||||||
|
private String routingKey1 = "myRouting1";
|
||||||
|
|
||||||
|
private String routingKey2 = "myRouting2";
|
||||||
|
|
||||||
|
// 连接对象
|
||||||
|
private Connection connection;
|
||||||
|
|
||||||
|
// 信道对象
|
||||||
|
private Channel channel;
|
||||||
|
|
||||||
|
|
||||||
|
public void setUp() throws IOException, TimeoutException {
|
||||||
|
|
||||||
|
// 创建连接工厂、连接、信道
|
||||||
|
ConnectionFactory factory = new ConnectionFactory();
|
||||||
|
factory.setHost(host);
|
||||||
|
factory.setPort(port);
|
||||||
|
factory.setUsername(username);
|
||||||
|
factory.setPassword(password);
|
||||||
|
factory.setVirtualHost(vhost);
|
||||||
|
// 连接
|
||||||
|
connection = factory.newConnection();
|
||||||
|
// 信道
|
||||||
|
channel = connection.createChannel();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testProducer() throws IOException, TimeoutException {
|
||||||
|
// 创建交换机:直连交换机
|
||||||
|
setUp();
|
||||||
|
channel.exchangeDeclare(exchangeName, BuiltinExchangeType.DIRECT,
|
||||||
|
true, false, null);
|
||||||
|
// 创建队列
|
||||||
|
channel.queueDeclare(queueName1, true, false, false, null);
|
||||||
|
channel.queueDeclare(queueName2, true, false, false, null);
|
||||||
|
channel.queueDeclare(queueName3, true, false, false, null);
|
||||||
|
// 交换机绑定
|
||||||
|
channel.queueBind(queueName1, exchangeName, routingKey1);
|
||||||
|
channel.queueBind(queueName2, exchangeName, routingKey2);
|
||||||
|
channel.queueBind(queueName3, exchangeName, routingKey1);
|
||||||
|
// 发送消息
|
||||||
|
String msg = "Hello, RabbitMQ";
|
||||||
|
channel.basicPublish(exchangeName, routingKey1, null, msg.getBytes());
|
||||||
|
String msg2 = "RabbitMQ, Hello";
|
||||||
|
channel.basicPublish(exchangeName, routingKey2, null, msg.getBytes());
|
||||||
|
// 关闭
|
||||||
|
channel.close();
|
||||||
|
connection.close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testConsumer() throws IOException, TimeoutException {
|
||||||
|
// 获取消息
|
||||||
|
setUp();
|
||||||
|
DeliverCallback deliverCallback = (consumerTag, message) -> {
|
||||||
|
String msg = new String(message.getBody());
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
};
|
||||||
|
CancelCallback cancelCallback = consumerTag -> {
|
||||||
|
|
||||||
|
};
|
||||||
|
channel.basicConsume(queueName3, true, deliverCallback, cancelCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
107
src/test/java/com/cultural/heritage/rabbitmq/TestFanout.java
Normal file
107
src/test/java/com/cultural/heritage/rabbitmq/TestFanout.java
Normal file
|
@ -0,0 +1,107 @@
|
||||||
|
package com.cultural.heritage.rabbitmq;
|
||||||
|
|
||||||
|
import com.rabbitmq.client.*;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.TimeoutException;
|
||||||
|
|
||||||
|
@SpringBootTest
|
||||||
|
public class TestFanout {
|
||||||
|
|
||||||
|
// 服务器IP
|
||||||
|
private String host = "123.249.108.160";
|
||||||
|
|
||||||
|
// RabbitMQ端口
|
||||||
|
private int port = 5672;
|
||||||
|
|
||||||
|
// 用户名
|
||||||
|
private String username = "chenxinzhi";
|
||||||
|
|
||||||
|
// 密码
|
||||||
|
private String password = "yuanteng";
|
||||||
|
|
||||||
|
// 虚拟机名字
|
||||||
|
private String vhost = "vhost1";
|
||||||
|
|
||||||
|
// 交换机名字
|
||||||
|
private String exchangeName = "myExchange2";
|
||||||
|
|
||||||
|
// 队列名字
|
||||||
|
private String queueName1 = "myQueue1";
|
||||||
|
|
||||||
|
private String queueName2 = "myQueue2";
|
||||||
|
|
||||||
|
private String queueName3 = "myQueue3";
|
||||||
|
|
||||||
|
// 路由Key
|
||||||
|
private String routingKey1 = "myRouting1";
|
||||||
|
|
||||||
|
private String routingKey2 = "myRouting2";
|
||||||
|
|
||||||
|
// 连接对象
|
||||||
|
private Connection connection;
|
||||||
|
|
||||||
|
// 信道对象
|
||||||
|
private Channel channel;
|
||||||
|
|
||||||
|
|
||||||
|
public void setUp() throws IOException, TimeoutException {
|
||||||
|
|
||||||
|
// 创建连接工厂、连接、信道
|
||||||
|
ConnectionFactory factory = new ConnectionFactory();
|
||||||
|
factory.setHost(host);
|
||||||
|
factory.setPort(port);
|
||||||
|
factory.setUsername(username);
|
||||||
|
factory.setPassword(password);
|
||||||
|
factory.setVirtualHost(vhost);
|
||||||
|
// 连接
|
||||||
|
connection = factory.newConnection();
|
||||||
|
// 信道
|
||||||
|
channel = connection.createChannel();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testProducer() throws IOException, TimeoutException {
|
||||||
|
setUp();
|
||||||
|
// 创建交换机:直连交换机
|
||||||
|
channel.exchangeDeclare(exchangeName, BuiltinExchangeType.FANOUT,
|
||||||
|
true, false, null);
|
||||||
|
// 创建队列
|
||||||
|
channel.queueDeclare(queueName1, true, false, false, null);
|
||||||
|
channel.queueDeclare(queueName2, true, false, false, null);
|
||||||
|
channel.queueDeclare(queueName3, true, false, false, null);
|
||||||
|
// 交换机绑定
|
||||||
|
channel.queueBind(queueName1, exchangeName, "");
|
||||||
|
channel.queueBind(queueName2, exchangeName, "");
|
||||||
|
channel.queueBind(queueName3, exchangeName, "");
|
||||||
|
// 发送消息
|
||||||
|
String msg = "Hello, RabbitMQ";
|
||||||
|
channel.basicPublish(exchangeName, "", null, msg.getBytes());
|
||||||
|
// 关闭
|
||||||
|
channel.close();
|
||||||
|
connection.close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testConsumer() throws IOException, TimeoutException {
|
||||||
|
setUp();
|
||||||
|
// 获取消息
|
||||||
|
DeliverCallback deliverCallback = (consumerTag, message) -> {
|
||||||
|
String msg = new String(message.getBody());
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
};
|
||||||
|
CancelCallback cancelCallback = consumerTag -> {
|
||||||
|
|
||||||
|
};
|
||||||
|
channel.basicConsume(queueName1, true, deliverCallback, cancelCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
118
src/test/java/com/cultural/heritage/rabbitmq/TestHeader.java
Normal file
118
src/test/java/com/cultural/heritage/rabbitmq/TestHeader.java
Normal file
|
@ -0,0 +1,118 @@
|
||||||
|
package com.cultural.heritage.rabbitmq;
|
||||||
|
|
||||||
|
import com.rabbitmq.client.*;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.concurrent.TimeoutException;
|
||||||
|
|
||||||
|
@SpringBootTest
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
public class TestHeader {
|
||||||
|
|
||||||
|
// 服务器IP
|
||||||
|
private String host = "123.249.108.160";
|
||||||
|
|
||||||
|
// RabbitMQ端口
|
||||||
|
private int port = 5672;
|
||||||
|
|
||||||
|
// 用户名
|
||||||
|
private String username = "chenxinzhi";
|
||||||
|
|
||||||
|
// 密码
|
||||||
|
private String password = "yuanteng";
|
||||||
|
|
||||||
|
// 虚拟机名字
|
||||||
|
private String vhost = "vhost1";
|
||||||
|
|
||||||
|
// 交换机名字
|
||||||
|
private String exchangeName = "myExchange4";
|
||||||
|
|
||||||
|
// 队列名字
|
||||||
|
private String queueName1 = "myQueue1";
|
||||||
|
|
||||||
|
|
||||||
|
// 连接对象
|
||||||
|
private Connection connection;
|
||||||
|
|
||||||
|
// 信道对象
|
||||||
|
private Channel channel;
|
||||||
|
|
||||||
|
|
||||||
|
public void setUp() throws IOException, TimeoutException {
|
||||||
|
|
||||||
|
// 创建连接工厂、连接、信道
|
||||||
|
ConnectionFactory factory = new ConnectionFactory();
|
||||||
|
factory.setHost(host);
|
||||||
|
factory.setPort(port);
|
||||||
|
factory.setUsername(username);
|
||||||
|
factory.setPassword(password);
|
||||||
|
factory.setVirtualHost(vhost);
|
||||||
|
// 连接
|
||||||
|
connection = factory.newConnection();
|
||||||
|
// 信道
|
||||||
|
channel = connection.createChannel();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testProducer() throws IOException, TimeoutException {
|
||||||
|
setUp();
|
||||||
|
// 创建交换机:直连交换机
|
||||||
|
channel.exchangeDeclare(exchangeName, BuiltinExchangeType.HEADERS,
|
||||||
|
true, false, null);
|
||||||
|
// 创建队列
|
||||||
|
channel.queueDeclare(queueName1, true, false, false, null);
|
||||||
|
|
||||||
|
// 发送消息
|
||||||
|
String msg = "Hello, RabbitMQ";
|
||||||
|
Map map = new HashMap();
|
||||||
|
map.put("one", "one2");
|
||||||
|
map.put("two", "two");
|
||||||
|
AMQP.BasicProperties props = new AMQP.BasicProperties().builder().headers(map).build();
|
||||||
|
channel.basicPublish(exchangeName, "", props, msg.getBytes());
|
||||||
|
// 关闭
|
||||||
|
channel.close();
|
||||||
|
connection.close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testConsumer() throws IOException, TimeoutException {
|
||||||
|
setUp();
|
||||||
|
// 获取消息
|
||||||
|
DeliverCallback deliverCallback = (consumerTag, message) -> {
|
||||||
|
String msg = new String(message.getBody());
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
};
|
||||||
|
CancelCallback cancelCallback = consumerTag -> {
|
||||||
|
|
||||||
|
};
|
||||||
|
// 绑定队列和交换机
|
||||||
|
Map map = new HashMap();
|
||||||
|
map.put("x-match", "any");
|
||||||
|
map.put("one", "one");
|
||||||
|
map.put("two", "two");
|
||||||
|
channel.queueBind(queueName1, exchangeName, "", map);
|
||||||
|
// 接收消息
|
||||||
|
channel.basicConsume(queueName1, true, deliverCallback, cancelCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test() throws IOException, TimeoutException, InterruptedException {
|
||||||
|
testProducer();
|
||||||
|
Thread.sleep(5000);
|
||||||
|
testConsumer();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
117
src/test/java/com/cultural/heritage/rabbitmq/TestTopic.java
Normal file
117
src/test/java/com/cultural/heritage/rabbitmq/TestTopic.java
Normal file
|
@ -0,0 +1,117 @@
|
||||||
|
package com.cultural.heritage.rabbitmq;
|
||||||
|
|
||||||
|
import com.rabbitmq.client.*;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.TimeoutException;
|
||||||
|
|
||||||
|
@SpringBootTest
|
||||||
|
public class TestTopic {
|
||||||
|
|
||||||
|
// 服务器IP
|
||||||
|
private String host = "123.249.108.160";
|
||||||
|
|
||||||
|
// RabbitMQ端口
|
||||||
|
private int port = 5672;
|
||||||
|
|
||||||
|
// 用户名
|
||||||
|
private String username = "chenxinzhi";
|
||||||
|
|
||||||
|
// 密码
|
||||||
|
private String password = "yuanteng";
|
||||||
|
|
||||||
|
// 虚拟机名字
|
||||||
|
private String vhost = "vhost1";
|
||||||
|
|
||||||
|
// 交换机名字
|
||||||
|
private String exchangeName = "myExchange3";
|
||||||
|
|
||||||
|
// 队列名字
|
||||||
|
private String queueName1 = "myQueue1";
|
||||||
|
|
||||||
|
private String queueName2 = "myQueue2";
|
||||||
|
|
||||||
|
private String queueName3 = "myQueue3";
|
||||||
|
|
||||||
|
// 路由Key
|
||||||
|
private String routingKey1 = "myRouting.*";
|
||||||
|
|
||||||
|
private String routingKey2 = "myRouting.b";
|
||||||
|
|
||||||
|
private String routingKey3 = "myRouting.#";
|
||||||
|
|
||||||
|
// 连接对象
|
||||||
|
private Connection connection;
|
||||||
|
|
||||||
|
// 信道对象
|
||||||
|
private Channel channel;
|
||||||
|
|
||||||
|
|
||||||
|
public void setUp() throws IOException, TimeoutException {
|
||||||
|
|
||||||
|
// 创建连接工厂、连接、信道
|
||||||
|
ConnectionFactory factory = new ConnectionFactory();
|
||||||
|
factory.setHost(host);
|
||||||
|
factory.setPort(port);
|
||||||
|
factory.setUsername(username);
|
||||||
|
factory.setPassword(password);
|
||||||
|
factory.setVirtualHost(vhost);
|
||||||
|
// 连接
|
||||||
|
connection = factory.newConnection();
|
||||||
|
// 信道
|
||||||
|
channel = connection.createChannel();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testProducer() throws IOException, TimeoutException {
|
||||||
|
setUp();
|
||||||
|
// 创建交换机:直连交换机
|
||||||
|
channel.exchangeDeclare(exchangeName, BuiltinExchangeType.TOPIC,
|
||||||
|
true, false, null);
|
||||||
|
// 创建队列
|
||||||
|
channel.queueDeclare(queueName1, true, false, false, null);
|
||||||
|
channel.queueDeclare(queueName2, true, false, false, null);
|
||||||
|
channel.queueDeclare(queueName3, true, false, false, null);
|
||||||
|
// 交换机绑定
|
||||||
|
channel.queueBind(queueName1, exchangeName, routingKey1);
|
||||||
|
channel.queueBind(queueName2, exchangeName, routingKey2);
|
||||||
|
channel.queueBind(queueName3, exchangeName, routingKey3);
|
||||||
|
// 发送消息
|
||||||
|
String msg = "Hello, RabbitMQ";
|
||||||
|
channel.basicPublish(exchangeName, "myRouting.a.b", null, msg.getBytes());
|
||||||
|
// 关闭
|
||||||
|
channel.close();
|
||||||
|
connection.close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testConsumer() throws IOException, TimeoutException {
|
||||||
|
setUp();
|
||||||
|
// 获取消息
|
||||||
|
DeliverCallback deliverCallback = (consumerTag, message) -> {
|
||||||
|
String msg = new String(message.getBody());
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
System.out.println(msg);
|
||||||
|
};
|
||||||
|
CancelCallback cancelCallback = consumerTag -> {
|
||||||
|
|
||||||
|
};
|
||||||
|
channel.basicConsume(queueName3, true, deliverCallback, cancelCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test() throws IOException, TimeoutException, InterruptedException {
|
||||||
|
testProducer();
|
||||||
|
Thread.sleep(5000);
|
||||||
|
testConsumer();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,21 @@
|
||||||
|
package com.cultural.heritage.rabbitmqtest;
|
||||||
|
|
||||||
|
import org.springframework.amqp.rabbit.annotation.Exchange;
|
||||||
|
import org.springframework.amqp.rabbit.annotation.Queue;
|
||||||
|
import org.springframework.amqp.rabbit.annotation.QueueBinding;
|
||||||
|
import org.springframework.amqp.rabbit.annotation.RabbitListener;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class ConsumerTest {
|
||||||
|
|
||||||
|
@RabbitListener(bindings = @QueueBinding(
|
||||||
|
value = @Queue("myQueue"),
|
||||||
|
exchange = @Exchange(name = "myExchange", delayed = "true"),
|
||||||
|
key = "myKey"
|
||||||
|
))
|
||||||
|
public void listenDelayMessage(String msg) {
|
||||||
|
System.out.println("接收延时消息:" + msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
package com.cultural.heritage.rabbitmqtest;
|
||||||
|
|
||||||
|
|
||||||
|
import jakarta.annotation.Resource;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.amqp.AmqpException;
|
||||||
|
import org.springframework.amqp.core.Message;
|
||||||
|
import org.springframework.amqp.core.MessagePostProcessor;
|
||||||
|
import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
@SpringBootTest
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
public class RabbitMQTest {
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private RabbitTemplate rabbitTemplate;
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDelayMessage() {
|
||||||
|
String exchange = "myExchange";
|
||||||
|
String message = "Hello, delay message!";
|
||||||
|
|
||||||
|
rabbitTemplate.convertAndSend(exchange, "myKey", message, new MessagePostProcessor() {
|
||||||
|
@Override
|
||||||
|
public Message postProcessMessage(Message message) throws AmqpException {
|
||||||
|
// 添加延迟消息属性
|
||||||
|
message.getMessageProperties().setDelay(5000);
|
||||||
|
return message;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
try {
|
||||||
|
Thread.sleep(30 * 1000);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,52 @@
|
||||||
|
//package com.cultural.heritage.config;
|
||||||
|
//
|
||||||
|
//import jakarta.annotation.PostConstruct;
|
||||||
|
//import jakarta.annotation.Resource;
|
||||||
|
//import org.springframework.amqp.core.Message;
|
||||||
|
//import org.springframework.amqp.core.ReturnedMessage;
|
||||||
|
//import org.springframework.amqp.rabbit.connection.CorrelationData;
|
||||||
|
//import org.springframework.amqp.rabbit.core.RabbitTemplate;
|
||||||
|
//import org.springframework.stereotype.Component;
|
||||||
|
//
|
||||||
|
//@Component
|
||||||
|
//public class MessageConfirmConfig implements RabbitTemplate.ConfirmCallback, RabbitTemplate.ReturnsCallback {
|
||||||
|
//
|
||||||
|
// @Resource
|
||||||
|
// private RabbitTemplate rabbitTemplate;
|
||||||
|
//
|
||||||
|
// @PostConstruct
|
||||||
|
// public void init() {
|
||||||
|
// // 设置发布确认交当前对象处理-this
|
||||||
|
// rabbitTemplate.setConfirmCallback(this);
|
||||||
|
//
|
||||||
|
// // 设置消息退回交当前对象处理-this
|
||||||
|
// rabbitTemplate.setReturnsCallback(this);
|
||||||
|
//
|
||||||
|
// // 设置是否保留退回的消息(默认保留)
|
||||||
|
//// rabbitTemplate.setMandatory(true);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @Override
|
||||||
|
// public void confirm(CorrelationData correlationData, boolean ack, String cause) {
|
||||||
|
// if (ack) {
|
||||||
|
// System.out.println("mq收到消息: = " + correlationData.getId());
|
||||||
|
// } else {
|
||||||
|
// System.out.println("mq未收到消息:" + cause);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @Override
|
||||||
|
// public void returnedMessage(ReturnedMessage returned) {
|
||||||
|
// Message message = returned.getMessage();
|
||||||
|
// String replyText = returned.getReplyText();
|
||||||
|
// int replyCode = returned.getReplyCode();
|
||||||
|
// String exchange = returned.getExchange();
|
||||||
|
// String routingKey = returned.getRoutingKey();
|
||||||
|
// System.out.println("消息被退回:");
|
||||||
|
// System.out.println("消息:" + new String(message.getBody()));
|
||||||
|
// System.out.println("原因:" + replyText);
|
||||||
|
// System.out.println("应答码:" + replyCode);
|
||||||
|
// System.out.println("交换机:" + exchange);
|
||||||
|
// System.out.println("路由:" + routingKey);
|
||||||
|
// }
|
||||||
|
//}
|
77
src/test/java/com/cultural/heritage/temp/RabbitConfig.java
Normal file
77
src/test/java/com/cultural/heritage/temp/RabbitConfig.java
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
//package com.cultural.heritage.config;
|
||||||
|
//
|
||||||
|
//import org.springframework.amqp.core.*;
|
||||||
|
//import org.springframework.beans.factory.annotation.Qualifier;
|
||||||
|
//import org.springframework.context.annotation.Bean;
|
||||||
|
//import org.springframework.context.annotation.Configuration;
|
||||||
|
//
|
||||||
|
//@Configuration
|
||||||
|
//public class RabbitConfig {
|
||||||
|
//
|
||||||
|
// private String exchange = "myExchange";
|
||||||
|
//
|
||||||
|
// private String queue = "myQueue";
|
||||||
|
////
|
||||||
|
//// private String queueName2 = "myQueue2";
|
||||||
|
////
|
||||||
|
//// private String queueName3 = "myQueue3";
|
||||||
|
////
|
||||||
|
// private String routingKey = "myKey";
|
||||||
|
////
|
||||||
|
//// private String routingKey2 = "routingKey.b";
|
||||||
|
////
|
||||||
|
//// private String routingKey3 = "routingKey.#";
|
||||||
|
//
|
||||||
|
// @Bean("myExchange")
|
||||||
|
// public org.springframework.amqp.core.Exchange exchange() {
|
||||||
|
// return ExchangeBuilder
|
||||||
|
// .directExchange(exchange)
|
||||||
|
// .delayed()
|
||||||
|
// .build();
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @Bean("myQueue")
|
||||||
|
// public Queue queue() {
|
||||||
|
// return QueueBuilder.durable(queue).build();
|
||||||
|
//// return QueueBuilder.durable(queueName1).lazy().build();
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
//// @Bean("myQueue2")
|
||||||
|
//// public Queue queue2() {
|
||||||
|
//// return QueueBuilder.durable(queueName2).build();
|
||||||
|
//// }
|
||||||
|
////
|
||||||
|
//// @Bean("myQueue3")
|
||||||
|
//// public Queue queue3() {
|
||||||
|
//// return QueueBuilder.durable(queueName3).build();
|
||||||
|
//// }
|
||||||
|
//
|
||||||
|
// @Bean
|
||||||
|
// public Binding binding(@Qualifier("myExchange") Exchange exchange, @Qualifier("myQueue") Queue queue) {
|
||||||
|
// return BindingBuilder.bind(queue).to(exchange).with(routingKey).noargs();
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//// @Bean
|
||||||
|
//// public Binding binding1(@Qualifier("myExchange1") Exchange exchange, @Qualifier("myQueue1") Queue queue) {
|
||||||
|
//// Map map = new HashMap();
|
||||||
|
//// map.put("x-match", "any");
|
||||||
|
//// map.put("one", "one");
|
||||||
|
//// map.put("two", "two");
|
||||||
|
//// return BindingBuilder.bind(queue).to(exchange).with("").and(map);
|
||||||
|
//// }
|
||||||
|
////
|
||||||
|
//// @Bean
|
||||||
|
//// public Binding binding2(@Qualifier("myExchange1") Exchange exchange, @Qualifier("myQueue2") Queue queue) {
|
||||||
|
//// return BindingBuilder.bind(queue).to(exchange).with(routingKey2).noargs();
|
||||||
|
//// }
|
||||||
|
////
|
||||||
|
//// @Bean
|
||||||
|
//// public Binding binding3(@Qualifier("myExchange1") Exchange exchange, @Qualifier("myQueue3") Queue queue) {
|
||||||
|
//// return BindingBuilder.bind(queue).to(exchange).with(routingKey3).noargs();
|
||||||
|
//// }
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//}
|
25
src/test/java/com/cultural/heritage/test/TestHashCode.java
Normal file
25
src/test/java/com/cultural/heritage/test/TestHashCode.java
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
package com.cultural.heritage.test;
|
||||||
|
|
||||||
|
public class TestHashCode {
|
||||||
|
private int num;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (this == o) return true;
|
||||||
|
if (o == null || getClass() != o.getClass()) return false;
|
||||||
|
TestHashCode that = (TestHashCode) o;
|
||||||
|
return num == that.num;
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Override
|
||||||
|
// public int hashCode() {
|
||||||
|
// return Objects.hash(num);
|
||||||
|
// }
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
TestHashCode testHashCode1 = new TestHashCode();
|
||||||
|
TestHashCode testHashCode2 = new TestHashCode();
|
||||||
|
System.out.println(testHashCode1.equals(testHashCode2));
|
||||||
|
testHashCode1.hashCode();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user