Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
W
wangxiaolu-link-report
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
sfa
wangxiaolu-link-report
Commits
2181295a
提交
2181295a
authored
2月 11, 2025
作者:
吕本才
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
1、增加集成积木报表
上级
隐藏空白字符变更
内嵌
并排
正在显示
9 个修改的文件
包含
452 行增加
和
0 行删除
+452
-0
.gitignore
.gitignore
+35
-0
pom.xml
pom.xml
+111
-0
WangxiaoluLinkModuleReportApplication.java
...om/link/report/WangxiaoluLinkModuleReportApplication.java
+33
-0
JimuReportTokenServiceImpl.java
.../link/report/service/impl/JimuReportTokenServiceImpl.java
+128
-0
bootstrap-dev.yml
src/main/resources/bootstrap-dev.yml
+15
-0
bootstrap-live.yml
src/main/resources/bootstrap-live.yml
+15
-0
bootstrap-qa.yml
src/main/resources/bootstrap-qa.yml
+15
-0
bootstrap.yml
src/main/resources/bootstrap.yml
+3
-0
logback-spring.xml
src/main/resources/logback-spring.xml
+97
-0
没有找到文件。
.gitignore
0 → 100644
浏览文件 @
2181295a
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### IntelliJ IDEA ###
.idea/
*.iws
*.iml
*.ipr
### Eclipse ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
### Mac OS ###
.DS_Store
pom.xml
0 → 100644
浏览文件 @
2181295a
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<groupId>
com.wangxiaolu.sfa
</groupId>
<artifactId>
wangxiaolu-sfa-parent
</artifactId>
<version>
0.0.1
</version>
<!-- <relativePath/>-->
</parent>
<modelVersion>
4.0.0
</modelVersion>
<name>
wangxiaolu-link-report
</name>
<description>
wangxiaolu-link-report 报表工具模块,处理数仓数据展示图表
</description>
<groupId>
com.wangxiaolu.sfa
</groupId>
<artifactId>
wangxiaolu-link-report
</artifactId>
<version>
0.0.1
</version>
<properties>
<maven.compiler.source>
8
</maven.compiler.source>
<maven.compiler.target>
8
</maven.compiler.target>
</properties>
<dependencies>
<!-- SpringCloud Alibaba Nacos -->
<dependency>
<groupId>
com.alibaba.cloud
</groupId>
<artifactId>
spring-cloud-starter-alibaba-nacos-discovery
</artifactId>
</dependency>
<!-- SpringCloud Alibaba Nacos Config -->
<dependency>
<groupId>
com.alibaba.cloud
</groupId>
<artifactId>
spring-cloud-starter-alibaba-nacos-config
</artifactId>
</dependency>
<!-- SpringCloud Alibaba Sentinel -->
<dependency>
<groupId>
com.alibaba.cloud
</groupId>
<artifactId>
spring-cloud-starter-alibaba-sentinel
</artifactId>
</dependency>
<!--web-->
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-web
</artifactId>
</dependency>
<!--freemarker-->
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-freemarker
</artifactId>
</dependency>
<!-- minio oss-->
<dependency>
<groupId>
io.minio
</groupId>
<artifactId>
minio
</artifactId>
<version>
${minio.version}
</version>
<optional>
true
</optional>
</dependency>
<!-- RuoYi Common DataSource -->
<dependency>
<groupId>
com.wangxiaolu.sfa
</groupId>
<artifactId>
wangxiaolu-sfa-common-datasource
</artifactId>
</dependency>
<!-- RuoYi Common DataScope -->
<dependency>
<groupId>
com.wangxiaolu.sfa
</groupId>
<artifactId>
wangxiaolu-sfa-common-datascope
</artifactId>
</dependency>
<!-- RuoYi Common Log -->
<dependency>
<groupId>
com.wangxiaolu.sfa
</groupId>
<artifactId>
wangxiaolu-sfa-common-log
</artifactId>
</dependency>
<!-- Mysql Connector -->
<dependency>
<groupId>
com.mysql
</groupId>
<artifactId>
mysql-connector-j
</artifactId>
</dependency>
<!-- RuoYi Common Swagger -->
<dependency>
<groupId>
com.wangxiaolu.sfa
</groupId>
<artifactId>
wangxiaolu-sfa-common-swagger
</artifactId>
</dependency>
<!-- JimuReport -->
<dependency>
<groupId>
org.jeecgframework.jimureport
</groupId>
<artifactId>
jimureport-spring-boot-starter
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-web
</artifactId>
<optional>
true
</optional>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-maven-plugin
</artifactId>
</plugin>
</plugins>
</build>
</project>
src/main/java/com/link/report/WangxiaoluLinkModuleReportApplication.java
0 → 100644
浏览文件 @
2181295a
package
com
.
link
.
report
;
import
com.sfa.common.security.annotation.EnableCustomConfig
;
import
com.sfa.common.security.annotation.EnableRyFeignClients
;
import
org.mybatis.spring.annotation.MapperScan
;
import
org.springframework.boot.SpringApplication
;
import
org.springframework.boot.autoconfigure.SpringBootApplication
;
/**
* @description: 报表中心模块
* @author: wzlUp
* @date: 2023/06/16 17:05
* @motto: Done is better than perfect.
*/
@EnableCustomConfig
//@EnableCustomSwagger2
@EnableRyFeignClients
@MapperScan
(
"org.jeecg.modules.jmreport.dao"
)
@SpringBootApplication
(
scanBasePackages
=
{
"org.jeecg.modules.jmreport"
,
"com.link.report"
})
public
class
WangxiaoluLinkModuleReportApplication
{
public
static
void
main
(
String
[]
args
)
{
SpringApplication
.
run
(
WangxiaoluLinkModuleReportApplication
.
class
,
args
);
System
.
out
.
println
(
" .------------------------------------. \n"
+
" : __ :\n"
+
" : =='_)) __-:!:- :\n"
+
" : ,.' .' ))-:!:- :\n"
+
" : ((_,' .'-:!:- - Report Started - :\n"
+
" : ~^~~~^~~^~~~^~ :\n"
+
" `------------------------------------' "
);
}
}
src/main/java/com/link/report/service/impl/JimuReportTokenServiceImpl.java
0 → 100644
浏览文件 @
2181295a
package
com
.
link
.
report
.
service
.
impl
;
import
cn.hutool.core.date.DateUtil
;
import
com.sfa.common.core.utils.DateUtils
;
import
com.sfa.common.security.service.TokenService
;
import
com.sfa.common.security.utils.SecurityUtils
;
import
com.sfa.system.api.model.LoginUser
;
import
org.apache.commons.lang3.StringUtils
;
import
org.jeecg.modules.jmreport.api.JmReportTokenServiceI
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.http.HttpHeaders
;
import
org.springframework.stereotype.Component
;
import
javax.servlet.http.HttpServletRequest
;
import
java.util.HashMap
;
import
java.util.Map
;
/**
* @description: 自定义报表鉴权(如果不进行自定义, 则所有请求不做权限控制)
* @author: wzlUp
* @date: 2023/06/25 16:37
* @motto: Done is better than perfect.
*/
@Component
public
class
JimuReportTokenServiceImpl
implements
JmReportTokenServiceI
{
@Autowired
private
TokenService
tokenService
;
/**
* 通过请求获取Token
*/
@Override
public
String
getToken
(
HttpServletRequest
request
)
{
String
token
=
request
.
getParameter
(
"token"
);
String
jmToken
=
request
.
getHeader
(
"token"
);
if
(
token
==
null
||
token
.
length
()
==
0
)
{
token
=
jmToken
;
}
LoginUser
loginUser
=
tokenService
.
getLoginUser
(
token
);
if
(
loginUser
!=
null
)
{
return
token
;
}
return
""
;
}
/**
* 获取登录人用户名
*/
@Override
public
String
getUsername
(
String
s
)
{
LoginUser
loginUser
=
tokenService
.
getLoginUser
(
s
);
return
loginUser
.
getUsername
();
}
@Override
public
String
[]
getRoles
(
String
s
)
{
return
new
String
[
0
];
}
/**
* Token校验
*/
@Override
public
Boolean
verifyToken
(
String
s
)
{
if
(
s
!=
null
&&
s
.
length
()
>
0
)
{
LoginUser
loginUser
=
tokenService
.
getLoginUser
(
s
);
return
loginUser
!=
null
;
}
return
false
;
}
/**
* 自定义请求头
*/
@Override
public
HttpHeaders
customApiHeader
()
{
HttpHeaders
header
=
new
HttpHeaders
();
header
.
add
(
"X-Access-Token"
,
SecurityUtils
.
getToken
());
return
header
;
}
/**
* 获取多租户id
* @return tenantId
*/
public
String
getTenantId
()
{
String
token
=
SecurityUtils
.
getCurrentRequestInfo
().
getParameter
(
"token"
);
String
header
=
SecurityUtils
.
getCurrentRequestInfo
().
getHeader
(
"X-Access-Token"
);
LoginUser
loginUser
=
null
;
if
(
StringUtils
.
isNoneBlank
(
token
))
{
loginUser
=
tokenService
.
getLoginUser
(
token
);
}
else
if
(
StringUtils
.
isNotBlank
(
header
))
{
loginUser
=
tokenService
.
getLoginUser
(
header
);
}
else
{
//都不具备则不能访问
return
"NO"
;
}
//具备admin或者管理员权限才可访问所有报表
if
(
SecurityUtils
.
isAdmin
(
loginUser
.
getUserid
())
||
loginUser
.
getRoles
().
contains
(
"it"
)
||
loginUser
.
getRoles
().
contains
(
"manger"
))
{
return
""
;
}
return
loginUser
.
getUsername
();
}
@Override
public
Map
<
String
,
Object
>
getUserInfo
(
String
token
)
{
// 将所有信息存放至map 解析sql会根据map的键值解析,可自定义其他值
Map
<
String
,
Object
>
map
=
new
HashMap
<>(
20
);
LoginUser
loginUser
=
tokenService
.
getLoginUser
(
token
);
map
.
put
(
"sysUserCode"
,
loginUser
.
getUsername
());
//设置当前日期(年月日)
map
.
put
(
"sysData"
,
DateUtils
.
getDate
());
//设置昨天日期(年月日)
map
.
put
(
"sysYesterDay"
,
DateUtil
.
yesterday
());
//设置当前登录用户昵称
map
.
put
(
"sysUserName"
,
loginUser
.
getSysUser
().
getNickName
());
//设置当前登录用户部门ID
map
.
put
(
"deptId"
,
loginUser
.
getSysUser
().
getDeptId
());
//设置当前登录用户描述
// map.put("describe", loginUser.getSysUser().getDept().getDescribes());
map
.
put
(
"describe"
,
loginUser
.
getSysUser
().
getDept
().
getRemark
());
return
map
;
}
}
src/main/resources/bootstrap-dev.yml
0 → 100644
浏览文件 @
2181295a
spring
:
application
:
name
:
wangxiaolu-link-report
cloud
:
nacos
:
discovery
:
server-addr
:
127.0.0.1:8848
group
:
sfa
namespace
:
9fb64726-e415-43e4-9e79-9be8d2666671
config
:
server-addr
:
127.0.0.1:8848
file-extension
:
yaml
group
:
sfa
namespace
:
9fb64726-e415-43e4-9e79-9be8d2666671
src/main/resources/bootstrap-live.yml
0 → 100644
浏览文件 @
2181295a
spring
:
application
:
name
:
wangxiaolu-link-report
cloud
:
nacos
:
discovery
:
server-addr
:
192.168.100.38:8848
group
:
sfa
namespace
:
5ae12140-31d8-490a-9798-f923cb0e30d4
config
:
server-addr
:
192.168.100.38:8848
file-extension
:
yaml
group
:
sfa
namespace
:
5ae12140-31d8-490a-9798-f923cb0e30d4
src/main/resources/bootstrap-qa.yml
0 → 100644
浏览文件 @
2181295a
spring
:
application
:
name
:
wangxiaolu-link-report
cloud
:
nacos
:
discovery
:
server-addr
:
192.168.100.38:8848
group
:
sfa
namespace
:
24aed289-30a5-4e5c-8110-1b96281d1265
config
:
server-addr
:
192.168.100.38:8848
file-extension
:
yaml
group
:
sfa
namespace
:
24aed289-30a5-4e5c-8110-1b96281d1265
src/main/resources/bootstrap.yml
0 → 100644
浏览文件 @
2181295a
spring
:
profiles
:
active
:
dev
src/main/resources/logback-spring.xml
0 → 100644
浏览文件 @
2181295a
<?xml version="1.0" encoding="UTF-8"?>
<!-- 日志级别从低到高分为 TRACE < DEBUG < INFO < WARN < ERROR < FATAL,如果设置为WARN,则低于WARN的信息都不会输出 -->
<!-- scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true -->
<!-- scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。 -->
<!-- debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。 -->
<configuration
scan=
"true"
scanPeriod=
"60 seconds"
debug=
"false"
>
<property
name=
"APP_NAME"
value=
"wangxiaolu-link-report"
/>
<property
name=
"MODEL_NAME"
value=
"report"
/>
<contextName>
${APP_NAME}
</contextName>
<!-- 日志存放路径 对应yml文件中spring.profiles.active配置-->
<springProfile
name=
"dev"
>
<property
name=
"LOG_PATH"
value=
"./logs/${APP_NAME}"
/>
</springProfile>
<springProfile
name=
"qa,live"
>
<property
name=
"LOG_PATH"
value=
"/var/logs/sfa/${APP_NAME}"
/>
</springProfile>
<conversionRule
conversionWord=
"clr"
converterClass=
"org.springframework.boot.logging.logback.ColorConverter"
/>
<conversionRule
conversionWord=
"wex"
converterClass=
"org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter"
/>
<conversionRule
conversionWord=
"wEx"
converterClass=
"org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter"
/>
<property
name=
"CONSOLE_LOG_PATTERN"
value=
"${CONSOLE_LOG_PATTERN:-%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}} ${LOG_LEVEL_PATTERN:-%5p} --- [%thread] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"
/>
<property
name=
"FILE_LOG_PATTERN"
value=
"${FILE_LOG_PATTERN:-%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}} ${LOG_LEVEL_PATTERN:-%5p} --- [%thread] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"
/>
<!-- 控制台输出 -->
<appender
name=
"console"
class=
"ch.qos.logback.core.ConsoleAppender"
>
<encoder>
<pattern>
${CONSOLE_LOG_PATTERN}
</pattern>
<charset>
UTF-8
</charset>
</encoder>
</appender>
<!-- 按照每天生成日志文件 -->
<appender
name=
"rollingFile"
class=
"ch.qos.logback.core.rolling.RollingFileAppender"
>
<encoder>
<pattern>
${FILE_LOG_PATTERN}
</pattern>
</encoder>
<file>
${LOG_PATH}/${MODEL_NAME}-today.log
</file>
<rollingPolicy
class=
"ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"
>
<cleanHistoryOnStart>
false
</cleanHistoryOnStart>
<fileNamePattern>
${LOG_PATH}/${MODEL_NAME}-%d{yyyy-MM-dd}.%i.gz
</fileNamePattern>
<maxFileSize>
200MB
</maxFileSize>
<maxHistory>
30
</maxHistory>
<totalSizeCap>
0
</totalSizeCap>
</rollingPolicy>
</appender>
<!-- 按照每天生成日志文件 -->
<appender
name=
"errorFile"
class=
"ch.qos.logback.core.rolling.RollingFileAppender"
>
<encoder>
<pattern>
${FILE_LOG_PATTERN}
</pattern>
</encoder>
<file>
${LOG_PATH}/${MODEL_NAME}-error-today.log
</file>
<rollingPolicy
class=
"ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"
>
<cleanHistoryOnStart>
false
</cleanHistoryOnStart>
<fileNamePattern>
${LOG_PATH}/${MODEL_NAME}-error-%d{yyyy-MM-dd}.%i.gz
</fileNamePattern>
<maxFileSize>
200MB
</maxFileSize>
<maxHistory>
30
</maxHistory>
<totalSizeCap>
0
</totalSizeCap>
</rollingPolicy>
<!--
此日志文件只记录debug级别的
onMatch和onMismatch都有三个属性值,分别为Accept、DENY和NEUTRAL
onMatch="ACCEPT" 表示匹配该级别及以上
onMatch="DENY" 表示不匹配该级别及以上
onMatch="NEUTRAL" 表示该级别及以上的,由下一个filter处理,如果当前是最后一个,则表示匹配该级别及以上
onMismatch="ACCEPT" 表示匹配该级别以下
onMismatch="NEUTRAL" 表示该级别及以下的,由下一个filter处理,如果当前是最后一个,则不匹配该级别以下的
onMismatch="DENY" 表示不匹配该级别以下的
-->
<filter
class=
"ch.qos.logback.classic.filter.LevelFilter"
>
<level>
ERROR
</level>
<onMatch>
ACCEPT
</onMatch>
<onMismatch>
DENY
</onMismatch>
</filter>
</appender>
<!-- 控制台-->
<root
level=
"INFO"
>
<appender-ref
ref=
"console"
/>
</root>
<!-- 文件日志-->
<root
level=
"INFO"
>
<appender-ref
ref=
"rollingFile"
/>
<appender-ref
ref=
"errorFile"
/>
<!-- <appender-ref ref="logstash"/>-->
</root>
</configuration>
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论