您的位置:首页 > Web前端 > JavaScript

H5、js、上传头像将图片转换成base64格式的:data:image/png;base64,iVBORw0

2017-12-28 16:36 776 查看
$("#img_upload_file").change(function() {
varoFile = this.files[0];
console.log("oFile")
console.log(oFile)
varreader = newFileReader();
reader.readAsDataURL(oFile);//调用自带方法进行转换
reader.onload =function(e) {
$("#img_upload_show").attr("src",this.result);//将转换后的编码存入src完成预览
varrFilter = /^(image\/bmp|image\/gif|image\/jpeg|image\/png|image\/tiff)$/i;
if(!rFilter.test(oFile.type)) {
alert("文件格式必须为图片");
return;
}
if(oFile.size >iMaxFilesize) {
alert("图片大小不能超过2M");
return;
}
console.log(this.result)
userTk =xx;
varuserPhoto = this.result;
updatePhoto(userId,userTk,userPhoto);
//$("#img_upload_base").val(this.result); //将转换后的编码保存到input供后台使用
};

});


this.result的结果是:data:image/png;base64,iVBORw0KGgoAAAAxxxxxxxxxxxxxxxxxx.....,
=》

var userPhoto =this.result.split(",");截取分割即可

data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAkAAAAJAQMAAADaX5RTAAAAA3NCSVQICAjb4U/gAAAABlBMVEX///+ZmZmOUEqyAAAAAnRSTlMA/1uRIrUAAAAJcEhZcwAACusAAArrAYKLDVoAAAAWdEVYdENyZWF0aW9uIFRpbWUAMDkvMjAvMTIGkKG+AAAAHHRFWHRTb2Z0d2FyZQBBZG9iZSBGaXJld29ya3MgQ1M26LyyjAAAAB1JREFUCJljONjA8LiBoZyBwY6BQQZMAtlAkYMNAF1fBs/zPvcnAAAAAElFTkSuQmCC


那么这是什么呢?这是Data URI scheme。
Data URI scheme是在RFC2397中定义的,目的是将一些小的数据,直接嵌入到网页中,从而不用再从外部文件载入。比如上面那串字符,其实是一张小图片,将这些字符复制黏贴到火狐的地址栏中并转到,就能看到它了,一张1X36的白灰png图片。
在上面的Data URI中,data表示取得数据的协定名称,image/png 是数据类型名称,base64 是数据的编码方法,逗号后面就是这个image/png文件base64编码后的数据。

 

目前,Data URI scheme支持的类型有:
data:,文本数据
data:text/plain,文本数据
data:text/html,HTML代码
data:text/html;base64,base64编码的HTML代码
data:text/css,CSS代码
data:text/css;base64,base64编码的CSS代码
data:text/javascript,Javascript代码
data:text/javascript;base64,base64编码的Javascript代码
data:image/gif;base64,base64编码的gif图片数据
data:image/png;base64,base64编码的png图片数据
data:image/jpeg;base64,base64编码的jpeg图片数据
data:image/x-icon;base64,base64编码的icon图片数据

参考:https://www.cnblogs.com/xcsn/p/4677373.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: