mirror of
https://github.com/continew-org/continew-starter.git
synced 2025-09-09 20:57:23 +08:00
build: sa-token 1.40.0 => 1.41.0
This commit is contained in:
@@ -13,16 +13,10 @@
|
|||||||
<description>ContiNew Starter 认证模块 - SaToken</description>
|
<description>ContiNew Starter 认证模块 - SaToken</description>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<!-- Sa-Token(轻量级 Java 权限认证框架,让鉴权变得简单、优雅) -->
|
<!-- Web 模块 -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>cn.dev33</groupId>
|
<groupId>top.continew</groupId>
|
||||||
<artifactId>sa-token-spring-boot3-starter</artifactId>
|
<artifactId>continew-starter-web</artifactId>
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- Sa-Token 整合 JWT -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>cn.dev33</groupId>
|
|
||||||
<artifactId>sa-token-jwt</artifactId>
|
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- 缓存模块 - Redisson -->
|
<!-- 缓存模块 - Redisson -->
|
||||||
@@ -32,10 +26,34 @@
|
|||||||
<optional>true</optional>
|
<optional>true</optional>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- Web 模块 -->
|
<!-- Sa-Token(轻量级 Java 权限认证框架,让鉴权变得简单、优雅) -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>top.continew</groupId>
|
<groupId>cn.dev33</groupId>
|
||||||
<artifactId>continew-starter-web</artifactId>
|
<artifactId>sa-token-spring-boot3-starter</artifactId>
|
||||||
|
<exclusions>
|
||||||
|
<exclusion>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-web</artifactId>
|
||||||
|
</exclusion>
|
||||||
|
</exclusions>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<!-- Sa-Token 整合 JWT -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>cn.dev33</groupId>
|
||||||
|
<artifactId>sa-token-jwt</artifactId>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<!-- Sa-Token 集成 Redisson 客户端 -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>cn.dev33</groupId>
|
||||||
|
<artifactId>sa-token-redisson</artifactId>
|
||||||
|
<exclusions>
|
||||||
|
<exclusion>
|
||||||
|
<groupId>org.redisson</groupId>
|
||||||
|
<artifactId>redisson</artifactId>
|
||||||
|
</exclusion>
|
||||||
|
</exclusions>
|
||||||
</dependency>
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</project>
|
</project>
|
@@ -18,12 +18,13 @@ package top.continew.starter.auth.satoken.autoconfigure.dao;
|
|||||||
|
|
||||||
import cn.dev33.satoken.dao.SaTokenDao;
|
import cn.dev33.satoken.dao.SaTokenDao;
|
||||||
import cn.dev33.satoken.dao.SaTokenDaoDefaultImpl;
|
import cn.dev33.satoken.dao.SaTokenDaoDefaultImpl;
|
||||||
import org.redisson.client.RedisClient;
|
import cn.dev33.satoken.dao.SaTokenDaoForRedisson;
|
||||||
|
import org.redisson.api.RedissonClient;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.NoSuchBeanDefinitionException;
|
import org.springframework.beans.factory.NoSuchBeanDefinitionException;
|
||||||
import org.springframework.boot.autoconfigure.AutoConfigureBefore;
|
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
@@ -63,8 +64,8 @@ public class SaTokenDaoConfiguration {
|
|||||||
* 自定义持久层实现-Redis(默认)
|
* 自定义持久层实现-Redis(默认)
|
||||||
*/
|
*/
|
||||||
@ConditionalOnMissingBean(SaTokenDao.class)
|
@ConditionalOnMissingBean(SaTokenDao.class)
|
||||||
@ConditionalOnClass(RedisClient.class)
|
@ConditionalOnBean(RedissonClient.class)
|
||||||
@AutoConfigureBefore(RedissonAutoConfiguration.class)
|
@AutoConfigureAfter(RedissonAutoConfiguration.class)
|
||||||
@ConditionalOnProperty(name = "sa-token.extension.dao.type", havingValue = "redis")
|
@ConditionalOnProperty(name = "sa-token.extension.dao.type", havingValue = "redis")
|
||||||
public static class Redis {
|
public static class Redis {
|
||||||
static {
|
static {
|
||||||
@@ -72,8 +73,8 @@ public class SaTokenDaoConfiguration {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public SaTokenDao saTokenDao() {
|
public SaTokenDao saTokenDao(RedissonClient redissonClient) {
|
||||||
return new SaTokenDaoRedisDefaultImpl();
|
return new SaTokenDaoForRedisson(redissonClient);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1,147 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2022-present Charles7c Authors. All Rights Reserved.
|
|
||||||
* <p>
|
|
||||||
* Licensed under the GNU LESSER GENERAL PUBLIC LICENSE 3.0;
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
* <p>
|
|
||||||
* http://www.gnu.org/licenses/lgpl.html
|
|
||||||
* <p>
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package top.continew.starter.auth.satoken.autoconfigure.dao;
|
|
||||||
|
|
||||||
import cn.dev33.satoken.dao.SaTokenDao;
|
|
||||||
import cn.dev33.satoken.util.SaFoxUtil;
|
|
||||||
import top.continew.starter.cache.redisson.util.RedisUtils;
|
|
||||||
|
|
||||||
import java.time.Duration;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 默认 Sa-Token 持久层 Redis 实现(参考:Sa-Token/sa-token-plugin/sa-token-dao-redisx/SaTokenDaoOfRedis.java)
|
|
||||||
*
|
|
||||||
* @author Charles7c
|
|
||||||
* @since 1.0.0
|
|
||||||
*/
|
|
||||||
public class SaTokenDaoRedisDefaultImpl implements SaTokenDao {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String get(String key) {
|
|
||||||
return RedisUtils.get(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void set(String key, String value, long timeout) {
|
|
||||||
if (timeout == 0 || timeout <= SaTokenDao.NOT_VALUE_EXPIRE) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// 判断是否为永不过期
|
|
||||||
if (timeout == SaTokenDao.NEVER_EXPIRE) {
|
|
||||||
RedisUtils.set(key, value);
|
|
||||||
} else {
|
|
||||||
RedisUtils.set(key, value, Duration.ofSeconds(timeout));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void update(String key, String value) {
|
|
||||||
long expire = getTimeout(key);
|
|
||||||
// -2:无此键
|
|
||||||
if (expire == SaTokenDao.NOT_VALUE_EXPIRE) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
this.set(key, value, expire);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void delete(String key) {
|
|
||||||
RedisUtils.delete(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long getTimeout(String key) {
|
|
||||||
long timeout = RedisUtils.getTimeToLive(key);
|
|
||||||
return timeout < 0 ? timeout : timeout / 1000;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void updateTimeout(String key, long timeout) {
|
|
||||||
// 判断是否想要设置为永久
|
|
||||||
if (timeout == SaTokenDao.NEVER_EXPIRE) {
|
|
||||||
long expire = getTimeout(key);
|
|
||||||
// 如果其已经被设置为永久,则不作任何处理。如果尚未被设置为永久,那么再次 set 一次
|
|
||||||
if (expire != SaTokenDao.NEVER_EXPIRE) {
|
|
||||||
this.set(key, this.get(key), timeout);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
RedisUtils.expire(key, Duration.ofSeconds(timeout));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Object getObject(String key) {
|
|
||||||
return RedisUtils.get(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setObject(String key, Object object, long timeout) {
|
|
||||||
if (0 == timeout || timeout <= SaTokenDao.NOT_VALUE_EXPIRE) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// 判断是否为永不过期
|
|
||||||
if (timeout == SaTokenDao.NEVER_EXPIRE) {
|
|
||||||
RedisUtils.set(key, object);
|
|
||||||
} else {
|
|
||||||
RedisUtils.set(key, object, Duration.ofSeconds(timeout));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void updateObject(String key, Object object) {
|
|
||||||
long expire = getObjectTimeout(key);
|
|
||||||
// -2:无此键
|
|
||||||
if (expire == SaTokenDao.NOT_VALUE_EXPIRE) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
this.setObject(key, object, expire);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void deleteObject(String key) {
|
|
||||||
RedisUtils.delete(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long getObjectTimeout(String key) {
|
|
||||||
return this.getTimeout(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void updateObjectTimeout(String key, long timeout) {
|
|
||||||
// 判断是否想要设置为永久
|
|
||||||
if (timeout == SaTokenDao.NEVER_EXPIRE) {
|
|
||||||
long expire = getObjectTimeout(key);
|
|
||||||
// 如果其已经被设置为永久,则不作任何处理。如果尚未被设置为永久,那么再次 set 一次
|
|
||||||
if (expire != SaTokenDao.NEVER_EXPIRE) {
|
|
||||||
this.setObject(key, this.getObject(key), timeout);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
RedisUtils.expire(key, Duration.ofSeconds(timeout));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<String> searchData(String prefix, String keyword, int start, int size, boolean sortType) {
|
|
||||||
Collection<String> keys = RedisUtils.keys("%s*%s*".formatted(prefix, keyword));
|
|
||||||
List<String> list = new ArrayList<>(keys);
|
|
||||||
return SaFoxUtil.searchList(list, start, size, sortType);
|
|
||||||
}
|
|
||||||
}
|
|
@@ -43,7 +43,7 @@
|
|||||||
<redisson.version>3.45.0</redisson.version>
|
<redisson.version>3.45.0</redisson.version>
|
||||||
<jetcache.version>2.7.7</jetcache.version>
|
<jetcache.version>2.7.7</jetcache.version>
|
||||||
<cosid.version>2.11.0</cosid.version>
|
<cosid.version>2.11.0</cosid.version>
|
||||||
<sa-token.version>1.40.0</sa-token.version>
|
<sa-token.version>1.41.0</sa-token.version>
|
||||||
<just-auth.version>1.16.7</just-auth.version>
|
<just-auth.version>1.16.7</just-auth.version>
|
||||||
<mybatis-plus.version>3.5.8</mybatis-plus.version>
|
<mybatis-plus.version>3.5.8</mybatis-plus.version>
|
||||||
<mybatis-flex.version>1.10.8</mybatis-flex.version>
|
<mybatis-flex.version>1.10.8</mybatis-flex.version>
|
||||||
|
Reference in New Issue
Block a user