JPG PDF都适用
代码我忘了是在哪篇博客上抄的了,自己只是稍做了调整,话不多说上代码
Base64Util
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Base64;
import java.util.Base64.Decoder;
import java.util.Base64.Encoder;
public class Base64Util {
/**
* 将base64编码转换成文件
* */
public static void base64StringToFile(String base64sString, String filePath) {
BufferedInputStream bin = null;
FileOutputStream fout = null;
BufferedOutputStream bout = null;
try {
// 将base64编码的字符串解码成字节数组
// BASE64Decoder decoder = new BASE64Decoder();
Decoder decoder = Base64.getDecoder();
byte[] bytes = decoder.decode(base64sString);
// 创建一个将bytes作为其缓冲区的ByteArrayInputStream对象
ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
// 创建从底层输入流中读取数据的缓冲输入流对象
bin = new BufferedInputStream(bais);
// 指定输出的文件
File file = new File(filePath);
// 创建到指定文件的输出流
fout = new FileOutputStream(file);
// 为文件输出流对接缓冲输出流对象
bout = new BufferedOutputStream(fout);
byte[] buffers = new byte[1024];
int len = bin.read(buffers);
while (len != -1) {
bout.write(buffers, 0, len);
len = bin.read(buffers);
}
// 刷新此输出流并强制写出所有缓冲的输出字节,必须这行代码,否则有可能有问题
bout.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
bin.close();
fout.close();
bout.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 将文件转换成base64编码
* */
public static String getFileBinary(File file) {
FileInputStream fin =null;
BufferedInputStream bin =null;
ByteArrayOutputStream baos = null;
BufferedOutputStream bout =null;
// BASE64Encoder encoder = new BASE64Encoder();
Encoder encoder = Base64.getEncoder();
try {
//建立读取文件的文件输出流
fin = new FileInputStream(file);
//在文件输出流上安装节点流(更大效率读取)
bin = new BufferedInputStream(fin);
// 创建一个新的 byte 数组输出流,它具有指定大小的缓冲区容量
baos = new ByteArrayOutputStream();
//创建一个新的缓冲输出流,以将数据写入指定的底层输出流
bout = new BufferedOutputStream(baos);
byte[] buffer = new byte[1024];
int len = bin.read(buffer);
while(len != -1){
bout.write(buffer, 0, len);
len = bin.read(buffer);
}
//刷新此输出流并强制写出所有缓冲的输出字节,必须这行代码,否则有可能有问题
bout.flush();
byte[] bytes = baos.toByteArray();
//sun公司的API
return encoder.encodeToString(bytes).trim();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
fin.close();
bin.close();
bout.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return null;
}
}
刚刚有个大佬私信我说图片转base64格式有点小bug,怎么说呢,因为前端后台都是我自己写的,前端我在传图片base64的时候就做了字符串截取的,所以没有发现这个问题。大佬也挺好的把修正后的代码也发给我了,我在这里感谢大佬了。
public static void base64StringToFile(String base64sString, String filePath) {
String base64sString1 = base64sString.replaceAll(" ", "+");
String base64sString2 = "";
if (image.contains("png")) {
base64sString2 = base64sString1.replace("data:image/png;base64,", "");
}
if (image.contains("jpg")) {
base64sString2 = base64sString1.replace("data:image/jpg;base64,", "");
}
if (image.contains("jpeg")) {
base64sString2 = base64sString1.replace("data:image/jpeg;base64,", "");
}
String base64sString3 = base64sString2.replace("base64,", "");
BufferedInputStream bin = null;
FileOutputStream fout = null;
BufferedOutputStream bout = null;
try {
// 将base64编码的字符串解码成字节数组
// BASE64Decoder decoder = new BASE64Decoder();
Decoder decoder = Base64.getDecoder();
byte[] bytes = decoder.decode(base64sString3);
// 创建一个将bytes作为其缓冲区的ByteArrayInputStream对象
ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
// 创建从底层输入流中读取数据的缓冲输入流对象
bin = new BufferedInputStream(bais);
// 指定输出的文件
File file = new File(filePath);
// 创建到指定文件的输出流
fout = new FileOutputStream(file);
// 为文件输出流对接缓冲输出流对象
bout = new BufferedOutputStream(fout);
byte[] buffers = new byte[1024];
int len = bin.read(buffers);
while (len != -1) {
bout.write(buffers, 0, len);
len = bin.read(buffers);
}
// 刷新此输出流并强制写出所有缓冲的输出字节,必须这行代码,否则有可能有问题
bout.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
bin.close();
fout.close();
bout.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}