From a4d146df2ee8fbfd243a16a8eabb8535d68b0750 Mon Sep 17 00:00:00 2001 From: chubin Date: Sun, 29 Sep 2024 15:54:30 +0800 Subject: [PATCH] =?UTF-8?q?1=E3=80=81=E7=94=A8=E6=88=B7=E8=A7=92=E8=89=B2?= =?UTF-8?q?=E5=85=B3=E8=81=94=202=E3=80=81=E5=BC=80=E5=90=AF=E4=BA=8B?= =?UTF-8?q?=E5=8A=A1=EF=BC=8C=E7=A1=AE=E4=BF=9D=E8=A1=A8=E5=8D=95=E6=95=B0?= =?UTF-8?q?=E6=8D=AE=E7=9A=84=E4=B8=80=E8=87=B4=E6=80=A7=203=E3=80=81?= =?UTF-8?q?=E6=96=B0=E5=A2=9EREADME.md=E6=96=87=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- demo/demo/README.md | 21 ++++++++ .../java/demo/Controller/RoleController.java | 14 ++++- .../java/demo/Controller/UserController.java | 44 ++++++++++++---- .../demo/Controller/UserRoleController.java | 26 ++++++++++ .../src/main/java/demo/DemoApplication.java | 2 + .../src/main/java/demo/Entity/UserDTO.java | 25 +++++++++ .../src/main/java/demo/Entity/UserRole.java | 25 +++++++++ .../src/main/java/demo/Mapper/UserMapper.java | 9 ++-- .../main/java/demo/Mapper/UserRoleMapper.java | 26 ++++++++++ .../java/demo/Service/UserRoleService.java | 52 +++++++++++++++++++ .../main/java/demo/Service/UserService.java | 7 ++- .../test/java/demo/DemoApplicationTests.java | 9 +--- 12 files changed, 233 insertions(+), 27 deletions(-) create mode 100644 demo/demo/README.md create mode 100644 demo/demo/src/main/java/demo/Controller/UserRoleController.java create mode 100644 demo/demo/src/main/java/demo/Entity/UserDTO.java create mode 100644 demo/demo/src/main/java/demo/Entity/UserRole.java create mode 100644 demo/demo/src/main/java/demo/Mapper/UserRoleMapper.java create mode 100644 demo/demo/src/main/java/demo/Service/UserRoleService.java diff --git a/demo/demo/README.md b/demo/demo/README.md new file mode 100644 index 0000000..c77f30a --- /dev/null +++ b/demo/demo/README.md @@ -0,0 +1,21 @@ +用户管理 + +1、注册时要往用户表和用户_角色关联表里面添加信息 + +2、删除时,先删除用户_角色关联表里面的信息,再删除用户表里面的信息 + +3、修改时,先修改用户表里面的信息,再修改用户_角色关联表里面的信息 + +4、查询时,要查询角色表和用户_角色关联表里面的信息 + +注意:1、2、3要开启事务,一致性 + +角色管理 + +1、新增时直接新增即可 + +2、删除时,先判断用户_角色关联表里面的信息,则不能删除角色表里面的信息 + +3、修改时,直接修改即可,关联表只是存储角色ID,不可变 + +4、查询时,直接查询即可 \ No newline at end of file diff --git a/demo/demo/src/main/java/demo/Controller/RoleController.java b/demo/demo/src/main/java/demo/Controller/RoleController.java index fdadd5f..a695b0e 100644 --- a/demo/demo/src/main/java/demo/Controller/RoleController.java +++ b/demo/demo/src/main/java/demo/Controller/RoleController.java @@ -2,6 +2,7 @@ package demo.Controller; import demo.Entity.*; import demo.Service.RoleService; +import demo.Service.UserRoleService; import lombok.Value; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.annotations.Delete; @@ -25,6 +26,9 @@ public class RoleController { @Autowired private RoleService roleService; + @Autowired + private UserRoleService userroleService; + //角色增删改查 /** @@ -62,8 +66,14 @@ public class RoleController { if (role==null){ return Result.error(401, "角色不存在"); }else { - roleService.deleteByRoleName(roleName); - return Result.success("删除成功"); + List userRole = userroleService.findByRoleId(role.getId()); + if(userRole.size()==0){ + roleService.deleteByRoleName(roleName); + return Result.success("删除成功"); + } + else { + return Result.error(401, "角色已被使用,暂且删除不了"); + } } } diff --git a/demo/demo/src/main/java/demo/Controller/UserController.java b/demo/demo/src/main/java/demo/Controller/UserController.java index 5a4f498..bb40135 100644 --- a/demo/demo/src/main/java/demo/Controller/UserController.java +++ b/demo/demo/src/main/java/demo/Controller/UserController.java @@ -2,14 +2,15 @@ package demo.Controller; import demo.Entity.*; import demo.Service.RoleService; +import demo.Service.UserRoleService; import demo.Service.UserService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.StringRedisTemplate; -import org.springframework.scheduling.annotation.Scheduled; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; +import javax.transaction.Transactional; import javax.validation.Valid; import javax.validation.constraints.Pattern; import java.time.Duration; @@ -18,7 +19,6 @@ import java.time.LocalDateTime; import java.time.ZoneOffset; import java.util.Date; import java.util.List; -import java.util.Set; @Slf4j @RestController @@ -29,6 +29,9 @@ public class UserController { @Autowired private UserService userService; + @Autowired + private UserRoleService userroleService; + @Autowired private StringRedisTemplate redisTemplate; @@ -43,13 +46,20 @@ public class UserController { * @param userVO * @return */ + @Transactional(rollbackOn = Exception.class) @PostMapping("/register") - public Result register(@RequestBody UserVO userVO) { + public Result register(@Valid UserVO userVO, @Valid int roleId) { // 查询用户名是否被占用 User user = userService.findByUserName(userVO.getLoginName()); if (user==null){ // 没有占用,进行注册 userService.register(userVO.getLoginName(), userVO.getUserChnName(), userVO.getPassword()); + User newUser = userService.findByUserName(userVO.getLoginName()); + userroleService.insert(newUser.getId(), roleId); + UserRole userRole = userroleService.findByUserId(newUser.getId()); + if(userRole==null){ + throw new RuntimeException("注册失败"); + } return Result.success("注册成功"); }else { return Result.error(401, "用户名已被占用"); @@ -61,13 +71,21 @@ public class UserController { * @param loginName * @return */ + @Transactional(rollbackOn = Exception.class) @DeleteMapping("/delete") public Result delete(@Pattern(regexp = "^\\S{5,16}$") String loginName){ // 查询用户名是否被占用 User user = userService.findByUserName(loginName); if (user!=null){ // 存在,进行删除 - userService.deleteByUserName(loginName); + User newUser = userService.findByUserName(loginName); + userroleService.delete(newUser.getId()); + UserRole userRole = userroleService.findByUserId(user.getId()); + userroleService.delete(userRole.getId()); + User newUser1 = userService.findByUserName(loginName); + if(userRole!=null && newUser1!=null){ + throw new RuntimeException("删除失败"); + } return Result.success("删除成功"); }else { return Result.error(401, "用户名不存在"); @@ -79,8 +97,9 @@ public class UserController { * @param userVo * @return */ + @Transactional(rollbackOn = Exception.class) @PutMapping("/update") - public Result update(@Valid UserVO userVo){ + public Result update(@Valid UserVO userVo, @Valid int roleId){ // 查询用户名是否被占用 User user = userService.findByUserName(userVo.getLoginName()); if (user!=null){ @@ -92,6 +111,13 @@ public class UserController { // 将Instant转换为Date Date date = Date.from(instant); userService.updateByUserName(userVo.getLoginName(), userVo.getUserChnName(), date, userVo.getPassword()); + UserRole userRole = userroleService.findByUserId(user.getId()); + if(userRole!=null){ + userroleService.update(user.getId(), roleId); + } + else{ + throw new RuntimeException("用户角色关联数据不存在,无法更新"); + } return Result.success("更新成功"); }else { return Result.error(401, "用户名不存在"); @@ -149,14 +175,14 @@ public class UserController { } @GetMapping("/query") - public Result> query(){ + public Result> query(){ return Result.success(userService.query()); } @PostMapping("/queryByUserName") - public Result queryByUserName(@Valid String loginName){ - User user = userService.queryByUserName(loginName); - if(user==null){ + public Result queryByUserName(@Valid String loginName){ + UserDTO userDTO = userService.queryByUserName(loginName); + if(userDTO==null){ return Result.error(401, "用户不存在"); } return Result.success(userService.queryByUserName(loginName)); diff --git a/demo/demo/src/main/java/demo/Controller/UserRoleController.java b/demo/demo/src/main/java/demo/Controller/UserRoleController.java new file mode 100644 index 0000000..ee25163 --- /dev/null +++ b/demo/demo/src/main/java/demo/Controller/UserRoleController.java @@ -0,0 +1,26 @@ +package demo.Controller; + +import demo.Entity.*; +import demo.Service.RoleService; +import lombok.Value; +import lombok.extern.slf4j.Slf4j; +import org.apache.ibatis.annotations.Delete; +import org.apache.ibatis.annotations.Param; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import javax.validation.Valid; +import java.time.Instant; +import java.time.LocalDateTime; +import java.time.ZoneOffset; +import java.util.Date; +import java.util.List; + +@Slf4j +@RestController +@RequestMapping("/role") +@Validated +public class UserRoleController { + +} diff --git a/demo/demo/src/main/java/demo/DemoApplication.java b/demo/demo/src/main/java/demo/DemoApplication.java index e488b53..28a8390 100644 --- a/demo/demo/src/main/java/demo/DemoApplication.java +++ b/demo/demo/src/main/java/demo/DemoApplication.java @@ -2,8 +2,10 @@ package demo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; +import org.springframework.transaction.annotation.EnableTransactionManagement; @SpringBootApplication +@EnableTransactionManagement//开启事务支持 //@MapperScan("demo.Mapper") // 指定扫描的包路径 public class DemoApplication { diff --git a/demo/demo/src/main/java/demo/Entity/UserDTO.java b/demo/demo/src/main/java/demo/Entity/UserDTO.java new file mode 100644 index 0000000..cf51245 --- /dev/null +++ b/demo/demo/src/main/java/demo/Entity/UserDTO.java @@ -0,0 +1,25 @@ +package demo.Entity; + +import lombok.Data; + +import javax.persistence.*; + +@Entity +@Data +public class UserDTO { + @Id + @Column(length = 32, nullable = false) + private int id; + + @Column(length = 50) + private String loginName; + + @Column(length = 50) + private String userChnName; + + @Column(length = 50) + private String roleName; + + @Column(length = 50) + private String roleCode; +} diff --git a/demo/demo/src/main/java/demo/Entity/UserRole.java b/demo/demo/src/main/java/demo/Entity/UserRole.java new file mode 100644 index 0000000..5117b72 --- /dev/null +++ b/demo/demo/src/main/java/demo/Entity/UserRole.java @@ -0,0 +1,25 @@ +package demo.Entity; + +import lombok.Data; + +import javax.persistence.*; +import java.util.Date; + +@Entity +@Data +@Table(name = "user_role_relation") +public class UserRole { + @Id + @Column(length = 32, nullable = false) + private int id; + + @Column(length = 32) + private int userID; + + @Column(length = 32) + private int roleID; + + @Temporal(TemporalType.TIMESTAMP) + @Column() + private Date createTime; +} \ No newline at end of file diff --git a/demo/demo/src/main/java/demo/Mapper/UserMapper.java b/demo/demo/src/main/java/demo/Mapper/UserMapper.java index 4601653..da57125 100644 --- a/demo/demo/src/main/java/demo/Mapper/UserMapper.java +++ b/demo/demo/src/main/java/demo/Mapper/UserMapper.java @@ -1,6 +1,7 @@ package demo.Mapper; import demo.Entity.User; +import demo.Entity.UserDTO; import org.apache.ibatis.annotations.*; import java.util.Date; @@ -24,9 +25,9 @@ public interface UserMapper { @Update("UPDATE user SET USER_CHN_NAME = #{userChnName}, UPDATE_TIME = #{updateTime}, PASSWORD = #{password} WHERE LOGIN_NAME = #{loginName}") void updateByUserName(@Param("loginName") String loginName, @Param("userChnName") String userChnName, @Param("updateTime") Date updateTime, @Param("password") String password); - @Select("SELECT * FROM user") - List findAll(); + @Select("SELECT user.ID, user.LOGIN_NAME, user.USER_CHN_NAME, role.ROLE_NAME, role.ROLE_CODE FROM user, role, user_role_relation WHERE user.ID = user_role_relation.USER_ID and role.ID = user_role_relation.ROLE_ID") + List findAll(); - @Select("SELECT * FROM user WHERE LOGIN_NAME = #{loginName}") - User queryByUserName(@Param("loginName")String loginName); + @Select("SELECT user.ID, user.LOGIN_NAME, user.USER_CHN_NAME, role.ROLE_NAME, role.ROLE_CODE FROM user, role, user_role_relation WHERE user.LOGIN_NAME = #{loginName} and user.ID = user_role_relation.USER_ID and role.ID = user_role_relation.ROLE_ID") + UserDTO queryByUserName(@Param("loginName")String loginName); } \ No newline at end of file diff --git a/demo/demo/src/main/java/demo/Mapper/UserRoleMapper.java b/demo/demo/src/main/java/demo/Mapper/UserRoleMapper.java new file mode 100644 index 0000000..5a34385 --- /dev/null +++ b/demo/demo/src/main/java/demo/Mapper/UserRoleMapper.java @@ -0,0 +1,26 @@ +package demo.Mapper; + +import demo.Entity.Role; +import demo.Entity.UserRole; +import org.apache.ibatis.annotations.*; + +import java.util.Date; +import java.util.List; + +@Mapper +public interface UserRoleMapper { + @Insert("INSERT INTO user_role_relation (USER_ID, ROLE_ID, CREATE_TIME) values (#{userId}, #{roleId}, #{createTime})") + void insert(@Param("userId") int userId, @Param("roleId") int roleId, @Param("createTime") Date createTime); + + @Delete("DELETE FROM user_role_relation WHERE USER_ID = #{userId}") + void delete(@Param("userId") int userId); + + @Select("SELECT * FROM user_role_relation WHERE ROLE_ID = #{roleId}") + List findByRoleId(@Param("roleId") int roleId); + + @Update("UPDATE user_role_relation SET ROLE_ID = #{roleId} WHERE USER_ID = #{userId}") + void update(@Param("userId") int userId, @Param("roleId") int roleId); + + @Select("SELECT * FROM user_role_relation WHERE USER_ID = #{userId}") + UserRole findByUserId(@Param("userId") int userId); +} diff --git a/demo/demo/src/main/java/demo/Service/UserRoleService.java b/demo/demo/src/main/java/demo/Service/UserRoleService.java new file mode 100644 index 0000000..9e1c122 --- /dev/null +++ b/demo/demo/src/main/java/demo/Service/UserRoleService.java @@ -0,0 +1,52 @@ +package demo.Service; + +import demo.Entity.Role; +import demo.Entity.RoleVO; +import demo.Entity.User; +import demo.Entity.UserRole; +import demo.Mapper.RoleMapper; +import demo.Mapper.UserMapper; +import demo.Mapper.UserRoleMapper; +import lombok.Data; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.time.Instant; +import java.time.LocalDateTime; +import java.time.ZoneOffset; +import java.util.Date; +import java.util.List; + +@Slf4j +@Service +public class UserRoleService { + @Autowired + private UserRoleMapper userroleMapper; + + public void insert(int userId, int roleId) { + // 创建一个LocalDateTime对象 + LocalDateTime localDateTime = LocalDateTime.now(); + // 将LocalDateTime转换为Instant + Instant instant = localDateTime.toInstant(ZoneOffset.UTC); + // 将Instant转换为Date + Date date = Date.from(instant); + userroleMapper.insert(userId, roleId, date); + } + + public void delete(int userId) { + userroleMapper.delete(userId); + } + + public List findByRoleId(int roleId) { + return userroleMapper.findByRoleId(roleId); + } + + public void update(int userId, int roleId) { + userroleMapper.update(userId, roleId); + } + + public UserRole findByUserId(int userId) { + return userroleMapper.findByUserId(userId); + } +} diff --git a/demo/demo/src/main/java/demo/Service/UserService.java b/demo/demo/src/main/java/demo/Service/UserService.java index addea9b..fa31456 100644 --- a/demo/demo/src/main/java/demo/Service/UserService.java +++ b/demo/demo/src/main/java/demo/Service/UserService.java @@ -1,9 +1,8 @@ package demo.Service; -import demo.Entity.Role; import demo.Entity.User; +import demo.Entity.UserDTO; import demo.Mapper.UserMapper; -import lombok.Data; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -46,11 +45,11 @@ public class UserService { userMapper.updateByUserName(loginName, userChnName, updateTime, password); } - public List query(){ + public List query(){ return userMapper.findAll(); } - public User queryByUserName(String loginName){ + public UserDTO queryByUserName(String loginName){ return userMapper.queryByUserName(loginName); } } diff --git a/demo/demo/src/test/java/demo/DemoApplicationTests.java b/demo/demo/src/test/java/demo/DemoApplicationTests.java index aa65aae..f8e4183 100644 --- a/demo/demo/src/test/java/demo/DemoApplicationTests.java +++ b/demo/demo/src/test/java/demo/DemoApplicationTests.java @@ -9,15 +9,8 @@ import javax.sql.DataSource; @SpringBootTest class DemoApplicationTests { - @Autowired - private DataSource dataSource; - @Autowired - private UserMapper userMapper; @Test - void contextLoads() throws Exception { - - System.out.println(dataSource.getConnection()); - + void contextLoads(){ } }