Base64轉(zhuǎn)MultipartFile實(shí)現(xiàn)

前記:上傳圖片文件,我要求的方式是前端使用最簡(jiǎn)單的multipart/form-data,后臺(tái)使用的是MultipartFile[]的方式接收,但是前端小哥用MUI一直發(fā)送失敗,改用base64的方式發(fā)送。后端接收base64字符串后,裝換成MultipartFile的方式,然后用Thumbnails對(duì)圖片進(jìn)行修改。


1.直接上代碼吧!

解析Base64

package com.itkim.util;

import org.springframework.web.multipart.MultipartFile;
import sun.misc.BASE64Decoder;

import java.io.IOException;

/**
 * @description: 傳入圖片的base64
 * @author: KimJun
 * @date: 18/11/13 00:25
 */
public class base64ToMultipart {
    public static MultipartFile base64ToMultipart(String base64) {
        try {
            String[] baseStrs = base64.split(",");

            BASE64Decoder decoder = new BASE64Decoder();
            byte[] b = new byte[0];
            b = decoder.decodeBuffer(baseStrs[1]);

            for(int i = 0; i < b.length; ++i) {
                if (b[i] < 0) {
                    b[i] += 256;
                }
            }
            return new BASE64DecodedMultipartFile(b, baseStrs[0]);
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
  
    //測(cè)試
    public static void main(String[] args) {
        MultipartFile multipartFiles[] = new MultipartFile[2];
        multipartFiles[0] = base64ToMultipart.base64ToMultipart("");
        System.out.println(multipartFiles[0].getSize());
        
    }
}
package com.itkim.util;

import org.springframework.web.multipart.MultipartFile;

import java.io.*;

/**
 * @description: TODO
 * @author: KimJun
 * @date: 18/11/12 23:37
 */

public class BASE64DecodedMultipartFile implements MultipartFile {

    private final byte[] imgContent;
    private final String header;

    public BASE64DecodedMultipartFile(byte[] imgContent, String header) {
        this.imgContent = imgContent;
        this.header = header.split(";")[0];
    }

    @Override
    public String getName() {
        // TODO - implementation depends on your requirements
        return System.currentTimeMillis() + Math.random() + "." + header.split("/")[1];
    }

    @Override
    public String getOriginalFilename() {
        // TODO - implementation depends on your requirements
        return System.currentTimeMillis() + (int)Math.random() * 10000 + "." + header.split("/")[1];
    }

    @Override
    public String getContentType() {
        // TODO - implementation depends on your requirements
        return header.split(":")[1];
    }

    @Override
    public boolean isEmpty() {
        return imgContent == null || imgContent.length == 0;
    }

    @Override
    public long getSize() {
        return imgContent.length;
    }

    @Override
    public byte[] getBytes() throws IOException {
        return imgContent;
    }

    @Override
    public InputStream getInputStream() throws IOException {
        return new ByteArrayInputStream(imgContent);
    }

    @Override
    public void transferTo(File dest) throws IOException, IllegalStateException {
        new FileOutputStream(dest).write(imgContent);
    }I
}

2.圖片的實(shí)體類(補(bǔ)上實(shí)體類)

package com.itkim.entity;

/**
 * @description: TODO
 * @author: KimJun
 * @date: 18/11/12 22:20
 */
public class Pic {
    //圖片的id 第幾張。
    private String picNum;

    //圖片的Base64編碼
    private String picString;

    public String getPicNum() {
        return picNum;
    }

    public String getPicString() {
        return picString;
    }

    @Override
    public String toString() {
        return "Pic{" +
                "picNum='" + picNum + '\'' +
                ", picString='" + picString + '\'' +
                '}';
    }
}

3.前端測(cè)試代碼(需要jQuery)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./jquery-3.3.1.min.js"></script>
</head>
<body>

請(qǐng)輸入圖片的Base64碼 1--<input name="data1" style="width: 400px"><br>
請(qǐng)輸入圖片的Base64碼 2--<input name="data2" style="width: 400px"><br>
<button id="submit" onclick="btnAction()">點(diǎn)擊發(fā)送請(qǐng)求</button>
<script type="text/javascript">
    function btnAction() {

        var pictureFiles=[];
        var data1={"picNum":"0","picString": $("*[name='data1']").val()};
        var data2={"picNum":"1","picString": $("*[name='data2']").val()};
        pictureFiles.push(data1);
        pictureFiles.push(data2);
        $.ajax({
            type:"POST",
            url:"http://localhost:8080/user/additem",
            dataType:"json",
            contentType:"application/json",
            data:JSON.stringify(pictureFiles),
            success:function(data){
                console.log("成功上傳。。。。");
            }
        });
    };

</script>
</body>
</html>

4.Controller接收

@RequestMapping(value = "additem", method = RequestMethod.POST)  
@ResponseBody
public Msg multipartFileUpload(@RequestBody List<Pic> pictureFiles) throws IOException {
    System.out.println(pictureFiles.toString());
    System.out.println(pictureFiles.size());
    //如果圖片的長(zhǎng)度、大于8則拋異常
    if (pictureFiles.size() > 8) {
        return Msg.fail("上傳失敗,圖片的張數(shù)大于8");
    } else {
        //新建一個(gè)數(shù)組接收保存
        MultipartFile[] pictureFile = new MultipartFile[pictureFiles.size()];
        for (int i = 0; i < pictureFiles.size(); i++) {
            String ImgBase = pictureFiles.get(i).getPicString();
            System.out.println(ImgBase);
            if (!ImgBase.equals(null)) {
                pictureFile[i] = base64ToMultipart.base64ToMultipart(ImgBase);
            } else {
                break;
            }
        }
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容