DExaminaFileController.java 9.0 KB
package com.skua.modules.technicalfile.controller;

import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;

import com.skua.core.api.vo.Result;
import com.skua.core.aspect.annotation.AutoLog;
import com.skua.core.query.QueryGenerator;
import com.skua.modules.technicalfile.entity.DExaminaFile;
import com.skua.modules.technicalfile.service.IDExaminaFileService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.jeecgframework.poi.excel.ExcelImportUtil;
import org.jeecgframework.poi.excel.def.NormalExcelConstants;
import org.jeecgframework.poi.excel.entity.ExportParams;
import org.jeecgframework.poi.excel.entity.ImportParams;
import org.jeecgframework.poi.excel.view.JeecgEntityExcelView;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.util.Arrays;
import java.util.List;
import java.util.Map;

/**
* 化验技术资料
*/
@Slf4j
@Api(tags="化验技术资料")
@RestController
@RequestMapping("/technicalfile/examinaFile")
public class DExaminaFileController {
   @Autowired
   private IDExaminaFileService dExaminaFileService;

   /**
     * 分页列表查询
    * @param dExaminaFile
    * @param pageNo
    * @param pageSize
    * @param req
    * @return
    */
   @AutoLog(value = "化验技术资料-分页列表查询")
   @ApiOperation(value="化验技术资料-分页列表查询", notes="化验技术资料-分页列表查询")
   @GetMapping(value = "/list")
   public Result<IPage<DExaminaFile>> queryPageList(DExaminaFile dExaminaFile,
                                                    @RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
                                                    @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
                                                    HttpServletRequest req) {
       Result<IPage<DExaminaFile>> result = new Result<IPage<DExaminaFile>>();
       QueryWrapper<DExaminaFile> queryWrapper = QueryGenerator.initQueryWrapper(dExaminaFile, req.getParameterMap());
       Page<DExaminaFile> page = new Page<DExaminaFile>(pageNo, pageSize);
       IPage<DExaminaFile> pageList = dExaminaFileService.page(page, queryWrapper);
       result.setSuccess(true);
       result.setResult(pageList);
       return result;
   }

   /**
     *   添加
    * @param dExaminaFile
    * @return
    */
   @AutoLog(value = "化验技术资料-添加")
   @ApiOperation(value="化验技术资料-添加", notes="化验技术资料-添加")
   @PostMapping(value = "/add")
   public Result<DExaminaFile> add(@RequestBody DExaminaFile dExaminaFile) {
       Result<DExaminaFile> result = new Result<DExaminaFile>();
       try {
           dExaminaFileService.save(dExaminaFile);
           result.success("添加成功!");
       } catch (Exception e) {
           log.error(e.getMessage(),e);
           result.error500("操作失败");
       }
       return result;
   }

   /**
     *  编辑
    * @param dExaminaFile
    * @return
    */
   @AutoLog(value = "化验技术资料-编辑")
   @ApiOperation(value="化验技术资料-编辑", notes="化验技术资料-编辑")
   @PutMapping(value = "/edit")
   public Result<DExaminaFile> edit(@RequestBody DExaminaFile dExaminaFile) {
       Result<DExaminaFile> result = new Result<DExaminaFile>();
       DExaminaFile dExaminaFileEntity = dExaminaFileService.getById(dExaminaFile.getId());
       if(dExaminaFileEntity==null) {
           result.error500("未找到对应实体");
       }else {
           boolean ok = dExaminaFileService.updateById(dExaminaFile);
           //TODO 返回false说明什么?
           if(ok) {
               result.success("修改成功!");
           }
       }

       return result;
   }

   /**
     *   通过id删除
    * @param id
    * @return
    */
   @AutoLog(value = "化验技术资料-通过id删除")
   @ApiOperation(value="化验技术资料-通过id删除", notes="化验技术资料-通过id删除")
   @DeleteMapping(value = "/delete")
   public Result<?> delete(@RequestParam(name="id",required=true) String id) {
       try {
           dExaminaFileService.removeById(id);
       } catch (Exception e) {
           log.error("删除失败",e.getMessage());
           return Result.error("删除失败!");
       }
       return Result.ok("删除成功!");
   }

