excel文件下载(Servlet版+excel插入图片)

@WebServlet("/PopDownload")
public class PopDownload extends HttpServlet {
	private static final long serialVersionUID = 1L;
	
    public PopDownload() {
    }

	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		String path = this.getServletContext().getRealPath("/")+"img/funny.jpg";
		File file = new File(path);
		if(file.exists()){
			//读取图片
			ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
			BufferedImage bufferedImage = ImageIO.read(file);
			ImageIO.write(bufferedImage, "jpg", byteArrayOutputStream);
			
			HSSFWorkbook wb = new HSSFWorkbook();
			HSSFSheet sheet = wb.createSheet("图片");
			
			HSSFPatriarch patriarch = sheet.createDrawingPatriarch(); 
			HSSFClientAnchor hssfClientAnchor = new HSSFClientAnchor(0, 0, 0, 0, (short)1, 1, (short)4, 8);
			patriarch.createPicture(hssfClientAnchor, wb.addPicture(byteArrayOutputStream.toByteArray(), HSSFWorkbook.PICTURE_TYPE_JPEG));
			byteArrayOutputStream.close();
			
			//设置请求头
			String returnName = "测试.xls";
			response.setContentType("application/octet-stream;charset=utf-8");
			returnName = response.encodeURL(new String(returnName.getBytes(),"iso8859-1"));			
			response.addHeader("Content-Disposition",   "attachment;filename=" + returnName);
		    
			ByteArrayOutputStream byteArrayOutputStream2 = new ByteArrayOutputStream();
			wb.write(byteArrayOutputStream2);
			response.setContentLength(byteArrayOutputStream2.size());
			
			//输出到浏览器
			ServletOutputStream outputstream = response.getOutputStream();
			byteArrayOutputStream2.writeTo(outputstream);					
			byteArrayOutputStream2.close();									
			outputstream.flush();											
			wb.close();
		}else{
			System.out.println("文件没有找到");
		}
		
	}

	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

}


项目名:popDownload


浏览器访问路径:localhost:8080/popDownload/PopDownload

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值