后台服务处理下载Excel文件(二)

下载模板方式一:
Controller类

  /**
         * 下载模板
         * @param response
         * @param activeId
         */
        @RequestMapping("/downloadExcel")
        public void downloadExcel(HttpServletResponse response, @RequestParam("id") Long activeId){
   
            String excelFile = getClass().getResource("/static/templates/links_addr.xlsx").getPath();
            String path = getClass().getResource("/static/templates/").getPath();
            //查询所有需要上传的榜单id列表
            List<Top> topList = topService.getNeedTopLinkList(activeId);
            if(CollectionUtils.isNotEmpty(topList)){
                File newFile = linkService.convertDownExcel(excelFile, path, topList);
                //向前后输出文件流
                exportExcel(response, newFile);
                //删除新生成的文件
                deleteFile(newFile);
            }else{
                //导出文件
                exportExcel(response, new File(excelFile));
            }
            logger.error("没有榜单链接模板,activeId:{}",activeId);
        }
        
    /**
    	 * 导出excel文件
    	 * @param response
    	 * @param excelFile
    	 */
    	public static void exportExcel(HttpServletResponse response, File excelFile){
    
    		try{
    			// 下载
    			InputStream fis = new BufferedInputStream(new FileInputStream(excelFile));
    			byte[] buffer = new byte[fis.available()];
    			fis.read(buffer);
    			fis.close();
    
    			response.reset();
    			response.setContentType("text/html;charset=UTF-8");
    			OutputStream output = new BufferedOutputStream(response.getOutputStream());
    			response.setContentType("application/x-msdownload");
    			String newName = URLEncoder.encode(excelFile.getName(),"UTF-8");
    			response.addHeader("Content-Disposition", "attachment;filename=\"" + newName + "\"");
    			response.addHeader("Content-Length", "" + excelFile.length());
    			output.write(buffer);
    			output.flush();
    
    		}catch (IOException e) {
    			e.printStackTrace();
    		}
    
    	}

service类

 /**
     * 解析excel
     * @param tempPath
     * @param path
     * @param topList
     * @return
     */
    @Override
    public File convertDownExcel(String tempPath, String path,List<Top> topList) {

        File newFile = ExcelUtil.createNewFile(tempPath, path);
//        File newFile = new File(tempPath);
        InputStream is = null;
        XSSFWorkbook workbook = null;
        XSSFSheet sheet = null;
        try {
            is = new FileInputStream(newFile);// 将excel文件转为输入流
            workbook = new XSSFWorkbook(is);// 创建个workbook,
            // 获取第一个sheet
            sheet = workbook.getSheetAt(1);
        } catch (Exception e1) {
            e1.printStackTrace();
        }

        if (sheet != null) {
            try {
                // 写数据
                FileOutputStream fos = new FileOutputStream(newFile);
                XSSFRow row = sheet.getRow(0);
                if (row == null) {
                    row = sheet.createRow(0);
                }
                XSSFCell cell = row.getCell(0);
                if (cell == null) {
                    cell = row.createCell(0);
                }

                for (int i = 0; i < topList.size(); i++) {
                    Top vo = topList.get(i);
                    row = sheet.createRow(i + 1); //从第二行开始

                    //根据excel模板格式写入数据....
                    ExcelUtil.createRowAndCell(vo.getId(), row, cell, 0);
                    ExcelUtil.createRowAndCell(vo.getTitle(), row, cell, 1);

                }
                workbook.write(fos);
                fos.flush();
                fos.close();

                // 下载
                InputStream fis = new BufferedInputStream(new FileInputStream(newFile));
                byte[] buffer = new byte[fis.available()];
                fis.read(buffer);
                fis.close();

            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                try {
                    if (null != is) {
                        is.close();
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }

        return newFile;
    }

ExcelUtil.java

/**
 * 读取excel模板,并复制到新文件中供写入和下载
 *
 * @return
 */
public static File createNewFile(String tempPath, String rPath) {
    // 读取模板,并赋值到新文件************************************************************
    // 文件模板路径
    String path = tempPath;
    File file = new File(path);
    // 保存文件的路径
    String realPath = rPath;
    // 新的文件名
    String newFileName = System.currentTimeMillis() + "_" + file.getName();
    // 判断路径是否存在
    File dir = new File(realPath);
    if (!dir.exists()) {
        dir.mkdirs();
    }
    // 写入到新的excel
    File newFile = new File(realPath, newFileName);
    try {
        newFile.createNewFile();
        // 复制模板到新文件
        fileChannelCopy(file, newFile);
    } catch (Exception e) {
        e.printStackTrace();
    }
    return newFile;
}
/**
     * 复制文件
     *
     * @param s 源文件
     * @param t 复制到的新文件
     */

    public static void fileChannelCopy(File s, File t) {
        try {
            InputStream in = null;
            OutputStream out = null;
            try {
                in = new BufferedInputStream(new FileInputStream(s), 1024);
                out = new BufferedOutputStream(new FileOutputStream(t), 1024);
                byte[] buffer = new byte[1024];
                int len;
                while ((len = in.read(buffer)) != -1) {
                    out.write(buffer, 0, len);
                }
            } finally {
                if (null != in) {
                    in.close();
                }
                if (null != out) {
                    out.close();
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
创建系统服务的模块,木马使用的SvcHost服务方式启动, 现在不用,共享一下,拿些积分! '=======================================================++ ' 函数名称:CreateNormalService ' 函数说明:创建一个标准系统服务 ' 返回数值:4-提供参数不对,2-服务存在,0-创建成功 ' 参数说明:(服务名,映像路径,服务显示名,服务描述) ' 必填参数:(serviceName,serviceImagePath,"","") '=======================================================++ ' 函数名称:CreateSvcHostService ' 函数说明:创建一个SvcHost启动的服务 ' 返回数值:True-成功,False-失败 ' 参数说明:(服务名,DLL路径,SvcHost组名,服务显示名,服务描述) ' 必填参数:(serviceName,serviceDll,scvHostGroup,"","") '=======================================================++ ' 函数名称:ReplaceSvcHostService ' 函数说明:替换一个原来的SvcHost服务 ' 返回数值:True-成功,False-失败 ' 参数说明:(服务名,DLL路径,SvcHost组名) '=======================================================++ ' 函数名称:DeleteTheService ' 函数说明:删除一个服务 ' 参数说明:(服务名,SvcHost服务组名) ' 调用说明:第个参数一般为空,(删除SvcHost的服务才用) '======================================================= ' 函数名称:Add_SvcHost_serviceName ' 函数说明:在SvcHost服务组里增加一个服务名称 ' 返回数值:返回BOOL,并设置serviceNameIsAlreadyExist(BOOL) ' 参数说明:(SvcHost组名,SvcHost服务名,服务名是否已存在标志) '=======================================================+ ' 函数名称:ControlServiceStatus ' 函数说明:控制服务运行状态 ' 参数说明:(服务名,运行状态) ' 调用说明:第个参数:"pause","continue","stop"

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值