Spring Boot与Shiro实现权限管理04
创始人
2024-04-07 02:18:01
0

1.实现用户管理

1.1 用户列表

首先创建dto,用于请求与响应数据的传输。在common包下创建dto包,在该包下创建UserDto.java类。

@Data
@AllArgsConstructor
@NoArgsConstructor
public class UserDto implements Serializable {private Integer id;private String username;
}
创建Controller层

在controller包下的UserController.java类添加用户查询控制器。

@RestController
@RequestMapping("/api")
public class UserController {@Autowiredprivate UserService userService;@RequiresPermissions("user:list")@ApiOperation("用户列表")@GetMapping("/users")public ResponseEntity> list(@RequestParam(required = false) Integer pageSize,@RequestParam(required = false) Integer pageNum) {PageCondition pc = new PageCondition(pageNum, pageSize);PageModel pageModel = userService.listAllUser(pc);return Results.success(pageModel);}
}
创建Service层

在service包下的UserService.java类添加查询用户列表方法。

    /*** 查询用户列表* @param condition* @return*/PageModel listAllUser(PageCondition condition);
    @Overridepublic PageModel listAllUser(PageCondition condition) {PageHelper.startPage(condition.getPageNum(), condition.getPageSize());PageInfo pageInfo = new PageInfo<>(sysUserMapper.findAll());return Results.pageModel(pageInfo);}
创建Mapper层
    /*** 查询用户列表* @return*/List findAll();
  
测试一下

在这里插入图片描述
后面对用户的新增,删除和修改等功能,其实现方式和流程与上面的流程基本一致,这里就不一一详细介绍了。

2.实现用户角色分配

前面已经创建了一个新的角色:“角色分配管理员A”,同时这个角色已经被分配了三个权限,接着在用户管理模块创建picachoA用户,为这个用户指定角色,角色被分配了一组权限,这就决定了这个用户访问系统时拥有这组权限。

完成Controller层
   @RequiresPermissions("user:assign-role")@ApiOperation("用户角色分配")@PutMapping("/user/{id}/role")public ResponseEntity assignRole(@RequestBody List roleIdList, @PathVariable Integer id) {userService.assignRole(id, roleIdList);return Results.success();}
完成Service层
   /*** 用户角色分配* @param id* @param roleIdList*/void assignRole(Integer id, List roleIdList);
    @Transactional@Overridepublic void assignRole(Integer userId, List roleIdList) {if (sysUserMapper.find(userId) == null) {throw Errors.badRequest("用户不存在");}if (!CollectionUtils.isEmpty(roleIdList)) {int count = sysRoleMapper.countByIds(roleIdList);if (count != roleIdList.size()) {throw Errors.badRequest("角色不存在");}}sysUserRoleMapper.deleteByUserId(userId);if (!CollectionUtils.isEmpty(roleIdList)) {List rps = roleIdList.stream().map(p -> {SysUserRole rp = new SysUserRole();rp.setRoleId(p);rp.setUserId(userId);return rp;}).collect(Collectors.toList());if (sysUserRoleMapper.insertBatch(rps) != roleIdList.size()) {throw Errors.db();}}}
完成mapper层

SysRoleMapper

    int countByIds(@Param("roleIdList") List roleIdList);
  

SysUserRoleMapper

    void deleteByUserId(Integer userId);int insertBatch(@Param("rps") List rps);
  deletefrom sys_user_rolewhere user_id = #{userId}insert into sys_user_role (role_id, user_id)values(#{t.roleId},#{t.userId})
测试一下

登陆超级管理员为用户picachoA分配角色分配管理员A,接着使用用户picachoA登陆查看其拥有的权限。

首先给超级管理员添加用户角色分配权限。

INSERT INTO `sys_permission`(id, permission_code, permission_name)VALUE (901, 'user:assign-role', '用户角色分配');INSERT INTO `sys_role_permission`(role_id, permission_id)
VALUES (1, 901);

在这里插入图片描述
此时为picachoA用户添加了“角色分配管理员A”的角色,这个用户就拥有了这个角色对应的权限了。

3.实现通知

3.1 实现新建通知

完成Controller层

在controller包下创建NotifyController.java类。

@RestController
@RequestMapping("api")
public class NotifyController {@Autowiredprivate NotifyService notifyService;@Autowiredprivate UserService userService;@RequiresPermissions("notify:add")@ApiOperation("创建通知")@PostMapping("/notify")public ResponseEntity add(@RequestBody String content) {if (StringUtils.isBlank(content)) {return Results.userInputError("通知内容不能为空");}String username = (String) SecurityUtils.getSubject().getPrincipal();Integer userID = userService.findUserID(username);NotifyDto dto = notifyService.create(userID, content);return Results.success(dto);}
}
完成Service层

UserService

    /*** 查询用户* @param username* @return*/Integer findUserID(String username);
    @Overridepublic Integer findUserID(String username) {SysUser user = sysUserMapper.findByUsername(username);if (user == null) {return null;}return user.getId();}

NotifyService

public interface NotifyService {NotifyDto create(Integer userId, String content);
}
@Service
public class NotifyServiceImpl implements NotifyService {@Autowiredprivate NotifyMapper notifyMapper;@Autowiredprivate SysUserMapper sysUserMapper;@Transactional@Overridepublic NotifyDto create(Integer userId, String content) {if (sysUserMapper.find(userId) == null) {throw Errors.badRequest("用户不存在");}Notify sr = new Notify();sr.setUserId(userId);sr.setContent(content);if (1 != notifyMapper.insert(sr)) {throw new ServiceException("无法新增通知记录到数据库");}return notifyMapper.findById(sr.getId());}}
完成mapper层
NotifyDto findById(Integer id);
  
测试一下

添加一个通知管理员用户

INSERT INTO `sys_role`(id, role_name)VALUE (3, '通知管理员');INSERT INTO `sys_role_permission`(role_id, permission_id)
VALUES (3, 101),(3, 102),(3, 103),(3, 104);INSERT INTO `sys_user`(id, username, password)VALUE (10003, 'picacho', '123456');INSERT INTO `sys_user_role`(user_id, role_id)VALUE (10003, 3);

在这里插入图片描述
还有通知的查询,编辑,删除就不一一实现,这个demo项目到这里就基本结束了。
源码下载地址:源码下载

上一篇:0092 图

下一篇:论NFV的六大用例

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...