导出时excel报错,给出提示信息

1.jsp:

<span> <input type="button" id="exportBtn" class="but" name="query" value=" 导出" /></span>
<iframe id="iframeExport" style="display:none"></iframe>

2.js:

$("#exportBtn").click(function(){
	importExcelByIfream();
});
var importExcelByIfream = function() {
	var iframe = document.getElementById("iframeExport");
	iframe.src=me.getPath()+"/rest/achievement/exportTable?param1=param1&param2=param2";
}

3.java:

	@RequestMapping("/exportTable")
	public void exportTable(HttpServletRequest request,HttpServletResponse response) throws Exception{
		String param1= request.getParameter("param1");
		String param2= request.getParameter("param2");
	
		String fileName="导出excel.xls";

		try {
			HSSFWorkbook workbook = biz.exportTable(param1, param2);
			if (workbook!=null) {
				String userAgent = request.getHeader("User-Agent");
				if (userAgent.contains("MSIE") || userAgent.contains("Trident")) {// IE
					fileName = URLEncoder.encode(fileName, "UTF-8");
				} else if (null != userAgent && -1 != userAgent.indexOf("Mozilla")) { // 火狐,chrome等
					fileName = new String(fileName.getBytes("UTF-8"), "iso-8859-1");
				} 
				response.setContentType("application/vnd.ms-excel;charset=utf-8");
				response.setHeader("Content-disposition", "attachment; filename="+fileName);  
				workbook.write(response.getOutputStream());
			}else {
			        response.reset();
			        String info="导出数据出错,原因未知";
			        ServletOutputStream os = response.getOutputStream();
			        response.setHeader("Content-type", "text/html;charset=UTF-8");
			        os.write(("<script>").getBytes("UTF-8"));
			        os.write(("alert('"+info+"');").getBytes("UTF-8"));
			        os.write(("</script>").getBytes("UTF-8"));
				 	os.close();
			}
	
		} catch (Exception e) {
			e.printStackTrace();
			response.reset();
			String info="导出数据出错, "+e.getMessage().replaceAll("'", "“");
		        ServletOutputStream os = response.getOutputStream();
		        response.setHeader("Content-type", "text/html;charset=UTF-8");
		        os.write(("<script>").getBytes("UTF-8"));
		        os.write(("alert('"+info+"');").getBytes("UTF-8"));
		        os.write(("</script>").getBytes("UTF-8"));
		        os.close();
		}
		
	}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值