|
|
@ -61,13 +61,18 @@ public class TokenAop {
|
|
|
|
@Around("requestMapping()")
|
|
|
|
@Around("requestMapping()")
|
|
|
|
public Object tokenAop(ProceedingJoinPoint point) throws Throwable {
|
|
|
|
public Object tokenAop(ProceedingJoinPoint point) throws Throwable {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Token
|
|
|
|
|
|
|
|
String requestToken = TokenThreadLocal.get();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 如果 ThreadLocal为空 则去当前request中获取
|
|
|
|
|
|
|
|
if(StringUtils.isEmpty(requestToken)){
|
|
|
|
// 将 Token放入 线程缓存
|
|
|
|
// 将 Token放入 线程缓存
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
RequestAttributes ra = RequestContextHolder.getRequestAttributes();
|
|
|
|
RequestAttributes ra = RequestContextHolder.getRequestAttributes();
|
|
|
|
ServletRequestAttributes sra = (ServletRequestAttributes) ra;
|
|
|
|
ServletRequestAttributes sra = (ServletRequestAttributes) ra;
|
|
|
|
if(sra != null) {
|
|
|
|
if(sra != null) {
|
|
|
|
HttpServletRequest request = sra.getRequest();
|
|
|
|
HttpServletRequest request = sra.getRequest();
|
|
|
|
String requestToken = UserTokenUtil.getRequestToken(request);
|
|
|
|
requestToken = UserTokenUtil.getRequestToken(request);
|
|
|
|
if(StringUtils.isNotEmpty(requestToken)){
|
|
|
|
if(StringUtils.isNotEmpty(requestToken)){
|
|
|
|
// 放入当前线程缓存中
|
|
|
|
// 放入当前线程缓存中
|
|
|
|
TokenThreadLocal.put(requestToken);
|
|
|
|
TokenThreadLocal.put(requestToken);
|
|
|
@ -78,6 +83,8 @@ public class TokenAop {
|
|
|
|
}catch (Exception e){
|
|
|
|
}catch (Exception e){
|
|
|
|
log.error(e.getMessage(),e);
|
|
|
|
log.error(e.getMessage(),e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 计时器
|
|
|
|
// 计时器
|
|
|
|
TimeInterval timer = DateUtil.timer();
|
|
|
|
TimeInterval timer = DateUtil.timer();
|
|
|
@ -96,9 +103,12 @@ public class TokenAop {
|
|
|
|
long timerCount = timer.interval();
|
|
|
|
long timerCount = timer.interval();
|
|
|
|
//保存日志
|
|
|
|
//保存日志
|
|
|
|
LogUtil.saveLog(point, exception, timerCount);
|
|
|
|
LogUtil.saveLog(point, exception, timerCount);
|
|
|
|
|
|
|
|
|
|
|
|
// 线程销毁时 删除 token
|
|
|
|
// 线程销毁时 删除 token
|
|
|
|
|
|
|
|
if(StringUtils.isNotEmpty(requestToken)){
|
|
|
|
TokenThreadLocal.remove();
|
|
|
|
TokenThreadLocal.remove();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return returnValue;
|
|
|
|
return returnValue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|