DOtherFileController.java 8.8 KB
package com.skua.modules.technicalfile.controller;

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

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.DOtherFile;
import com.skua.modules.technicalfile.service.IDOtherFileService;
import java.util.Date;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
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 com.alibaba.fastjson.JSON;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;

/**
* 其他技术资料
*/
@Slf4j
@Api(tags="其他技术资料")
@RestController
@RequestMapping("/technicalfile/otherFile")
public class DOtherFileController {
   @Autowired
   private IDOtherFileService dOtherFileService;

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

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

   /**
     *  编辑
    * @param dOtherFile
    * @return
    */
   @AutoLog(value = "其他技术资料-编辑")
   @ApiOperation(value="其他技术资料-编辑", notes="其他技术资料-编辑")
   @PutMapping(value = "/edit")
   public Result<DOtherFile> edit(@RequestBody DOtherFile dOtherFile) {
       Result<DOtherFile> result = new Result<DOtherFile>();
       DOtherFile dOtherFileEntity = dOtherFileService.getById(dOtherFile.getId());
       if(dOtherFileEntity==null) {
           result.error500("未找到对应实体");
       }else {
           boolean ok = dOtherFileService.updateById(dOtherFile);
           //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 {
           dOtherFileService.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<DOtherFile> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
       Result<DOtherFile> result = new Result<DOtherFile>();
       if(ids==null || "".equals(ids.trim())) {
           result.error500("参数不识别!");
       }else {
           this.dOtherFileService.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<DOtherFile> queryById(@RequestParam(name="id",required=true) String id) {
       Result<DOtherFile> result = new Result<DOtherFile>();
       DOtherFile dOtherFile = dOtherFileService.getById(id);
       if(dOtherFile==null) {
           result.error500("未找到对应实体");
       }else {
           result.setResult(dOtherFile);
           result.setSuccess(true);
       }
       return result;
   }

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

     //Step.2 AutoPoi 导出Excel
     ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
     List<DOtherFile> pageList = dOtherFileService.list(queryWrapper);
     //导出文件名称
     mv.addObject(NormalExcelConstants.FILE_NAME, "其他技术资料列表");
     mv.addObject(NormalExcelConstants.CLASS, DOtherFile.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<DOtherFile> listDOtherFiles = ExcelImportUtil.importExcel(file.getInputStream(), DOtherFile.class, params);
             dOtherFileService.saveBatch(listDOtherFiles);
             return Result.ok("文件导入成功!数据行数:" + listDOtherFiles.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("文件导入失败!");
 }

}