feat(新增): 动态菜单

This commit is contained in:
bunny 2024-03-25 09:46:15 +08:00
parent db21e70786
commit 4b2141bb5a
8 changed files with 83 additions and 6 deletions

View File

@ -47,7 +47,9 @@ public class LoginAuthInterceptor implements HandlerInterceptor {
} }
// 将用户信息放到ThreadLocal中 // 将用户信息放到ThreadLocal中
BaseContext.setSysUser(JSON.parseObject(sysUserString, SysUser.class)); SysUser sysUser = JSON.parseObject(sysUserString, SysUser.class);
BaseContext.setSysUser(sysUser);
BaseContext.setUserId(sysUser.getId());
// 更新Redis过期时间 // 更新Redis过期时间
redisTemplate.expire(token, 7, TimeUnit.DAYS); redisTemplate.expire(token, 7, TimeUnit.DAYS);

View File

@ -2,8 +2,11 @@ package com.atguigu.utils;
import com.atguigu.spzx.model.entity.system.SysMenu; import com.atguigu.spzx.model.entity.system.SysMenu;
import com.atguigu.spzx.model.vo.system.SysMenuVo;
import org.springframework.util.CollectionUtils;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List; import java.util.List;
@ -43,4 +46,26 @@ public class MenuHelper {
return sysMenu; return sysMenu;
} }
/**
* 将List<SysMenu>对象转换成List<SysMenuVo>对象
*
* @param menus 全部菜单列表
* @return 系统菜单响应结果实体类列表
*/
public static List<SysMenuVo> buildMenus(List<SysMenu> menus) {
LinkedList<SysMenuVo> sysMenuVos = new LinkedList<>();
menus.forEach(menu -> {
SysMenuVo menuVo = new SysMenuVo();
menuVo.setTitle(menu.getTitle());
menuVo.setName(menu.getComponent());
List<SysMenu> children = menu.getChildren();
if (!CollectionUtils.isEmpty(children)) {
menuVo.setChildren(buildMenus(children));
}
sysMenuVos.add(menuVo);
});
return sysMenuVos;
}
} }

View File

