谈canvas转图片的方法(base64编码)

版权声明:版权归wsc所有 https://blog.csdn.net/qq_37543808/article/details/88655052

上代码:这首先的是前端代码

<canvas width="400" height="400" style="margin:50px auto;border: 1px solid #ccc;">
		你的浏览器不支持Canvas
	</canvas>
	<span style="cursor:pointer;">点击下载</span>
	
	<script type="text/javascript">
			var canvas = $("canvas")[0];
			var cav = canvas.getContext("2d");
			cav.width = 200;
			cav.height = 200;

            cav.fillStyle = "#DC143C";
			cav.fillRect(0,0,200,200);

		var download = $("span");
		download.click(function () {
			 var baseStr = canvas.toDataURL("image/png");
             console.log(baseStr);
             baseStr = baseStr.substring(baseStr.laseIndexOf(",")+1);
			 $.post("<%=path %>/images/upload.do",{baseStr:baseStr},function () {
						
						
             })
            
        })
		
	</script>

上控制层代码:

package com.spring.Controller;

import java.io.File;
import java.util.Enumeration;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import com.spring.util.ImageDownloadUtil;
@Controller
@RequestMapping("/images")
public class ImagesController {
	
	 @RequestMapping(value="/upload.do",produces = "text/html; charset=utf-8")
	 @ResponseBody
	 public void ImageUpload(HttpServletRequest request,@RequestParam("baseStr")String baseStr,HttpServletResponse response) {
		        response.setCharacterEncoding("UTF-8"); 
		 		System.out.println("baseStr:"+baseStr);
		 		String path = request.getSession().getServletContext().getRealPath("/images");		 		
		 		long fileName = System.currentTimeMillis();
		 		ImageDownloadUtil.decodeBase64ToImage(baseStr, path, String.valueOf(fileName));
		 	
	 }
		
}

上服务层代码:

package com.spring.util;


import java.io.File;
import java.io.FileOutputStream;

import cn.hutool.core.codec.Base64Decoder;

public class ImageDownloadUtil {

	 public static void decodeBase64ToImage(String base64,String path,String fileName) {
		 try {
			 System.out.println(path+File.separator+fileName);
			  FileOutputStream out = new FileOutputStream(path+File.separator+fileName+".png");
			  
			  byte[] decodeBytes = Base64Decoder.decode(base64);
			  out.write(decodeBytes);
			  out.flush();
			  out.close();
		 }catch (Exception e) {
			// TODO: handle exception
		}
	 }
}

现在我们谈谈我在中间遇到的错误

     首先呢,我是把canvas通过toDataURL("image/png")转换成base64编码制,然后直接通过Ajax把整个生成的字符串发送给后台,发现生成的图片呢(声明下,后端处理的代码没有任何问题);

后来,我在改的过程中吧toDataURL("image/png")输出下,发现他的格式是:



看到没,前面有个data:image/png;base64, 。我想啊,后天是处理base64编码的,但是好像前面不是吧,结果我把前面这段截掉了,果然生成的图片就对了。(代码已经给出了)

猜你喜欢

转载自blog.csdn.net/qq_37543808/article/details/88655052