把canvas画布存为图片并保存到web目录下

前端代码:

$("#saveimg").click(function() {
	var c = document.getElementById("canvas"); //得到id为canvas的画布元素
	var dataURL = c.toDataURL("image/png");    //转化为base64编码的数据
	var imageData = dataURL.substring(22);     //把冗余字段去掉 "data:image/png;base64,"
	$.ajax({                                   //通过ajax将图片数据传到后台
		type : 'post',  
	        url : '${pageContext.request.contextPath}/center/CausalImgJson',  
	        data: 'dataURL=' + imageData,  
	        async : false, //同步方式  
	        success : function() {   
	   	}  
	});  
});

Java代码:

@RequestMapping("/CausalImgJson")
public @ResponseBody String causalImgJson(HttpServletRequest request,String dataURL,String test) {
	BASE64Decoder decoder = new BASE64Decoder();
	dataURL = dataURL.replace(" ", "+");//ajax传输过来的数据所有"+"都变成了" ";ajax在传输“+”和“&”时会丢失数据。
	try {
		byte[] b = decoder.decodeBuffer(dataURL);//转码得到图片数据
		ByteArrayInputStream bais = new ByteArrayInputStream(b);
		BufferedImage bi1 = ImageIO.read(bais);
		String path = request.getSession().getServletContext().getRealPath("/images/cau_img.png"); //获取绝对路径
		File w2 = new File(path);
		ImageIO.write(bi1, "png", w2);
	} catch (IOException e) {
		e.printStackTrace();
	}
	String str = "sucess";
	return str;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值