ExcelDataController.java 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. package com.wjp.modules.demo.controller;
  2. import com.alibaba.excel.EasyExcel;
  3. import com.github.xiaoymin.knife4j.annotations.Ignore;
  4. import com.wjp.common.constant.Constant;
  5. import com.wjp.common.page.PageData;
  6. import com.wjp.common.utils.ExcelDataListener;
  7. import com.wjp.common.utils.ExcelUtils;
  8. import com.wjp.common.utils.Result;
  9. import com.wjp.common.validator.AssertUtils;
  10. import com.wjp.common.validator.ValidatorUtils;
  11. import com.wjp.common.validator.group.AddGroup;
  12. import com.wjp.common.validator.group.DefaultGroup;
  13. import com.wjp.common.validator.group.UpdateGroup;
  14. import com.wjp.modules.demo.dto.ExcelDataDTO;
  15. import com.wjp.modules.demo.excel.ExcelDataExcel;
  16. import com.wjp.modules.demo.service.ExcelDataService;
  17. import io.swagger.v3.oas.annotations.Operation;
  18. import io.swagger.v3.oas.annotations.Parameter;
  19. import io.swagger.v3.oas.annotations.Parameters;
  20. import io.swagger.v3.oas.annotations.tags.Tag;
  21. import jakarta.servlet.http.HttpServletResponse;
  22. import lombok.AllArgsConstructor;
  23. import org.apache.shiro.authz.annotation.RequiresPermissions;
  24. import org.springframework.web.bind.annotation.*;
  25. import org.springframework.web.multipart.MultipartFile;
  26. import java.util.List;
  27. import java.util.Map;
  28. /**
  29. * Excel导入演示
  30. *
  31. * @author Toby javatangbin@163.com
  32. */
  33. @AllArgsConstructor
  34. @RestController
  35. @RequestMapping("demo/excel")
  36. @Tag(name = "Excel导入演示")
  37. public class ExcelDataController {
  38. private final ExcelDataService excelDataService;
  39. @GetMapping("page")
  40. @Operation(summary = "分页")
  41. @Parameters({
  42. @Parameter(name = Constant.PAGE, description = "当前页码,从1开始", required = true),
  43. @Parameter(name = Constant.LIMIT, description = "每页显示记录数", required = true),
  44. @Parameter(name = Constant.ORDER_FIELD, description = "排序字段"),
  45. @Parameter(name = Constant.ORDER, description = "排序方式,可选值(asc、desc)")
  46. })
  47. @RequiresPermissions("demo:excel:all")
  48. public Result<PageData<ExcelDataDTO>> page(@Parameter(hidden = true) @RequestParam Map<String, Object> params) {
  49. PageData<ExcelDataDTO> page = excelDataService.page(params);
  50. return new Result<PageData<ExcelDataDTO>>().ok(page);
  51. }
  52. @GetMapping("{id}")
  53. @Operation(summary = "信息")
  54. @RequiresPermissions("demo:excel:all")
  55. public Result<ExcelDataDTO> get(@PathVariable("id") Long id) {
  56. ExcelDataDTO data = excelDataService.get(id);
  57. return new Result<ExcelDataDTO>().ok(data);
  58. }
  59. @PostMapping
  60. @Operation(summary = "保存")
  61. @RequiresPermissions("demo:excel:all")
  62. public Result save(@RequestBody ExcelDataDTO dto) {
  63. //效验数据
  64. ValidatorUtils.validateEntity(dto, AddGroup.class, DefaultGroup.class);
  65. excelDataService.save(dto);
  66. return new Result();
  67. }
  68. @PutMapping
  69. @Operation(summary = "修改")
  70. @RequiresPermissions("demo:excel:all")
  71. public Result update(@RequestBody ExcelDataDTO dto) {
  72. //效验数据
  73. ValidatorUtils.validateEntity(dto, UpdateGroup.class, DefaultGroup.class);
  74. excelDataService.update(dto);
  75. return new Result();
  76. }
  77. @DeleteMapping
  78. @Operation(summary = "删除")
  79. @RequiresPermissions("demo:excel:all")
  80. public Result delete(@RequestBody Long[] ids) {
  81. //效验数据
  82. AssertUtils.isArrayEmpty(ids, "id");
  83. excelDataService.delete(ids);
  84. return new Result();
  85. }
  86. @PostMapping("import")
  87. @Operation(summary = "导入")
  88. @RequiresPermissions("demo:excel:all")
  89. public Result importExcel(@RequestParam("file") MultipartFile file) throws Exception {
  90. //解析并保存到数据库
  91. EasyExcel.read(file.getInputStream(), ExcelDataExcel.class, new ExcelDataListener<>(excelDataService)).sheet().doRead();
  92. return new Result();
  93. }
  94. @GetMapping("export")
  95. @Operation(summary = "导出")
  96. @RequiresPermissions("demo:excel:all")
  97. public void export(@Parameter(hidden = true) @RequestParam Map<String, Object> params, HttpServletResponse response) throws Exception {
  98. List<ExcelDataDTO> list = excelDataService.list(params);
  99. ExcelUtils.exportExcelToTarget(response, null, "Excel导入演示", list, ExcelDataExcel.class);
  100. }
  101. }