   /**
     *  批量删除
    * @param ids
    * @return
    */
   @AutoLog(value = "化验技术资料-批量删除")
   @ApiOperation(value="化验技术资料-批量删除", notes="化验技术资料-批量删除")
   @DeleteMapping(value = "/deleteBatch")
   public Result<DExaminaFile> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
       Result<DExaminaFile> result = new Result<DExaminaFile>();
       if(ids==null || "".equals(ids.trim())) {
           result.error500("参数不识别!");
       }else {
           this.dExaminaFileService.removeByIds(Arrays.asList(ids.split(",")));
           result.success("删除成功!");
       }
       return result;
   }

   /**
     * 通过id查询
    * @param id
    * @return
    */
   @AutoLog(value = "化验技术资料-通过id查询")
   @ApiOperation(value="化验技术资料-通过id查询", notes="化验技术资料-通过id查询")
   @GetMapping(value = "/queryById")
   public Result<DExaminaFile> queryById(@RequestParam(name="id",required=true) String id) {
       Result<DExaminaFile> result = new Result<DExaminaFile>();
       DExaminaFile dExaminaFile = dExaminaFileService.getById(id);
       if(dExaminaFile==null) {
           result.error500("未找到对应实体");
       }else {
           result.setResult(dExaminaFile);
           result.setSuccess(true);
       }
       return result;
   }

 /**
     * 导出excel
  *
  * @param request
  * @param response
  */
 @RequestMapping(value = "/exportXls")
 public ModelAndView exportXls(HttpServletRequest request, HttpServletResponse response) {
     // Step.1 组装查询条件
     QueryWrapper<DExaminaFile> queryWrapper = null;
     try {
         String paramsStr = request.getParameter("paramsStr");
         if (StringUtils.isNotEmpty(paramsStr)) {
             String deString = URLDecoder.decode(paramsStr, "UTF-8");
             DExaminaFile dExaminaFile = JSON.parseObject(deString, DExaminaFile.class);
             queryWrapper = QueryGenerator.initQueryWrapper(dExaminaFile, request.getParameterMap());
         }
     } catch (UnsupportedEncodingException e) {
         e.printStackTrace();
     }

     //Step.2 AutoPoi 导出Excel
     ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
     List<DExaminaFile> pageList = dExaminaFileService.list(queryWrapper);
     //导出文件名称
     mv.addObject(NormalExcelConstants.FILE_NAME, "化验技术资料列表");
     mv.addObject(NormalExcelConstants.CLASS, DExaminaFile.class);
     mv.addObject(NormalExcelConstants.PARAMS, new ExportParams("化验技术资料列表数据", "导出人:Jeecg", "导出信息"));
     mv.addObject(NormalExcelConstants.DATA_LIST, pageList);
     return mv;
 }

 /**
     * 通过excel导入数据
  *
  * @param request
  * @param response
  * @return
  */
 @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
 public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
     MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
     Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
     for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
         MultipartFile file = entity.getValue();// 获取上传文件对象
         ImportParams params = new ImportParams();
         params.setTitleRows(2);
         params.setHeadRows(1);
         params.setNeedSave(true);
         try {
             List<DExaminaFile> listDExaminaFiles = ExcelImportUtil.importExcel(file.getInputStream(), DExaminaFile.class, params);
             dExaminaFileService.saveBatch(listDExaminaFiles);
             return Result.ok("文件导入成功!数据行数:" + listDExaminaFiles.size());
         } catch (Exception e) {
             log.error(e.getMessage(),e);
             return Result.error("文件导入失败:"+e.getMessage());
         } finally {
             try {
                 file.getInputStream().close();
             } catch (IOException e) {
                 e.printStackTrace();
             }
         }
     }
     return Result.ok("文件导入失败!");
 }

}