图片使用base64图片数据格式上传(后台使用springMVC)

一、前台JSP页面

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
<c:set var="ctx" value="${pageContext.request.contextPath}" />
<!DOCTYPE html>
<html>    
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
	<title>文件上传</title>
	<script type="text/javascript"  src="${ctx}/js/jquery-2.1.4/jquery-2.1.4.js"></script>	
	<script type="text/javascript">

    //通过FileReader.readAsDataURL获取base64数据
    function uploadFile(file){
        var f = document.getElementById("myImage").files[0];
        var reader = new FileReader(); //新建一个FileReader
        reader.readAsDataURL(f);  // 读取文件base64数据
        reader.onload = function(e){ //数据读取完成产生onload事件
            var data = e.target.result; //获取数据
            if (data.lastIndexOf('data:base64') != -1) {
                  data = data.replace('data:base64', 'data:image/jpeg;base64');
            } else if (data.lastIndexOf('data:,') != -1) {
                  data = data.replace('data:,', 'data:image/jpeg;base64,');
            }

            if(isCanvasSupported()){
                 ajaxUploadBase64File(data);
            }else{
                 alert("您的浏览器不支持");
            }

        };

        reader.onerror = function(){
            console.log("上传失败了 ");
        }

        
    }

    //ajax异步上传
    function ajaxUploadBase64File(base64Data){
        var url = "${ctx}/upload/uploadBase64";
        $.ajax({
            url:url,
            type:"post",
            data:{base64Data:base64Data},
            success:function(data){
                if(data == "success"){
                   alert("上传成功");
                }else{
                    alert("上传失败");
                }
            },
            error:function(){
                alert("上传失败");
            }
        });
    }; 


    //是否支持canvas
    function isCanvasSupported(){
        var elem = document.createElement('canvas');
        return !!(elem.getContext && elem.getContext('2d'));
    };
	   
	</script>

</head>

<body>
    <input type="file" id="myImage" name="myImage"/> 
    <input type="button" οnclick="uploadFile();" value="上传">
</body>
</html>



二、后台Controller

package org.nercita.bcp.upload;

import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.UUID;

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

import org.apache.commons.io.FileUtils;
import org.springframework.stereotype.Controller;
import org.springframework.util.Base64Utils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.commons.CommonsMultipartFile;

@Controller
public class UploadController {	

    @RequestMapping("/upload/uploadImage")
    public String uploadImagePage(){
	return "/upload/uploadImage";
    }
	
	
    @RequestMapping(value="/upload/uploadBase64",method=RequestMethod.POST)
    @ResponseBody
    public String base64UpLoad(@RequestParam String base64Data, HttpServletRequest request, HttpServletResponse response){  	       
        try{  	           
            String dataPrix = "";
            String data = "";	       
            if(base64Data == null || "".equals(base64Data)){
                throw new Exception("上传失败,上传图片数据为空");
            }else{
                String [] d = base64Data.split("base64,");
                if(d != null && d.length == 2){
                    dataPrix = d[0];
                    data = d[1];
                }else{
                    throw new Exception("上传失败,数据不合法");
                }
            }	          
            String suffix = "";
            if("data:image/jpeg;".equalsIgnoreCase(dataPrix)){//data:image/jpeg;base64,base64编码的jpeg图片数据
                suffix = ".jpg";
            } else if("data:image/x-icon;".equalsIgnoreCase(dataPrix)){//data:image/x-icon;base64,base64编码的icon图片数据
                suffix = ".ico";
            } else if("data:image/gif;".equalsIgnoreCase(dataPrix)){//data:image/gif;base64,base64编码的gif图片数据
                suffix = ".gif";
            } else if("data:image/png;".equalsIgnoreCase(dataPrix)){//data:image/png;base64,base64编码的png图片数据
                suffix = ".png";
            }else{
                throw new Exception("上传图片格式不合法");
            }
            String tempFileName = UUID.randomUUID().toString() + suffix;	            

            //因为BASE64Decoder的jar问题,此处使用spring框架提供的工具包
            byte[] bs = Base64Utils.decodeFromString(data);
            try{
                //使用apache提供的工具类操作流
            	
            	System.out.println(request.getServletContext().getRealPath("/upload"));
                FileUtils.writeByteArrayToFile(new File(request.getServletContext().getRealPath("/upload"), tempFileName), bs);  
            }catch(Exception ee){
                throw new Exception("上传失败,写入文件失败,"+ee.getMessage());
            }	           	          
            return "success";	           
        }catch (Exception e) {  	          
            return "error";
        }  	     
    }	
}

        本文使用的是FileRead的readAsDataURL获取base64的图片编码数据,通常我们 使用canvas画布在html的dom元素中所绘的图行,也可以使用 canvas的toDataUrl转换成base64编码的图片数据进行上传,具体获取方式如下:

 var mycanvas = document.getElementById("mycanvas");  
 var imageBase64Data  = mycanvas.toDataURL("image/png");  




评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值