liusheng
3 天以前 e6456d2196b3e57bd06be0fbc74dd3e0fc28fdeb
ruoyi-common/src/main/java/com/ruoyi/common/core/redis/RedisCache.java
@@ -1,13 +1,11 @@
package com.ruoyi.common.core.redis;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.*;
import java.util.concurrent.TimeUnit;
import java.util.stream.Collectors;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.connection.DataType;
import org.springframework.data.redis.core.*;
import org.springframework.stereotype.Component;
@@ -142,6 +140,32 @@
    }
    /**
     * 缓存List数据
     *
     * @param cacheKey 缓存的键值
     * @param list     待缓存的List数据(这里如果新增的话,是往头部新增)并去重
     * @return 缓存的对象
     */
    public void setCacheListLeftAndDistinct(String cacheKey, List<String> list) {
        // 检查 key 类型
        DataType keyType = redisTemplate.type(cacheKey);
        if (keyType != DataType.NONE && keyType != DataType.LIST) {
            // 如果已经存在但不是 list 类型,删除它(或直接抛异常也可)
            redisTemplate.delete(cacheKey);
        }
        ListOperations<String, String> listOps = redisTemplate.opsForList();
        List<String> existingValues = listOps.range(cacheKey, 0, -1);
        List<String> newValues = list.stream().filter(value -> !existingValues.contains(value)).collect(Collectors.toList());
        if (!newValues.isEmpty()) {
            listOps.leftPushAll(cacheKey, newValues);
        }
    }
    /**
     * 获得缓存的list对象
     *
     * @param key 缓存的键值