package com.ssm.healthclub.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ssm.healthclub.pojo.Menu;
import com.ssm.healthclub.mapper.MenuMapper;
import com.ssm.healthclub.pojo.RoleMenu;
import com.ssm.healthclub.pojo.Subject;
import com.ssm.healthclub.service.IMenuService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ssm.healthclub.service.IRoleMenuService;
import com.ssm.healthclub.utils.R;
import com.ssm.healthclub.utils.ResultCode;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.*;
/**
* <p>
* 服务实现类
* </p>
*
* @author gapCheung
* @since 2023-05-29
*/
@Service
public class MenuServiceImpl extends ServiceImpl<MenuMapper, Menu> implements IMenuService {
@Autowired
private MenuMapper menuMapper;
@Autowired
private IRoleMenuService roleMenuService;
/**
* 分页查询菜单
*
* @param title
* @param pageNumber
* @param pageSize
* @return
*/
@Override
public R queryPage(String title, Integer pageNumber, Integer pageSize) {
Map<String, Object> map = new HashMap<>();
QueryWrapper<Menu> queryWrapper = new QueryWrapper<>();
queryWrapper.like(title != null && !"".equals(title), "title", title);
queryWrapper.eq("isDel", 0).eq("type", 0);
Page page = new Page(pageNumber, pageSize);
IPage<Subject> ipage = menuMapper.selectPage(page, queryWrapper);
map.put("total", ipage.getTotal());
map.put("rows", ipage.getRecords());
return R.success(ResultCode.SUCCESS, map);
}
/**
* 通过用户id查询菜单列表
*
* @param userId
* @return
*/
@Override
public List<Menu> listMenusByUserId(Integer userId) {
return menuMapper.listMenusByUserId(userId);
}
/**
* 分页查询权限
*
* @param title
* @param pageNumber
* @param pageSize
* @return
*/
@Override
public R queryPagePermission(String title, Integer pageNumber, Integer pageSize) {
Map<String, Object> map = new HashMap<>();
QueryWrapper<Menu> queryWrapper = new QueryWrapper<>();
queryWrapper.like(title != null && !"".equals(title), "title", title);
queryWrapper.eq("isDel", 0).eq("type", 1);
Page page = new Page(pageNumber, pageSize);
IPage<Subject> ipage = menuMapper.selectPage(page, queryWrapper);
map.put("total", ipage.getTotal());
map.put("rows", ipage.getRecords());
return R.success(ResultCode.SUCCESS, map);
}
/**
* 更新角色的菜单和权限
*
* @param ids
* @param roleId
* @return
*/
@Override
@Transactional
public R updMenuPermission(String ids, String roleId) {
try {
// 1.更新tb_menu中的remark字段
List<String> menuIdsList = new ArrayList<>();
List<Menu> menuList = menuMapper.selectList(new QueryWrapper<Menu>().eq("isDel", 0));
for (Menu menu : menuList) {
menuIdsList.add(String.valueOf(menu.getId()));
}
// 传过来的id数组查询数据库是否已存在该权限,如果存在不改,不存在修改
String[] roleIds = ids.split(",");
List<String> roleIdsList = new ArrayList<>();
for (String id : roleIds) {
roleIdsList.add(id);
Menu menu = menuMapper.selectById(id);
if (menu.getRemark().contains(roleId)) {
} else {
// 赋予权限
menu.setRemark(menu.getRemark() + "," + roleId);
menuMapper.update(menu, new QueryWrapper<Menu>().eq("type", 1).eq("id", menu.getId()));
}
}
// 未传过来的id数组说明不赋予权限,如果之前有,则取消权限
List<String> different = getDifferent(menuIdsList, roleIdsList);
for (String diffId : different) {
Menu menu = menuMapper.selectById(diffId);
if (menu.getRemark().contains(roleId)) {
// 删除权限
menu.setRemark(menu.getRemark().replace(("," + roleId), ""));
menuMapper.update(menu, new QueryWrapper<Menu>().eq("type", 1).eq("id", menu.getId()));
}
}
// 2.更新角色菜单中间表
// 先删除原有表中的数据
roleMenuService.remove(new QueryWrapper<RoleMenu>().eq("roleId", roleId));
// 重新新增数据
List<RoleMenu> roleMenuList = new ArrayList<>();
for (String menuId : roleIds) {
RoleMenu roleMenu = new RoleMenu(null, Integer.valueOf(roleId), Integer.valueOf(menuId));
roleMenuList.add(roleMenu);
}
roleMenuService.saveBatch(roleMenuList);
return R.success(ResultCode.SUCCESS);
} catch (Exception e) {
e.printStackTrace();
return R.success(ResultCode.FAIL);
}
}
/**
* 通过角色id查询对应的菜单和权限
*
* @param roleId
* @return
*/
@Override
public R showMenuPermission(String roleId) {
QueryWrapper<Menu> menuQuery = new QueryWrapper<Menu>().eq("type", 0).eq("isDel", 0).eq("parentId", 0);
QueryWrapper<Menu> menuChildQuery = new QueryWrapper<Menu>().eq("type", 0).eq("isDel", 0).ne("parentId", 0);
QueryWrapper<Menu> perQuery = new QueryWrapper<Menu>().eq("type", 1).eq("isDel", 0);
List<Menu> menuList = menuMapper.selectList(menuQuery);
List<Menu> menuChildList = menuMapper.selectList(menuChildQuery);
List<Menu> permissionList = menuMapper.selectList(perQuery);
for (Menu menu : menuList) {
List<Menu> arr = new ArrayList<>();
for (String roleIds : menu.getRemark().split(",")) {
if (roleIds.equals(roleId)) {
menu.setChecked(true);
}
}
for (Menu childMenu : menuChildList) {
List<Menu> ss = new ArrayList<>();
for (String roleIds : childMenu.getRemark().split(",")) {
if (roleIds.equals(roleId)) {
childMenu.setChecked(true);
}
}
if (childMenu.getParentId() == menu.getId()) {
arr.add(childMenu);
menu.setChildren(arr);
for (Menu permission : permissionList) {
if (permission.getParentId() == childMenu.getId()) {
ss.add(permission);
childMenu.setChildren(ss);
}
for (String roleIds : permission.getRemark().split(",")) {
if (roleIds.equals(roleId)) {
permission.setChecked(true);
}
}
}
}
}
}
return R.success(ResultCode.SUCCESS, menuList);
}
/**
* 从两个集合中取出不同的值
*
* @param list1
* @param list2
* @return
*/
private static List<String> getDifferent(List<String> list1, List<String> list2) {
List<String> diff = new ArrayList<>();
Map<String, Integer> map = new HashMap<>(list1.size() + list2.size());
List<String> maxList = list1;
List<String> minList = list2;
if (list2.size() > list1.size()) {
maxList = list2;
minList = list1;
}
没有合适的资源?快使用搜索试试~ 我知道了~
基于SSM框架的健身俱乐部管理系统设计源码
共373个文件
java:111个
gif:76个
js:71个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 67 浏览量
2024-04-19
01:13:37
上传
评论
收藏 13.96MB ZIP 举报
温馨提示
本源码为基于SSM框架的健身俱乐部管理系统设计,共包含373个文件,其中java文件111个,gif文件76个,js文件71个,html文件26个,css文件18个,png文件15个,xml文件14个,less文件10个,map文件5个,eot文件4个。该系统采用SSM技术栈开发,包括Spring、Spring MVC和MyBatis,提供了会员管理、课程预约、健身设备管理等功能,适用于健身俱乐部进行日常运营管理。
资源推荐
资源详情
资源评论
收起资源包目录
基于SSM框架的健身俱乐部管理系统设计源码 (373个子文件)
bootstrap.css 138KB
layui.css 117KB
bootstrap.min.css 114KB
layui.css 59KB
bootstrap-theme.css 22KB
swiper.css 20KB
bootstrap-theme.min.css 19KB
sweetalert.css 18KB
swiper.min.css 17KB
layer.css 14KB
updxadmin.css 10KB
xadmin.css 10KB
layui.mobile.css 10KB
bootstrap-datetimepicker.min.css 8KB
laydate.css 7KB
bootstrap-table.min.css 6KB
code.css 1KB
font.css 505B
iconfont.eot 53KB
iconfont.eot 48KB
iconfont.eot 40KB
glyphicons-halflings-regular.eot 20KB
loginbg.gif 299KB
59.gif 10KB
22.gif 10KB
24.gif 8KB
13.gif 7KB
16.gif 7KB
39.gif 6KB
64.gif 6KB
63.gif 6KB
50.gif 6KB
loading-0.gif 6KB
4.gif 6KB
1.gif 5KB
42.gif 5KB
71.gif 5KB
21.gif 5KB
20.gif 5KB
29.gif 5KB
70.gif 4KB
5.gif 4KB
17.gif 4KB
27.gif 4KB
9.gif 4KB
44.gif 4KB
11.gif 4KB
8.gif 4KB
3.gif 4KB
23.gif 4KB
34.gif 4KB
41.gif 4KB
38.gif 4KB
65.gif 3KB
32.gif 3KB
45.gif 3KB
7.gif 3KB
12.gif 3KB
26.gif 3KB
60.gif 3KB
2.gif 3KB
40.gif 3KB
25.gif 3KB
19.gif 3KB
66.gif 3KB
18.gif 3KB
46.gif 3KB
10.gif 3KB
28.gif 3KB
51.gif 3KB
57.gif 3KB
67.gif 3KB
0.gif 3KB
48.gif 3KB
43.gif 3KB
30.gif 2KB
61.gif 2KB
33.gif 2KB
69.gif 2KB
14.gif 2KB
47.gif 2KB
36.gif 2KB
49.gif 2KB
58.gif 2KB
6.gif 2KB
54.gif 2KB
53.gif 2KB
56.gif 2KB
62.gif 2KB
31.gif 2KB
55.gif 2KB
35.gif 2KB
15.gif 2KB
loading-2.gif 2KB
37.gif 1KB
68.gif 1KB
52.gif 777B
loading-1.gif 701B
coachTeaching.html 35KB
goods.html 35KB
共 373 条
- 1
- 2
- 3
- 4
资源评论
沐知全栈开发
- 粉丝: 4745
- 资源: 3373
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功