session使用
可以配置session
的实现方式和过期时间,session
目前提供3种实现方式,可以根据实际情况进行选择。
- 本地session方式,默认
- redis方式
- caffeine方式
- 自定义实现(3.5.1新增)
[!question] 3.5版本开始,由
caffeine
代替guava
实现方式,3.5之前版本请使用guava
本地session方式
HttpServletRequest
中的session
。
session类型配置:
wueasy :
gateway:
session: #session配置
type: local #类型 local 本地session 默认,redis ,caffeine
tokenWriteCookie: false #token写入cookie, true 是, false 不是,默认false
session过期时间配置:
默认30分钟,单位秒
server :
servlet:
session:
cookie:
http-only: true
timeout: 1800
tracking-modes: cookie
redis方式
使用
redis
方式保存session
信息,支持分布式环境。
session类型配置:
wueasy :
gateway:
session: #session配置
type: redis #类型 local 本地session 默认,redis ,caffeine
redis-auto-expire: true #是否自动延期过期时间,默认true,3.7.4增加
session过期时间配置:
expire
: 过期时间,可以配置秒,分钟,小时,天,例如:30m
30分钟,2h
2小时
wueasy :
gateway:
session:
expire: 30m #过期时间
配置redis连接信息:
1.3.0
开始支持此配置,之前版本请参考spring boot redis
配置。
wueasy :
data:
redis: #redis配置
session:
database : 1 #数据库索引(默认为0)
host : 127.0.0.1 #服务器地址
port : 6379 #服务器连接端口
password : 123456 #服务器连接密码(默认为空)
pool : #连接池配置
maxIdle : 8 # 连接池中的最大空闲连接,默认值也是8。
minIdle : 0 #连接池中的最小空闲连接,默认值也是0。
maxTotal : 2000 # 如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
maxWaitMillis : 1000 # 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException
timeout : 3000 #连接超时时间(毫秒)
caffeine方式
使用
caffeine
缓存方式保存session
信息。
session类型配置:
wueasy :
gateway:
session: #session配置
type: caffeine #类型 local 本地session 默认,redis ,caffeine
session过期时间配置:
expire
: 过期时间,可以配置秒,分钟,小时,天,例如:30m
30分钟,2h
2小时
wueasy :
gateway:
session:
expire: 30m #过期时间
自定义实现方式
自定义实现session需要基础接口类
com.wueasy.gateway.security.service.SessionService
,并实现接口里面的所有方法
session类型配置:
wueasy :
gateway:
session: #session配置
type: custom #类型
参考类
/**
* 自定义session实现
* @author: fallsea
* @version 1.0
*/
@Service(GatewayConstants.SESSION_SERVICE_NAME_CUSTOM)
public class CustomSessionServiceImpl implements SessionService{
@Override
public void addSession(Session<?> session) {
// TODO Auto-generated method stub
}
@Override
public void updateSession(Session<?> session) {
// TODO Auto-generated method stub
}
@Override
public Session<?> getSession(String token) {
// TODO Auto-generated method stub
return null;
}
@Override
public Session<?> getRealSession(String token) {
// TODO Auto-generated method stub
return null;
}
@Override
public void removeSession(String token) {
// TODO Auto-generated method stub
}
@Override
public Session<?> createSession() {
// TODO Auto-generated method stub
return null;
}
@Override
public Session<?> getSession() {
// TODO Auto-generated method stub
return null;
}
@Override
public Session<?> getRealSession() {
// TODO Auto-generated method stub
return null;
}
@Override
public Set<String> queryUserTokenList(String userId) {
// TODO Auto-generated method stub
return null;
}
}
自定义token参数名称
3.7.2
版本开始增加,通过自定义方式指定参数名称。
wueasy :
gateway:
session: #session配置
token-name: token #自定义token名称,默认token
cookie-token-name: WUEASY-TOKEN #自定义cookie token名称,默认WUEASY-TOKEN
获取session对象
可以通过SessionUtil
工具,获取session
服务接口,从而对session进行操作。
SessionService sessionService = SessionUtil.getSessionService();
支持以下方法。
/**
* session服务类
* @author: fallsea
* @version 1.0
*/
public interface SessionService {
/**
* 增加session
* @author: fallsea
* @param session
*/
void addSession(Session session);
/**
* 更新session
* @author: fallsea
* @param session
*/
void updateSession(Session session);
/**
* 获取session
* @author: fallsea
* @param token
* @return
*/
Session<?> getSession(String token);
/**
* 获取真是的session(不需要处理缓存)
* @author: fallsea
* @param token
* @return
*/
Session<?> getRealSession(String token);
/**
* 删除缓存信息
* @author: fallsea
* @param token
*/
void removeSession(String token);
/**
* 创建session
* @author: fallsea
* @return
*/
Session<?> createSession();
/**
* 获取session
* @author: fallsea
* @return
*/
Session<?> getSession();
/**
* 获取真是的session(不需要处理缓存)
* @author: fallsea
* @return
*/
Session<?> getRealSession();
}