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

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


		你的浏览器不支持Canvas
	
	点击下载
	
	

上控制层代码:

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把整个生成的字符串发送给后台,发现生成的图片呢(声明下,后端处理的代码没有任何问题);

谈canvas转图片的方法(base64编码)_第1张图片

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



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

谈canvas转图片的方法(base64编码)_第2张图片

你可能感兴趣的:(java,spring,decode)