中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot?@Cacheable自定義KeyGenerator方式是什么

發布時間:2021-12-24 09:04:12 來源:億速云 閱讀:309 作者:iii 欄目:開發技術

這篇文章主要介紹“SpringBoot @Cacheable自定義KeyGenerator方式是什么”,在日常操作中,相信很多人在SpringBoot @Cacheable自定義KeyGenerator方式是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”SpringBoot @Cacheable自定義KeyGenerator方式是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

@Cacheable自定義KeyGenerator

1. 概述

SpringBoot 使用 @Cacheable 可以方便的管理緩存數據,在不指定 key 屬性的情況下,默認使用 SimpleKeyGenerator 生成 key。除此之外,我們也可以自定義實現 KeyGenerator 接口,生成自己的 key 名稱策略。

2. MySimpleKey 類

MySimpleKey類的作用是存放參數數據,必須實現equals、hashCode。如果需要自定義key格式,同樣需要實現toString接口,下面的例子是把參數用逗號分隔。

public class MySimpleKey implements Serializable {
    public static final MySimpleKey EMPTY = new MySimpleKey(new Object[0]);
    private final Object[] params;
    private transient int hashCode;
    public MySimpleKey(Object... elements) {
        Assert.notNull(elements, "Elements must not be null");
        this.params = (Object[])elements.clone();
        this.hashCode = Arrays.deepHashCode(this.params);
    }
    public boolean equals(@Nullable Object other) {
        return this == other || other instanceof MySimpleKey && Arrays.deepEquals(this.params, ((MySimpleKey)other).params);
    }
    public final int hashCode() {
        return this.hashCode;
    }
    public String toString() {
        return StringUtils.arrayToCommaDelimitedString(this.params);
    }
}

3. MyKeyGenerator 類

MyKeyGenerator 實現 KeyGenerator 的接口,里面只有一個 generate 方法

public class MyKeyGenerator implements KeyGenerator {
    @Override
    public Object generate(Object o, Method method, Object... objects) {
        if (objects.length == 0) {
            return MySimpleKey.EMPTY;
        } else {
            if (objects.length == 1) {
                Object param = objects[0];
                if (param != null && !param.getClass().isArray()) {
                    return param;
                }
            }
            return new MySimpleKey(objects);
        }
    }
}

定義MyKeyGenerator Bean:

@Component
public class MyRedisConf {
    @Bean
    public MyKeyGenerator myKeyGenerator(){
        return new MyKeyGenerator();
    }
}

4. 配置keyGenerator

在 @Cacheable 配置 keyGenerator 屬性,值就是前面配置的Bean名稱

@Override
    @Cacheable(value = {"REDIS:GETSTRING3"}, keyGenerator = "myKeyGenerator")
    public String getString3(String tag, String name) {
        return tag + " " + name;
    }

測試結果如下,tag、name 參數確實以逗號分隔

127.0.0.1:6379[5]> KEYS *

1) "REDIS:GETSTRING3::hello,zhangsan"

Spring-Cache key設置

第一種方式:手動設置

為了便于key的不重復,我們可以手動設置key有類名、方法名、參數等組合

屬性名稱

描述

示例

methodName

當前方法名

#root.methodName

method

當前方法

#root.method.name

target

當前被調用的對象

#root.target

targetClass

當前被調用的對象的class

#root.targetClass

args

當前方法參數組成的數組

#root.args[0]

caches

當前被調用的方法使用的Cache

#root.caches[0].name

key = "#root.targetClass.simpleName+':'+#root.methodName+':'+#param"

如下圖所示

SpringBoot?@Cacheable自定義KeyGenerator方式是什么

第二種方式:自定義keyGenerator

1、自定義CacheKeyGenerator 實現KeyGenerator

public class CacheKeyGenerator implements KeyGenerator {
    /**
     * (非 Javadoc)
     * <p>
     * Title: generate
     * </p>
     * 
     * @param target
     * @param method
     * @param params
     * @return
     * @see org.springframework.cache.interceptor.KeyGenerator#generate(java.lang.Object,
     *      java.lang.reflect.Method, java.lang.Object[])
     */
    @Override
    public Object generate(Object target, Method method, Object... params) {
        StringBuilder key = new StringBuilder();
        key.append(target.getClass().getSimpleName()).append(":").append(method.getName()).append(":");
        if (params.length == 0) {
            return key.toString();
        }
        for (int i = 0; i < params.length; i++) {
            Object param = params[i];
            if (param == null || param instanceof LogableParam) {
                del(key);
            } else if (ClassUtils.isPrimitiveArray(param.getClass())) {
                int length = Array.getLength(param);
                for (int j = 0; j < length; j++) {
                    key.append(Array.get(param, j));
                    key.append(',');
                }
            } else if (ClassUtils.isPrimitiveOrWrapper(param.getClass()) || param instanceof String) {
                key.append(param);
            } else {
                key.append(param.toString());
            }
            key.append('-');
        }
        del(key);
        return key.toString();
    }
    private StringBuilder del(StringBuilder stringBuilder) {
        if (stringBuilder.toString().endsWith("-")) {
            stringBuilder.deleteCharAt(stringBuilder.length() - 1);
        }
        return stringBuilder;
    }
}

2、配置xml

<cache:annotation-driven cache-manager="cacheManager" key-generator="cacheKeyGenerator"
        proxy-target-class="true" />
<bean id="cacheKeyGenerator" class="com.tensoon.util.CacheKeyGenerator"></bean>

3、配置注解

如下圖所示

SpringBoot?@Cacheable自定義KeyGenerator方式是什么

到此,關于“SpringBoot @Cacheable自定義KeyGenerator方式是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

盐山县| 南平市| 友谊县| 山丹县| 阳江市| 精河县| 荆门市| 潍坊市| 三都| 宿州市| 曲水县| 阜阳市| 仁寿县| 乌海市| 福建省| 麻城市| 醴陵市| 济源市| 芦山县| 澄城县| 广元市| 大冶市| 吉水县| 吉林市| 克东县| 九龙城区| 富平县| 大足县| 芜湖市| 砀山县| 华宁县| 内江市| SHOW| 仙居县| 盐城市| 涞源县| 永川市| 彰化市| 长汀县| 金塔县| 苏尼特右旗|