package org.jeecg.config.jimureport;
|
|
import lombok.extern.slf4j.Slf4j;
|
import org.jeecg.common.system.util.JwtUtil;
|
import org.jeecg.common.system.vo.SysUserCacheInfo;
|
import org.jeecg.common.util.RedisUtil;
|
import org.jeecg.common.util.TokenUtils;
|
import org.jeecg.modules.jmreport.api.JmReportTokenServiceI;
|
import org.jeecg.modules.system.service.impl.SysBaseApiImpl;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.context.annotation.Lazy;
|
import org.springframework.stereotype.Component;
|
import org.springframework.util.CollectionUtils;
|
|
import javax.servlet.http.HttpServletRequest;
|
import java.util.HashMap;
|
import java.util.Map;
|
import java.util.Set;
|
|
/**
|
* 自定义积木报表鉴权(如果不进行自定义,则所有请求不做权限控制)
|
* * 1.自定义获取登录token
|
* * 2.自定义获取登录用户
|
* @author: jeecg-boot
|
*/
|
|
|
@Slf4j
|
@Component
|
public class JimuReportTokenService implements JmReportTokenServiceI {
|
@Autowired
|
private SysBaseApiImpl sysBaseApi;
|
@Autowired
|
@Lazy
|
private RedisUtil redisUtil;
|
|
@Override
|
public String getToken(HttpServletRequest request) {
|
return TokenUtils.getTokenByRequest(request);
|
}
|
|
@Override
|
public String getUsername(String token) {
|
return JwtUtil.getUsername(token);
|
}
|
|
@Override
|
public Boolean verifyToken(String token) {
|
return TokenUtils.verifyToken(token, sysBaseApi, redisUtil);
|
}
|
|
@Override
|
public String[] getRoles(String token) {
|
String username = JwtUtil.getUsername(token);
|
Set roles = sysBaseApi.getUserRoleSet(username);
|
if(CollectionUtils.isEmpty(roles)){
|
return null;
|
}
|
return (String[]) roles.toArray(new String[roles.size()]);
|
}
|
|
@Override
|
public Map<String, Object> getUserInfo(String token) {
|
Map<String, Object> map = new HashMap(5);
|
String username = JwtUtil.getUsername(token);
|
//此处通过token只能拿到一个信息 用户账号 后面的就是根据账号获取其他信息 查询数据或是走redis 用户根据自身业务可自定义
|
SysUserCacheInfo userInfo = null;
|
try {
|
userInfo = sysBaseApi.getCacheUser(username);
|
} catch (Exception e) {
|
log.error("获取用户信息异常:"+ e.getMessage());
|
return map;
|
}
|
//设置账号名
|
map.put(SYS_USER_CODE, userInfo.getSysUserCode());
|
//设置部门编码
|
map.put(SYS_ORG_CODE, userInfo.getSysOrgCode());
|
// 将所有信息存放至map 解析sql/api会根据map的键值解析
|
return map;
|
}
|
}
|