easypoi导出验证及校验码认证,模板唯一认证

文章描述了一个基于Java的API接口实现,用于动态导出文件并确保导入文件的模板真实性、唯一性和格式正确性。同时,还涉及了文件上传、模板校验以及Excel数据处理的相关操作。

动态导出文件,客户把文件信息补充完整,导入文件时,需要校验文件的真实性及文件的唯一性,确保导入的文件是单据的!

// 动态导出文件
@ApiOperation(value = "填报登记模板下载")
    @PostMapping(value = "/xxx/templateDownLoad")
    public void download(@RequestBody String jsonString, @RequestHeader("x-user-token") String token, HttpServletResponse response) {
   
   
        // 生成初始化,list内放需要导出的数据
        List<TemplateVo> findList = new ArrayList<>();
        Model model = JSON.parseObject(jsonString, Model.class);
        String msgid = model.getMsgid();
        if (StringUtils.isEmpty(msgid)){
   
   
            logger.info("未获取到唯一标识");
            throw new BusizException("唯一标识不能为空");
        }
        // 取得sql或者业务的内容
        findList = xxxService.getAll(model);
        try {
   
   
            //设置单元格位置
            CellRangeAddress cellAddresses = new CellRangeAddress(0, 0, 0, 0);
            //1.创建excel文档对象
            XSSFWorkbook wb = new XSSFWorkbook();
            //样式
            Map<String, XSSFCellStyle> cellStyle = createCellStyle(wb);
            //2.创建sheet对象
            XSSFSheet sheet = wb.createSheet("模板");
            //创建提示标题信息
            XSSFRow row0 = sheet.createRow(0);
            createTitle(row0, cellAddresses, sheet, cellStyle,msgid);
            //3.创建表头,创建第一行
            XSSFRow row1 = sheet.createRow(1);
            createHeaders(row1, cellAddresses, sheet, cellStyle);
            //填充数据
            createDataCellFdplPlan(findList1, sheet, cellStyle);
            //设置列宽
            setColumnLength(sheet);
            // 设置日期信息
            Calendar now = Calendar.getInstance();
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            String dateNowStr = sdf.format(now.getTime());
            // 开启流
            ByteArrayOutputStream bos = new ByteArrayOutputStream();
            wb.write(bos);
            byte[] bytes = bos.toByteArray();
            bos.close();
            response.setHeader("Content-Disposition", "attachment; filename=\"iJEP_" + dateNowStr + ".xlsx\"");
            response.addHeader("Content-Length", "" + bytes.length);
            response.setContentType("application/octet-stream; charset=UTF-8");
            IOUtils.write(bytes, response.getOutputStream());
            logger.info("登记模板--附件下载完成!");
        } catch (Exception e) {
   
   
            logger.info("登记模板--附件下载失败!" + e);
        }

    }
 // 样式设计   
 private Map<String, XSSFCellStyle> createCellStyle(XSSFWorkbook wb){
   
   
        Map<String, XSSFCellStyle> styles = new HashMap();
        XSSFCellStyle style = wb.createCellStyle();
        style.setAlignment(HorizontalAlignment.CENTER);
        style.setVerticalAlignment(VerticalAlignment.CENTER);
        style.setBorderRight(BorderStyle.THIN);
        style.setRightBorderColor(IndexedColors.GREY_50_PERCENT.getIndex());
        style.setBorderLeft(BorderStyle.THIN);
        style.setLeftBorderColor(IndexedColors.GREY_50_PERCENT.getIndex());
        style.setBorderTop(BorderStyle.THIN);
        style.setTopBorderColor(
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值