@CacheEvict多参数匹配删除
miheal_near 人气:0@CacheEvict 多参数匹配删除
如果@Cacheable(“XXX”)
Object getXXX(String a, String b, String c);
spring的缓存使用的key是ESPL表达式,然后翻看源码key默认用的生成方式是org.springframework.cache.interceptor.SimpleKeyGenerator
大于1个参数走的是最后一个方法
/** * Generate a key based on the specified parameters. */ public static Object generateKey(Object... params) { if (params.length == 0) { return SimpleKey.EMPTY; } if (params.length == 1) { Object param = params[0]; if (param != null && !param.getClass().isArray()) { return param; } } return new SimpleKey(params); }
然后查看org.springframework.cache.interceptor.SimpleKey对应代码,发现返回的其实是SimpleKey
/** * Create a new {@link SimpleKey} instance. * @param elements the elements of the key */ public SimpleKey(Object... elements) { Assert.notNull(elements, "Elements must not be null"); this.params = new Object[elements.length]; System.arraycopy(elements, 0, this.params, 0, elements.length); this.hashCode = Arrays.deepHashCode(this.params); }
解决思路
方案一:单独写一个自定义的KeyGenerator
处理对应的key。(之前的redis的文章已写过,所以不重复写了)
下面博文的 MyKeyGenerator 这个类
sprintboot使用spring-security包,缓存内存与redis共存
方案二:@Cacheable(value=“XXX”, key=“xxxx”)
@CacheEvict(value=“XXX”, key=“xxxx”)
做相应的key配置
数组的话可以使用 key = “#root.args[0]”
参数参考如下:
名字 | 位置 | 描述 | 示例 |
---|---|---|---|
methodName | root object | 当前被调用的方法名 | #root.methodName |
method | root object | 当前被调用的方法 | #root.method .name |
target | root object | 当前被调用的目标对象 | #root.target |
targetClass | root object | 当前被调用的目标对象类 | #root.targetClass |
args | root object | 当前被调用的方法的参数列表 | #root.args[0] |
caches | root object | 当前方法调用使用的缓存列表 | #root.caches[0].name |
argument name | evaluation context | 方法参数的名字,可以直接#参数名,也可以使用#p0或#a0的形式,0代表参数的索引 | #iban、#a0、#p0 |
result | evaluation context | 方法执行后的返回值 | #result |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
加载全部内容