AdminController.java 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. package com.free.controller.system;
  2. import java.util.HashMap;
  3. import java.util.List;
  4. import java.util.Map;
  5. import javax.validation.Valid;
  6. import org.springframework.beans.factory.annotation.Autowired;
  7. import org.springframework.cglib.beans.BeanCopier;
  8. import org.springframework.web.bind.annotation.DeleteMapping;
  9. import org.springframework.web.bind.annotation.GetMapping;
  10. import org.springframework.web.bind.annotation.PathVariable;
  11. import org.springframework.web.bind.annotation.PostMapping;
  12. import org.springframework.web.bind.annotation.RequestBody;
  13. import org.springframework.web.bind.annotation.RequestMapping;
  14. import org.springframework.web.bind.annotation.RequestParam;
  15. import org.springframework.web.bind.annotation.RestController;
  16. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  17. import com.baomidou.mybatisplus.core.metadata.IPage;
  18. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  19. import com.free.annotation.PassToken;
  20. import com.free.config.CustomizationException;
  21. import com.free.config.ExceptionEnum;
  22. import com.free.config.ResponseFormat;
  23. import com.free.dto.system.AdminCreateDTO;
  24. import com.free.entity.system.Admin;
  25. import com.free.service.system.AdminService;
  26. import com.free.utils.BcryptUtil;
  27. import io.swagger.annotations.Api;
  28. import io.swagger.annotations.ApiOperation;
  29. @RestController
  30. @RequestMapping("/admin")
  31. @Api(tags = "管理员用户")
  32. public class AdminController {
  33. @Autowired
  34. private AdminService service;
  35. /** 创建数据 */
  36. @ApiOperation("创建数据")
  37. @PostMapping("")
  38. public Object save(@RequestBody @Valid AdminCreateDTO data) {
  39. // 检查账号是否重复
  40. QueryWrapper<Admin> qw = new QueryWrapper<Admin>();
  41. qw.eq("account", data.getAccount());
  42. Long num = this.service.count(qw);
  43. // 重复抛出异常
  44. if (num > 0) {
  45. throw new CustomizationException(ExceptionEnum.ACCOUNT_IS_EXIST);
  46. }
  47. BeanCopier copier = BeanCopier.create(AdminCreateDTO.class, Admin.class, false);
  48. Admin adminData = new Admin();
  49. copier.copy(data, adminData, null);
  50. // 密码加密
  51. String ep = BcryptUtil.encryptPassword(adminData.getPassword());
  52. if (null != ep) {
  53. adminData.setPassword(ep);
  54. }
  55. this.service.save(adminData);
  56. // 再将数据查出来返回
  57. Admin returnData = this.service.getById(adminData.getId());
  58. return ResponseFormat.success(returnData);
  59. }
  60. /** 修改数据 */
  61. @ApiOperation("修改数据")
  62. @PostMapping("/{id}")
  63. public Object update(@PathVariable long id, @RequestBody Admin data) {
  64. QueryWrapper<Admin> qw = new QueryWrapper<Admin>();
  65. qw.eq("id", id);
  66. Long num = this.service.count(qw);
  67. if (num <= 0) {
  68. throw new CustomizationException(ExceptionEnum.NOT_FOUND);
  69. }
  70. data.setId(id);
  71. // 密码,账号不在修改范围内,清空
  72. data.setPassword(null);
  73. data.setAccount(null);
  74. this.service.updateById(data);
  75. Object newData = this.service.getById(id);
  76. return ResponseFormat.success(newData);
  77. }
  78. /** 列表查询 */
  79. @ApiOperation("查询数据列表")
  80. @SuppressWarnings({ "unchecked" })
  81. @GetMapping()
  82. public Object list(@RequestParam Map<String, Object> allParams) {
  83. Long skip = null, limit = null;
  84. Map map = new HashMap();
  85. QueryWrapper qw = new QueryWrapper<>();
  86. /** 参数处理处理 */
  87. for (String key : allParams.keySet()) {
  88. Object value = allParams.get(key);
  89. if (key.equals("skip")) {
  90. skip = Long.valueOf(String.valueOf(value));
  91. } else if (key.equals("limit")) {
  92. limit = Long.valueOf(String.valueOf(value));
  93. } else {
  94. if(key.equals("nick_name")||key.equals("account")){
  95. qw.like(key,value);
  96. } else {
  97. // 其他为查询条件
  98. qw.eq(key, value);
  99. }
  100. }
  101. }
  102. /** 分页处理 */
  103. if (null != skip && null != limit) {
  104. IPage page = new Page<>(skip, limit);
  105. IPage pageResult = service.page(page, qw);
  106. List data = pageResult.getRecords();
  107. long total = pageResult.getTotal();
  108. map.put("data", data);
  109. map.put("total", total);
  110. } else {
  111. List list = service.list(qw);
  112. map.put("data", list);
  113. }
  114. return ResponseFormat.success(map);
  115. }
  116. /** 根据id查询 */
  117. @ApiOperation("查询数据")
  118. @GetMapping("/{id}")
  119. public Object fetch(@PathVariable long id) {
  120. Object newData = service.getById(id);
  121. return ResponseFormat.success(newData);
  122. }
  123. /** 根据id删除数据 */
  124. @ApiOperation("删除数据")
  125. @DeleteMapping("/{id}")
  126. public Object delete(@PathVariable long id) {
  127. QueryWrapper<Admin> qw = new QueryWrapper<>();
  128. qw.eq("id", id);
  129. Long num = service.count(qw);
  130. if (num <= 0) {
  131. throw new CustomizationException(ExceptionEnum.NOT_FOUND);
  132. }
  133. service.removeById(id);
  134. return ResponseFormat.success();
  135. }
  136. @PassToken
  137. @PostMapping("/initData")
  138. public Object initSuperAdmin() {
  139. Admin admin = new Admin();
  140. admin.setAccount("sadmin");
  141. admin.setIs_super("0");
  142. admin.setNick_name("超级管理员");
  143. String pwd = "1qaz2wsx";
  144. String cpwd = BcryptUtil.encryptPassword(pwd);
  145. admin.setPassword(cpwd);
  146. this.service.save(admin);
  147. return ResponseFormat.success();
  148. }
  149. }