Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
A
aispace
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
Administrator
aispace
Commits
52ab6995
提交
52ab6995
authored
4月 10, 2026
作者:
kxjia
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
更新代码
上级
e48d8c32
显示空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
45 行增加
和
22 行删除
+45
-22
MenuService.java
...rc/main/java/com/fintech/penalty/service/MenuService.java
+25
-5
index.html
financial-penalty-monitor/frontend/dist/index.html
+1
-1
UserManage.vue
financial-penalty-monitor/frontend/src/views/UserManage.vue
+19
-16
没有找到文件。
financial-penalty-monitor/backend/src/main/java/com/fintech/penalty/service/MenuService.java
浏览文件 @
52ab6995
...
@@ -2,9 +2,11 @@ package com.fintech.penalty.service;
...
@@ -2,9 +2,11 @@ package com.fintech.penalty.service;
import
com.fintech.penalty.dto.*
;
import
com.fintech.penalty.dto.*
;
import
com.fintech.penalty.entity.Menu
;
import
com.fintech.penalty.entity.Menu
;
import
com.fintech.penalty.entity.Role
;
import
com.fintech.penalty.entity.RoleMenu
;
import
com.fintech.penalty.entity.RoleMenu
;
import
com.fintech.penalty.repository.MenuRepository
;
import
com.fintech.penalty.repository.MenuRepository
;
import
com.fintech.penalty.repository.RoleMenuRepository
;
import
com.fintech.penalty.repository.RoleMenuRepository
;
import
com.fintech.penalty.repository.RoleRepository
;
import
lombok.RequiredArgsConstructor
;
import
lombok.RequiredArgsConstructor
;
import
lombok.extern.slf4j.Slf4j
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
...
@@ -23,6 +25,7 @@ public class MenuService {
...
@@ -23,6 +25,7 @@ public class MenuService {
private
final
MenuRepository
menuRepository
;
private
final
MenuRepository
menuRepository
;
private
final
RoleMenuRepository
roleMenuRepository
;
private
final
RoleMenuRepository
roleMenuRepository
;
private
final
RoleRepository
roleRepository
;
public
List
<
MenuDTO
>
findAll
()
{
public
List
<
MenuDTO
>
findAll
()
{
List
<
Menu
>
allMenus
=
menuRepository
.
findAll
();
List
<
Menu
>
allMenus
=
menuRepository
.
findAll
();
...
@@ -98,21 +101,38 @@ public class MenuService {
...
@@ -98,21 +101,38 @@ public class MenuService {
roleCode
=
"ADMIN"
;
roleCode
=
"ADMIN"
;
}
}
if
(
"ADMIN"
.
equals
(
roleCode
))
{
List
<
Menu
>
allMenus
=
menuRepository
.
findAllVisible
();
List
<
Menu
>
allMenus
=
menuRepository
.
findAllVisible
();
if
(
allMenus
.
isEmpty
())
{
if
(
allMenus
.
isEmpty
())
{
log
.
warn
(
"No menus found in database"
);
return
new
ArrayList
<>();
return
new
ArrayList
<>();
}
}
if
(
"ADMIN"
.
equals
(
roleCode
))
{
return
buildTree
(
allMenus
);
return
buildTree
(
allMenus
);
}
}
return
buildTree
(
allMenus
.
stream
()
try
{
Role
role
=
roleRepository
.
findByCode
(
roleCode
).
orElse
(
null
);
if
(
role
!=
null
)
{
List
<
Long
>
menuIds
=
roleMenuRepository
.
findByRoleId
(
role
.
getId
()).
stream
()
.
map
(
RoleMenu:
:
getMenuId
)
.
collect
(
Collectors
.
toList
());
if
(!
menuIds
.
isEmpty
())
{
List
<
Menu
>
roleMenus
=
menuRepository
.
findAllById
(
menuIds
);
return
buildTree
(
roleMenus
.
stream
()
.
filter
(
m
->
m
.
getVisible
()
!=
null
&&
m
.
getVisible
())
.
filter
(
m
->
m
.
getVisible
()
!=
null
&&
m
.
getVisible
())
.
collect
(
Collectors
.
toList
()));
.
collect
(
Collectors
.
toList
()));
}
}
}
}
catch
(
Exception
e
)
{
log
.
warn
(
"获取角色菜单失败: {}"
,
e
.
getMessage
());
}
List
<
Menu
>
allMenus
=
menuRepository
.
findAllVisible
();
if
(
allMenus
.
isEmpty
())
{
return
new
ArrayList
<>();
}
return
buildTree
(
allMenus
);
}
public
MenuDTO
findById
(
Long
id
)
{
public
MenuDTO
findById
(
Long
id
)
{
Menu
menu
=
menuRepository
.
findById
(
id
)
Menu
menu
=
menuRepository
.
findById
(
id
)
...
...
financial-penalty-monitor/frontend/dist/index.html
浏览文件 @
52ab6995
...
@@ -5,7 +5,7 @@
...
@@ -5,7 +5,7 @@
<link
rel=
"icon"
href=
"/favicon.ico"
>
<link
rel=
"icon"
href=
"/favicon.ico"
>
<meta
name=
"viewport"
content=
"width=device-width, initial-scale=1.0"
>
<meta
name=
"viewport"
content=
"width=device-width, initial-scale=1.0"
>
<title>
金融监管处罚监控系统
</title>
<title>
金融监管处罚监控系统
</title>
<script
type=
"module"
crossorigin
src=
"/assets/index-
DLhtj81y
.js"
></script>
<script
type=
"module"
crossorigin
src=
"/assets/index-
C_I9toNW
.js"
></script>
<link
rel=
"stylesheet"
crossorigin
href=
"/assets/index-D_lRsYFa.css"
>
<link
rel=
"stylesheet"
crossorigin
href=
"/assets/index-D_lRsYFa.css"
>
</head>
</head>
<body>
<body>
...
...
financial-penalty-monitor/frontend/src/views/UserManage.vue
浏览文件 @
52ab6995
...
@@ -104,9 +104,7 @@
...
@@ -104,9 +104,7 @@
</el-form-item>
</el-form-item>
<el-form-item
label=
"角色"
prop=
"role"
>
<el-form-item
label=
"角色"
prop=
"role"
>
<el-select
v-model=
"form.role"
placeholder=
"请选择角色"
style=
"width: 100%"
>
<el-select
v-model=
"form.role"
placeholder=
"请选择角色"
style=
"width: 100%"
>
<el-option
label=
"管理员"
value=
"ADMIN"
/>
<el-option
v-for=
"item in roleOptions"
:key=
"item.value"
:label=
"item.label"
:value=
"item.value"
/>
<el-option
label=
"普通用户"
value=
"USER"
/>
<el-option
label=
"访客"
value=
"VIEWER"
/>
</el-select>
</el-select>
</el-form-item>
</el-form-item>
<el-form-item
label=
"状态"
prop=
"enabled"
v-if=
"isEdit"
>
<el-form-item
label=
"状态"
prop=
"enabled"
v-if=
"isEdit"
>
...
@@ -135,6 +133,12 @@ const pageSize = ref(10)
...
@@ -135,6 +133,12 @@ const pageSize = ref(10)
const
total
=
ref
(
0
)
const
total
=
ref
(
0
)
const
roleOptions
=
ref
([])
const
roleOptions
=
ref
([])
const
pagination
=
reactive
({
page
:
currentPage
,
size
:
pageSize
,
total
:
total
})
const
dialogVisible
=
ref
(
false
)
const
dialogVisible
=
ref
(
false
)
const
isEdit
=
ref
(
false
)
const
isEdit
=
ref
(
false
)
const
submitLoading
=
ref
(
false
)
const
submitLoading
=
ref
(
false
)
...
@@ -172,13 +176,14 @@ const fetchData = async () => {
...
@@ -172,13 +176,14 @@ const fetchData = async () => {
loading
.
value
=
true
loading
.
value
=
true
try
{
try
{
const
res
=
await
api
.
getUsers
({
const
res
=
await
api
.
getUsers
({
page
:
currentPage
.
valu
e
-
1
,
page
:
pagination
.
pag
e
-
1
,
size
:
pag
eSize
.
valu
e
size
:
pag
ination
.
siz
e
})
})
tableData
.
value
=
res
.
data
.
content
const
data
=
res
.
data
.
data
||
res
.
data
total
.
value
=
res
.
data
.
totalElements
tableData
.
value
=
data
.
content
||
[]
pagination
.
total
=
data
.
totalElements
||
data
.
total
||
0
}
catch
(
error
)
{
}
catch
(
error
)
{
console
.
error
(
'获取用户
列表
失败:'
,
error
)
console
.
error
(
'获取用户失败:'
,
error
)
}
finally
{
}
finally
{
loading
.
value
=
false
loading
.
value
=
false
}
}
...
@@ -187,17 +192,15 @@ const fetchData = async () => {
...
@@ -187,17 +192,15 @@ const fetchData = async () => {
const
fetchRoles
=
async
()
=>
{
const
fetchRoles
=
async
()
=>
{
try
{
try
{
const
res
=
await
api
.
getRolesSimple
()
const
res
=
await
api
.
getRolesSimple
()
roleOptions
.
value
=
res
.
data
.
map
(
r
=>
({
// 移除 nextTick,直接赋值
label
:
r
.
name
,
const
roles
=
res
.
data
||
[]
value
:
r
.
code
roleOptions
.
value
=
roles
.
map
(
r
=>
({
label
:
r
.
name
||
r
.
roleName
,
value
:
r
.
code
||
r
.
roleCode
}))
}))
}
catch
(
error
)
{
}
catch
(
error
)
{
console
.
error
(
'获取角色失败:'
,
error
)
console
.
error
(
'获取角色失败:'
,
error
)
roleOptions
.
value
=
[
roleOptions
.
value
=
[]
{
label
:
'管理员'
,
value
:
'ADMIN'
},
{
label
:
'普通用户'
,
value
:
'USER'
},
{
label
:
'访客'
,
value
:
'VIEWER'
}
]
}
}
}
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论