文件下载 上传 方法

/**
 * 文件下载
 * @param fileAddress  file的完整路径
 * @param originalFilename 文件名
 * @param response
 * @throws IOException
 */
public static void downloadFile(String fileAddress,String originalFilename, HttpServletResponse response) {
    InputStream inStream = null;
    try {
        inStream = new FileInputStream(fileAddress);
        response.reset();
        response.addHeader("Access-Control-Allow-Origin", "*");
        response.addHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");
        response.addHeader("Access-Control-Allow-Headers", "Content-Type");
        response.setContentType("application/octet-stream");
        response.setHeader("Content-Disposition", "attachment;filename=" +
                new String(originalFilename.getBytes(StandardCharsets.UTF_8), StandardCharsets.ISO_8859_1));
        byte[] b = new byte[1024];
        int len;
        while ((len = inStream.read(b)) > 0) {
            response.getOutputStream().write(b, 0, len);
        }
        inStream.close();
    } catch (IOException e) {
        throw new RuntimeException("文件下载异常"+e.getMessage());
    }finally {
        if (inStream != null){
            try {
                inStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

public static Workbook importExcel(MultipartFile file) throws Exception {
    String fileName = file.getOriginalFilename();
    if (!fileName.matches("^.+\\.(?i)(xls)$") && !fileName.matches("^.+\\.(?i)(xlsx)$")) {
        throw new Exception("文件上传格式不正确");
    }
    boolean isExcel2003 = true;
    if (fileName.matches("^.+\\.(?i)(xlsx)$")) {
        isExcel2003 = false;
    }
    InputStream is = file.getInputStream();
    Workbook wb = null;
    if (isExcel2003) {
        wb = new HSSFWorkbook(is);
    } else {
        wb = new XSSFWorkbook(is);
    }
    return wb;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值