@ -9,13 +9,13 @@ import org.springframework.context.annotation.ComponentScan;
import org.springframework.scheduling.annotation.EnableScheduling; import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.transaction.annotation.EnableTransactionManagement; import org.springframework.transaction.annotation.EnableTransactionManagement;
@Slf4j
@MapperScan("com.atguigu.spzx.manger.mapper")
@EnableCaching// 开启缓存注解
@ComponentScan("com.atguigu")
@EnableScheduling
@SpringBootApplication @SpringBootApplication
@EnableTransactionManagement // 开启注解方式的事务管理 @EnableTransactionManagement // 开启注解方式的事务管理
@EnableCaching// 开启缓存注解
@EnableScheduling
@ComponentScan("com.atguigu")
@MapperScan("com.atguigu.spzx.manger.mapper")
@Slf4j
public class MangerApplication { public class MangerApplication {
public static void main(String[] args) { public static void main(String[] args) {
SpringApplication.run(MangerApplication.class, args); SpringApplication.run(MangerApplication.class, args);

View File

@ -1,18 +1,22 @@
package com.atguigu.spzx.manger.controller; package com.atguigu.spzx.manger.controller;
import com.atguigu.context.BaseContext; import com.atguigu.context.BaseContext;
import com.atguigu.spzx.manger.service.SysMenuService;
import com.atguigu.spzx.manger.service.SysUserService; import com.atguigu.spzx.manger.service.SysUserService;
import com.atguigu.spzx.manger.service.ValidateCodeService; import com.atguigu.spzx.manger.service.ValidateCodeService;
import com.atguigu.spzx.model.dto.system.LoginDto; import com.atguigu.spzx.model.dto.system.LoginDto;
import com.atguigu.spzx.model.entity.system.SysUser; import com.atguigu.spzx.model.entity.system.SysUser;
import com.atguigu.spzx.model.vo.result.Result; import com.atguigu.spzx.model.vo.result.Result;
import com.atguigu.spzx.model.vo.system.LoginVo; import com.atguigu.spzx.model.vo.system.LoginVo;
import com.atguigu.spzx.model.vo.system.SysMenuVo;
import com.atguigu.spzx.model.vo.system.ValidateCodeVo; import com.atguigu.spzx.model.vo.system.ValidateCodeVo;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import java.util.List;
@Tag(name = "用户相关接口") @Tag(name = "用户相关接口")
@RestController @RestController
@RequestMapping("/admin/system/index") @RequestMapping("/admin/system/index")
@ -20,6 +24,8 @@ public class IndexController {
@Autowired @Autowired
private SysUserService sysUserService; private SysUserService sysUserService;
@Autowired @Autowired
private SysMenuService sysMenuService;
@Autowired
private ValidateCodeService validateCodeService; private ValidateCodeService validateCodeService;
@Operation(summary = "生成验证码", description = "生成验证码信息") @Operation(summary = "生成验证码", description = "生成验证码信息")
@ -49,4 +55,11 @@ public class IndexController {
sysUserService.logout(token); sysUserService.logout(token);
return Result.success(); return Result.success();
} }
@Operation(summary = "动态菜单", description = "动态菜单")
@GetMapping("menus")
public Result<List<SysMenuVo>> menus() {
List<SysMenuVo> sysMenuVoList = sysMenuService.findUserMenuList();
return Result.success(sysMenuVoList);
}
} }

View File

@ -42,4 +42,12 @@ public interface SysMenuMapper {
* @param id 菜单id * @param id 菜单id
*/ */
void deleteById(Long id); void deleteById(Long id);
/**
* 根据用户ID查找
*
* @param userId 用户ID
* @return 菜单列表
*/
List<SysMenu> selectListByUserId(Long userId);
} }

View File

@ -1,6 +1,7 @@
package com.atguigu.spzx.manger.service; package com.atguigu.spzx.manger.service;
import com.atguigu.spzx.model.entity.system.SysMenu; import com.atguigu.spzx.model.entity.system.SysMenu;
import com.atguigu.spzx.model.vo.system.SysMenuVo;
import java.util.List; import java.util.List;
@ -32,4 +33,11 @@ public interface SysMenuService {
* @param id 菜单id * @param id 菜单id
*/ */
void removeById(Long id); void removeById(Long id);
/**
* 动态菜单
*
* @return 动态菜单列表
*/
List<SysMenuVo> findUserMenuList();
} }

View File

@ -1,10 +1,12 @@
package com.atguigu.spzx.manger.service.impl; package com.atguigu.spzx.manger.service.impl;
import com.atguigu.constant.MessageConstant; import com.atguigu.constant.MessageConstant;
import com.atguigu.context.BaseContext;
import com.atguigu.exception.BunnyException; import com.atguigu.exception.BunnyException;
import com.atguigu.spzx.manger.mapper.SysMenuMapper; import com.atguigu.spzx.manger.mapper.SysMenuMapper;
import com.atguigu.spzx.manger.service.SysMenuService; import com.atguigu.spzx.manger.service.SysMenuService;
import com.atguigu.spzx.model.entity.system.SysMenu; import com.atguigu.spzx.model.entity.system.SysMenu;
import com.atguigu.spzx.model.vo.system.SysMenuVo;
import com.atguigu.utils.MenuHelper; import com.atguigu.utils.MenuHelper;
import com.atguigu.utils.StringEmptyUtil; import com.atguigu.utils.StringEmptyUtil;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
@ -64,4 +66,18 @@ public class SysMenuServiceImpl implements SysMenuService {
} }
sysMenuMapper.deleteById(id); sysMenuMapper.deleteById(id);
} }
/**
* 动态菜单
*
* @return 动态菜单列表
*/
@Override
public List<SysMenuVo> findUserMenuList() {
Long userId = BaseContext.getUserId();
// 根据用户ID查找
List<SysMenu> sysMenuList = sysMenuMapper.selectListByUserId(userId);
sysMenuList = MenuHelper.buildTree(sysMenuList);
return MenuHelper.buildMenus(sysMenuList);
}
} }

View File

@ -59,4 +59,9 @@
<include refid="columns"/> <include refid="columns"/>
from sys_menu where is_deleted = 0 order by sort_value from sys_menu where is_deleted = 0 order by sort_value
</select> </select>
<!-- 根据用户ID查找 -->
<select id="selectListByUserId" resultType="com.atguigu.spzx.model.entity.system.SysMenu">
</select>
</mapper> </mapper>