Java下载Excel兼容性问题

		String fileName = "Excel模板";
        String userAgent = request.getHeader("USER-AGENT").toLowerCase();
        if (userAgent != null) {
            if (userAgent.indexOf("msie") > -1 || userAgent.contains("like gecko")) {     win10 ie edge 浏览器 和其他系统的ie
                response.setHeader("Content-disposition", "attachment; filename="
                        + java.net.URLEncoder.encode((fileName + ".xls"), "utf-8"));
                response.setCharacterEncoding("UTF-8");
            } else { //其他浏览器   火狐  chrome, safari 下载文件名乱码问题
                response.setHeader("Content-disposition", "attachment; filename="
                        + new String((fileName + ".xls").getBytes("UTF-8"), "ISO-8859-1"));
                response.setCharacterEncoding("ISO-8859-1");
            }
        } else {
            response.setHeader("Content-disposition", "attachment; filename="
                    + java.net.URLEncoder.encode((fileName + ".xls"), "utf-8"));
            response.setCharacterEncoding("UTF-8");
        }
        response.setCharacterEncoding("UTF-8");
        response.setContentType("application/x-download charset=UTF-8");
        Workbook wb = new HSSFWorkbook();
        OutputStream outputStream = null;
        try {
            wb = bOMExportService.exportExcelModel(functionId);
            outputStream = response.getOutputStream();
            outputStream.flush();
        } catch (Exception e) {
            LOGGER.error(e.getMessage(), e);
        } finally {
            try {
                wb.write(outputStream);
                wb.close();
                outputStream.close();
            } catch (Exception e) {
	            LOGGER.error(e.getMessage(), e);
            }
        }

公众号

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值