admin/test_403_fix.sql
lvfengfree b92e1119ae fix: 修复菜单为空问题 - 移除后端过滤home路由的错误逻辑
- 修复RouteService中错误过滤home路由的问题
- 后端现在正确返回所有用户有权限的路由
- 添加设备管理相关功能(列表、在线监控、电源管理、远程监控)
- 添加详细的修复文档和重启脚本
- 更新权限配置脚本

问题根源:后端代码中有逻辑会过滤掉home路由,导致前端收到空数组,无法生成菜单
解决方案:移除过滤home路由的逻辑,让后端返回所有有权限的路由
2026-03-01 09:50:19 +08:00

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;