java file转blob_base64,file和blob相互转换

本文介绍了五个JavaScript实用函数:Base64转Blob、Blob转Base64、Base64转File、图片转Base64,以及Java中文件和Base64之间的转换。这些技巧在处理前后端数据传输、文件上传和编码解码时非常实用。
摘要由CSDN通过智能技术生成

1.第一个:base64转为Blob

function dataURLtoBlob(dataurl) {

var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],

bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);

while (n--) {

u8arr[n] = bstr.charCodeAt(n);

}

return new Blob([u8arr], { type: mime });

}

2.第二个:Blob转为base64

function blobToDataURL(blob, callback) {

let a = new FileReader();

a.onload = function (e) { callback(e.target.result); }

a.readAsDataURL(blob);

}

3.第三个:base64转换为file

function dataURLtoFile(dataurl, filename) {//将base64转换为文件

var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],

bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);

while(n--){

u8arr[n] = bstr.charCodeAt(n);

}

return new File([u8arr], filename, {type:mime});

}

4.第四个:js图片转换为base64

function getImgToBase64(url,callback){//将图片转换为Base64

var canvas = document.createElement('canvas'),

ctx = canvas.getContext('2d'),

img = new Image;

img.crossOrigin = 'Anonymous';

img.onload = function(){

canvas.height = img.height;

canvas.width = img.width;

ctx.drawImage(img,0,0);

var dataURL = canvas.toDataURL('image/png');

callback(dataURL);

canvas = null;

};

img.src = url;

}

第五个:在Java中base64和File相互转换

/**

* 文件转base64字符串

* @param file

* @return

*/

public static String fileToBase64(File file) {

String base64 = null;

InputStream in = null;

try {

in = new FileInputStream(file);

byte[] bytes = new byte[in.available()];

int length = in.read(bytes);

base64 = Base64.encodeToString(bytes, 0, length, Base64.DEFAULT);

} catch (FileNotFoundException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} finally {

try {

if (in != null) {

in.close();

}

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

return base64;

}

/**

* base64字符串转文件

* @param base64

* @return

*/

public static File base64ToFile(String base64) {

File file = null;

String fileName = "/Petssions/record/testFile.amr";

FileOutputStream out = null;

try {

// 解码,然后将字节转换为文件

file = new File(Environment.getExternalStorageDirectory(), fileName);

if (!file.exists())

file.createNewFile();

byte[] bytes = Base64.decode(base64, Base64.DEFAULT);// 将字符串转换为byte数组

ByteArrayInputStream in = new ByteArrayInputStream(bytes);

byte[] buffer = new byte[1024];

out = new FileOutputStream(file);

int bytesum = 0;

int byteread = 0;

while ((byteread = in.read(buffer)) != -1) {

bytesum += byteread;

out.write(buffer, 0, byteread); // 文件写操作

}

} catch (IOException ioe) {

ioe.printStackTrace();

} finally {

try {

if (out!= null) {

out.close();

}

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

return file;

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中的BlobFileBase64都是处理文件或数据的常用对象。下面将介绍它们的使用场景以及相互之间的转换Blob对象用于表示不能被修改的类文件数据,并且可以在被发送到服务器之前进行处理。它可用于在网页上生成和下载文件,比如将网页上的图片存储为Blob对象,然后使用URL.createObjectURL()方法将其显示为图像。此外,Blob对象也可以用于通过XMLHttpRequest或Fetch API将数据发送到服务器。 File对象继承自Blob对象,它是用户在表单中选择的文件的表示形式。File对象可以包含文件的名称、大小、类型以及最后修改日期等信息。在上传文件时,我们通常会使用File对象来获取文件的详细信息并进行验证。 Base64是一种将二进制数据编码为ASCII字符的方式,常用于在文本传输中表示二进制数据。我们可以使用JavaScript的btoa()和atob()函数在Base64字符串和二进制数据之间进行相互转换。 在相互转换方面,可以将Blob对象转换Base64字符串,然后使用toDataURL()方法将其转换为DataURL,或者使用FileReader对象的readAsDataURL()方法将BlobFile对象转换为DataURL。而将Base64字符串转换Blob对象,则可以使用Blob构造函数并设置正确的MIME类型。 综上所述,Blob对象适用于处理类文件数据和发送到服务器,File对象适用于处理用户上传的文件,而Base64适用于在文本传输中表示二进制数据。根据具体的应用场景和需求,我们可以进行这三种对象之间的相互转换
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值