- 修复RouteService中错误过滤home路由的问题 - 后端现在正确返回所有用户有权限的路由 - 添加设备管理相关功能(列表、在线监控、电源管理、远程监控) - 添加详细的修复文档和重启脚本 - 更新权限配置脚本 问题根源:后端代码中有逻辑会过滤掉home路由,导致前端收到空数组,无法生成菜单 解决方案:移除过滤home路由的逻辑,让后端返回所有有权限的路由
93 lines
2.9 KiB
SQL
93 lines
2.9 KiB
SQL
-- 测试403修复是否成功
|
|
USE soybean_admin;
|
|
|
|
-- 1. 检查角色配置
|
|
SELECT '=== 角色菜单配置 ===' AS info;
|
|
SELECT
|
|
role_code AS '角色代码',
|
|
role_name AS '角色名称',
|
|
CASE
|
|
WHEN menus LIKE '%home%' THEN '✓ 包含home'
|
|
ELSE '✗ 缺少home'
|
|
END AS 'home权限',
|
|
CHAR_LENGTH(menus) - CHAR_LENGTH(REPLACE(menus, ',', '')) + 1 AS '菜单数量',
|
|
menus AS '配置的菜单'
|
|
FROM sys_role
|
|
WHERE status = 1
|
|
ORDER BY role_code;
|
|
|
|
-- 2. 检查用户配置
|
|
SELECT '=== 用户角色配置 ===' AS info;
|
|
SELECT
|
|
user_id AS '用户ID',
|
|
user_name AS '用户名',
|
|
roles AS '角色',
|
|
status AS '状态'
|
|
FROM sys_user
|
|
WHERE deleted = 0
|
|
ORDER BY user_id;
|
|
|
|
-- 3. 检查路由名称
|
|
SELECT '=== 路由名称检查 ===' AS info;
|
|
SELECT
|
|
name AS '路由名称',
|
|
path AS '路由路径',
|
|
CASE
|
|
WHEN name LIKE '%-%' AND name NOT LIKE '%_%' THEN '父路由(连字符)'
|
|
WHEN name LIKE '%_%' THEN '子路由(下划线)'
|
|
ELSE '单级路由'
|
|
END AS '路由类型',
|
|
component AS '组件'
|
|
FROM sys_route
|
|
WHERE status = 1
|
|
ORDER BY order_num;
|
|
|
|
-- 4. 验证关键路由是否存在
|
|
SELECT '=== 关键路由验证 ===' AS info;
|
|
SELECT
|
|
'home' AS '路由名称',
|
|
CASE WHEN EXISTS(SELECT 1 FROM sys_route WHERE name = 'home' AND status = 1)
|
|
THEN '✓ 存在' ELSE '✗ 不存在' END AS '状态'
|
|
UNION ALL
|
|
SELECT
|
|
'device',
|
|
CASE WHEN EXISTS(SELECT 1 FROM sys_route WHERE name = 'device' AND status = 1)
|
|
THEN '✓ 存在' ELSE '✗ 不存在' END
|
|
UNION ALL
|
|
SELECT
|
|
'device_list',
|
|
CASE WHEN EXISTS(SELECT 1 FROM sys_route WHERE name = 'device_list' AND status = 1)
|
|
THEN '✓ 存在' ELSE '✗ 不存在' END
|
|
UNION ALL
|
|
SELECT
|
|
'my-device',
|
|
CASE WHEN EXISTS(SELECT 1 FROM sys_route WHERE name = 'my-device' AND status = 1)
|
|
THEN '✓ 存在' ELSE '✗ 不存在' END
|
|
UNION ALL
|
|
SELECT
|
|
'my-device_status',
|
|
CASE WHEN EXISTS(SELECT 1 FROM sys_route WHERE name = 'my-device_status' AND status = 1)
|
|
THEN '✓ 存在' ELSE '✗ 不存在' END;
|
|
|
|
-- 5. 检查角色菜单与路由的匹配情况
|
|
SELECT '=== R_USER 角色菜单匹配检查 ===' AS info;
|
|
SELECT
|
|
SUBSTRING_INDEX(SUBSTRING_INDEX(menus, ',', numbers.n), ',', -1) AS '配置的菜单',
|
|
CASE
|
|
WHEN EXISTS(
|
|
SELECT 1 FROM sys_route
|
|
WHERE name = SUBSTRING_INDEX(SUBSTRING_INDEX(menus, ',', numbers.n), ',', -1)
|
|
AND status = 1
|
|
) THEN '✓ 路由存在'
|
|
ELSE '✗ 路由不存在'
|
|
END AS '匹配状态'
|
|
FROM sys_role
|
|
JOIN (
|
|
SELECT 1 n UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL
|
|
SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL
|
|
SELECT 9 UNION ALL SELECT 10 UNION ALL SELECT 11 UNION ALL SELECT 12
|
|
) numbers
|
|
WHERE role_code = 'R_USER'
|
|
AND CHAR_LENGTH(menus) - CHAR_LENGTH(REPLACE(menus, ',', '')) >= numbers.n - 1
|
|
ORDER BY numbers.n;
|