|
@@ -1,81 +1,81 @@
|
|
|
-//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 jakarta.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 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 Boolean verifyToken(String token) {
|
|
|
-// return TokenUtils.verifyToken(token, sysBaseApi, redisUtil);
|
|
|
-// }
|
|
|
-//
|
|
|
-// @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;
|
|
|
-// }
|
|
|
-//}
|
|
|
+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 jakarta.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 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 Boolean verifyToken(String token) {
|
|
|
+ return TokenUtils.verifyToken(token, sysBaseApi, redisUtil);
|
|
|
+ }
|
|
|
+
|
|
|
+ @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;
|
|
|
+ }
|
|
|
+}
|