mirror of
https://gitee.com/binary/weixin-java-tools.git
synced 2025-10-20 18:47:38 +08:00
🎨 #1521 微信小程序 spring-boot-starter 增加一些新特性
This commit is contained in:
@@ -0,0 +1,37 @@
|
||||
package me.chanjar.weixin.common.redis;
|
||||
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.concurrent.locks.Lock;
|
||||
|
||||
/**
|
||||
* 微信redis操作基本类
|
||||
* <p>
|
||||
* 非内置实现redis相关操作, 请实现该类
|
||||
*/
|
||||
public abstract class BaseWxRedisOps implements WxRedisOps {
|
||||
|
||||
@Override
|
||||
public String getValue(String key) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setValue(String key, String value, int expire, TimeUnit timeUnit) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long getExpire(String key) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void expire(String key, int expire, TimeUnit timeUnit) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Lock getLock(String key) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
}
|
@@ -0,0 +1,48 @@
|
||||
package me.chanjar.weixin.common.redis;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import me.chanjar.weixin.common.util.locks.JedisDistributedLock;
|
||||
import redis.clients.jedis.Jedis;
|
||||
import redis.clients.jedis.JedisPool;
|
||||
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.concurrent.locks.Lock;
|
||||
|
||||
@RequiredArgsConstructor
|
||||
public class JedisWxRedisOps implements WxRedisOps {
|
||||
|
||||
private final JedisPool jedisPool;
|
||||
|
||||
@Override
|
||||
public String getValue(String key) {
|
||||
try (Jedis jedis = this.jedisPool.getResource()) {
|
||||
return jedis.get(key);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setValue(String key, String value, int expire, TimeUnit timeUnit) {
|
||||
try (Jedis jedis = this.jedisPool.getResource()) {
|
||||
jedis.psetex(key, timeUnit.toMillis(expire), value);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long getExpire(String key) {
|
||||
try (Jedis jedis = this.jedisPool.getResource()) {
|
||||
return jedis.ttl(key);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void expire(String key, int expire, TimeUnit timeUnit) {
|
||||
try (Jedis jedis = this.jedisPool.getResource()) {
|
||||
jedis.pexpire(key, timeUnit.toMillis(expire));
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public Lock getLock(String key) {
|
||||
return new JedisDistributedLock(jedisPool, key);
|
||||
}
|
||||
}
|
@@ -0,0 +1,39 @@
|
||||
package me.chanjar.weixin.common.redis;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.data.redis.core.StringRedisTemplate;
|
||||
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.concurrent.locks.Lock;
|
||||
import java.util.concurrent.locks.ReentrantLock;
|
||||
|
||||
@RequiredArgsConstructor
|
||||
public class RedisTemplateWxRedisOps implements WxRedisOps {
|
||||
|
||||
private final StringRedisTemplate redisTemplate;
|
||||
|
||||
@Override
|
||||
public String getValue(String key) {
|
||||
return redisTemplate.opsForValue().get(key);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setValue(String key, String value, int expire, TimeUnit timeUnit) {
|
||||
redisTemplate.opsForValue().set(key, value, expire, timeUnit);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long getExpire(String key) {
|
||||
return redisTemplate.getExpire(key);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void expire(String key, int expire, TimeUnit timeUnit) {
|
||||
redisTemplate.expire(key, expire, timeUnit);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Lock getLock(String key) {
|
||||
return new ReentrantLock();
|
||||
}
|
||||
}
|
@@ -0,0 +1,39 @@
|
||||
package me.chanjar.weixin.common.redis;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.redisson.api.RedissonClient;
|
||||
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.concurrent.locks.Lock;
|
||||
|
||||
@RequiredArgsConstructor
|
||||
public class RedissonWxRedisOps implements WxRedisOps {
|
||||
|
||||
private final RedissonClient redissonClient;
|
||||
|
||||
@Override
|
||||
public String getValue(String key) {
|
||||
Object value = redissonClient.getBucket(key).get();
|
||||
return value == null ? null : value.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setValue(String key, String value, int expire, TimeUnit timeUnit) {
|
||||
redissonClient.getBucket(key).set(value, expire, timeUnit);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long getExpire(String key) {
|
||||
return redissonClient.getBucket(key).remainTimeToLive();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void expire(String key, int expire, TimeUnit timeUnit) {
|
||||
redissonClient.getBucket(key).expire(expire, timeUnit);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Lock getLock(String key) {
|
||||
return redissonClient.getLock(key);
|
||||
}
|
||||
}
|
@@ -0,0 +1,27 @@
|
||||
package me.chanjar.weixin.common.redis;
|
||||
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.concurrent.locks.Lock;
|
||||
|
||||
/**
|
||||
* 微信Redis相关操作
|
||||
* <p>
|
||||
* 该接口不承诺稳定, 外部实现请继承{@link BaseWxRedisOps}
|
||||
*
|
||||
* @see BaseWxRedisOps 实现需要继承该类
|
||||
* @see JedisWxRedisOps jedis实现
|
||||
* @see RedissonWxRedisOps redisson实现
|
||||
* @see RedisTemplateWxRedisOps redisTemplate实现
|
||||
*/
|
||||
public interface WxRedisOps {
|
||||
|
||||
String getValue(String key);
|
||||
|
||||
void setValue(String key, String value, int expire, TimeUnit timeUnit);
|
||||
|
||||
Long getExpire(String key);
|
||||
|
||||
void expire(String key, int expire, TimeUnit timeUnit);
|
||||
|
||||
Lock getLock(String key);
|
||||
}
|
Reference in New Issue
Block a user