123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- package com.wjp.modules.demo.controller;
- import com.alibaba.excel.EasyExcel;
- import com.github.xiaoymin.knife4j.annotations.Ignore;
- import com.wjp.common.constant.Constant;
- import com.wjp.common.page.PageData;
- import com.wjp.common.utils.ExcelDataListener;
- import com.wjp.common.utils.ExcelUtils;
- import com.wjp.common.utils.Result;
- import com.wjp.common.validator.AssertUtils;
- import com.wjp.common.validator.ValidatorUtils;
- import com.wjp.common.validator.group.AddGroup;
- import com.wjp.common.validator.group.DefaultGroup;
- import com.wjp.common.validator.group.UpdateGroup;
- import com.wjp.modules.demo.dto.ExcelDataDTO;
- import com.wjp.modules.demo.excel.ExcelDataExcel;
- import com.wjp.modules.demo.service.ExcelDataService;
- import io.swagger.v3.oas.annotations.Operation;
- import io.swagger.v3.oas.annotations.Parameter;
- import io.swagger.v3.oas.annotations.Parameters;
- import io.swagger.v3.oas.annotations.tags.Tag;
- import jakarta.servlet.http.HttpServletResponse;
- import lombok.AllArgsConstructor;
- import org.apache.shiro.authz.annotation.RequiresPermissions;
- import org.springframework.web.bind.annotation.*;
- import org.springframework.web.multipart.MultipartFile;
- import java.util.List;
- import java.util.Map;
- /**
- * Excel导入演示
- *
- * @author Toby javatangbin@163.com
- */
- @AllArgsConstructor
- @RestController
- @RequestMapping("demo/excel")
- @Tag(name = "Excel导入演示")
- public class ExcelDataController {
- private final ExcelDataService excelDataService;
- @GetMapping("page")
- @Operation(summary = "分页")
- @Parameters({
- @Parameter(name = Constant.PAGE, description = "当前页码,从1开始", required = true),
- @Parameter(name = Constant.LIMIT, description = "每页显示记录数", required = true),
- @Parameter(name = Constant.ORDER_FIELD, description = "排序字段"),
- @Parameter(name = Constant.ORDER, description = "排序方式,可选值(asc、desc)")
- })
- @RequiresPermissions("demo:excel:all")
- public Result<PageData<ExcelDataDTO>> page(@Parameter(hidden = true) @RequestParam Map<String, Object> params) {
- PageData<ExcelDataDTO> page = excelDataService.page(params);
- return new Result<PageData<ExcelDataDTO>>().ok(page);
- }
- @GetMapping("{id}")
- @Operation(summary = "信息")
- @RequiresPermissions("demo:excel:all")
- public Result<ExcelDataDTO> get(@PathVariable("id") Long id) {
- ExcelDataDTO data = excelDataService.get(id);
- return new Result<ExcelDataDTO>().ok(data);
- }
- @PostMapping
- @Operation(summary = "保存")
- @RequiresPermissions("demo:excel:all")
- public Result save(@RequestBody ExcelDataDTO dto) {
- //效验数据
- ValidatorUtils.validateEntity(dto, AddGroup.class, DefaultGroup.class);
- excelDataService.save(dto);
- return new Result();
- }
- @PutMapping
- @Operation(summary = "修改")
- @RequiresPermissions("demo:excel:all")
- public Result update(@RequestBody ExcelDataDTO dto) {
- //效验数据
- ValidatorUtils.validateEntity(dto, UpdateGroup.class, DefaultGroup.class);
- excelDataService.update(dto);
- return new Result();
- }
- @DeleteMapping
- @Operation(summary = "删除")
- @RequiresPermissions("demo:excel:all")
- public Result delete(@RequestBody Long[] ids) {
- //效验数据
- AssertUtils.isArrayEmpty(ids, "id");
- excelDataService.delete(ids);
- return new Result();
- }
- @PostMapping("import")
- @Operation(summary = "导入")
- @RequiresPermissions("demo:excel:all")
- public Result importExcel(@RequestParam("file") MultipartFile file) throws Exception {
- //解析并保存到数据库
- EasyExcel.read(file.getInputStream(), ExcelDataExcel.class, new ExcelDataListener<>(excelDataService)).sheet().doRead();
- return new Result();
- }
- @GetMapping("export")
- @Operation(summary = "导出")
- @RequiresPermissions("demo:excel:all")
- public void export(@Parameter(hidden = true) @RequestParam Map<String, Object> params, HttpServletResponse response) throws Exception {
- List<ExcelDataDTO> list = excelDataService.list(params);
- ExcelUtils.exportExcelToTarget(response, null, "Excel导入演示", list, ExcelDataExcel.class);
- }
- }
|