1 // $base_img是获取到前端传递的值
2 $base_img = str_replace('data:image/jpg;base64,', '', $base_img);
3 // 设置文件路径和命名文件名称
4 $path = "./";
5 $output_file = $prefix.time().rand(100,999).'.jpg';
6 $path = $path.$output_file;
7 // 创建将数据流文件写入我们创建的文件内容中
8 file_put_contents($path, base64_decode($base_img));
9 // 输出文件
10 print_r($output_file);
1、base64编码表是怎样的?
Base64编码表
码值字符
码值字符
码值字符
码值字符
Base64编码说明
Base64编码要求把3个8位字节(3*8=24)转化为4个6位的字节(4*6=24),之后在6位的前面补两个0,形成8位一个字节的形式。 如果剩下的字符不足3个字节,则用0填充,输出字符使用'=',
因此编码后输出的文本末尾可能会出现1或2个'='。
为了保证所输出的编码位可读字符,Base64制定了一个编码表,以便进行统一转换。编码表的大小为2^6=64,这也是Base64名称的由来。
2、base64可以做图片src属性的地址么?
src=”
bgAAAAeFBMVEUAwAD///+U5ZTc9twOww7G8MYwzDCH4==”
src或 url() 中有一大串编码。它把一些 8-bit 数据翻译成标准 ASCII 字符,网上有很多免费的base64 编码和解码的工具,
后面跟的一串代码就相当于链接地址。
3、
Data URL 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代码
编码的gif图片数据
编码的png图片数据
编码的jpeg图片数据
编码的icon图片数据
4、将图片转化为base64格式的方法?
a、利用
canvas 将图片转化为base64 编码格式
dataURL =canvas.toDataURL("image/jpeg");
b、利用 html5 的
FileReader 将图片转化base64格式
FileReader 是H5提供的一个处理文件的API,
var reader=new FileReader();
reader.readAsBinaryString(file);
二、将base64数据流文件转换为图片文件
转自或参考: https://blog.csdn.net/gu_wen_jie/article/details/79050287
前后端交互处理图片的时候,会出现这样的情况:
前端传递给我们后端的是base64的图片数据流,我们需要做的就是将它转为图片并且保存起来,根据需要再决定是否将图片存储路径信息返回给前端。
下面就来说一下这个怎么处理,其实很简单,就是一个转码存储的过程。
1.假设现在前端将数据流传过来了(这个地方你可以自己用在线工具将本地的某张图片转码为base64格式然后拿来测试)
$base_img = str_replace('data:image/jpg;base64,', '', $base_img);
$path = "./";
$output_file = $prefix.time().rand(100,999).'.jpg';
$path = $path.$output_file;
file_put_contents($path, base64_decode($base_img));
print_r($output_file);
4.ok,这样就搞定了。你可以将路径信息返回给前端使用。
一、我们在看代码时经常在img或css背景图片中看到:
src=”
bgAAAAeFBMVEUAwAD///+U5ZTc9twOww7G8MYwzDCH4==”
src或 url() 中有一大串编码。它把一些 8-bit 数据翻译成标准 ASCII 字符,网上有很多免费的base64 编码和解码的工具,
后面跟的一串代码就相当于链接地址
。
二、目前,Data URL 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代码
编码的gif图片数据
编码的png图片数据
编码的jpeg图片数据
编码的icon图片数据
三、js将图片转化为base64(2种方法)
利用
canvas 将图片转化为base64 编码
格式
var canvas = document.createElement("canvas");
var ctx = canvas.getContext('2d'),
img = new Image;
img.src="./vheider.jpg";
img.onload = function(){
canvas.height = img.height;
canvas.width = img.width;
ctx.drawImage(img,0,0);
dataURL =canvas.toDataURL("image/jpeg");
$('#img').attr('src', dataURL);
console.log(canvas.toDataURL("image/jpeg"))
注意: 这里要在服务端打开,不然浏览器可能会报 index.html:41 Uncaught SecurityError: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.
错误
2 . 利用 html5 的 FileReader 将图片转化base64格式
FileReader 是H5提供的一个处理文件的API,
① 判断浏览器是否支持FileReader
if(window.FileReader){
}else{
return "浏览器不支持FileRedaer"
② FileReader 接口有四个方法:
readAsBinaryString (file) 将文件读取为二进制码
readAsDataURL (file) 将文件读取为 DataURL
readAsText (file,encoding) 将文件读取为文本(第二个参数是编码格式,一般默认是UTF-8)
about 中断读取
③ FileReader还提供给了一些事件:
onabort 中断时触发
onerror 出错时触发
onload 文件读取成功完成时触发
onloadend 读取完成触发,无论成功或失败
onloadstart 读取开始时触发
onprogress 读取中
FileReader 读取后的文件不会返回给FileReader 本身, 而是存储在了 result 中
<input type="file" id="file" multiple="multiple">
<div id="imgDiv"></div>
var result = document.getElementById("result");
var file = document.getElementById("file");
file.change=function(){
var file = file.files[0]
var reader=new FileReader();
reader.readAsBinaryString(file);
reader.onload=function (e){
imgDiv.innerHTML='<img src="'+this.result+'" alt=""/>'
console.log(this)
参考:将图片转换base64格式,data:image/png;base64是什么? - CSDN博客
https://blog.csdn.net/webxiaoma/article/details/70053444
四、base64格式图片数据上传到服务器并转图片(测试成功)
3 $base_img=$_POST['dataURL'];
4 // $base_img是获取到前端传递的值
5 $base_img = str_replace('data:image/jpeg;base64,', '', $base_img);
6 // 设置文件路径和命名文件名称
7 $path = "./";
8 $output_file = time().rand(100,999).'.jpeg';
9 $path = $path.$output_file;
10 // 创建将数据流文件写入我们创建的文件内容中
11 file_put_contents($path, base64_decode($base_img));
12 // 输出文件
13 print_r($output_file);
我的旨在学过的东西不再忘记(主要使用艾宾浩斯遗忘曲线算法及其它智能学习复习算法)的偏公益性质的完全免费的编程视频学习网站:
【读书编程笔记】fanrenyi.com;有各种前端、后端、算法、大数据、人工智能等课程。
版权申明:欢迎转载,但请注明出处
一些博文中有一些参考内容因时间久远找不到来源了没有注明,如果侵权请联系我删除。
在校每年国奖、专业第一,加拿大留学,先后工作于华东师范大学和香港教育大学。
2024-09-05:27岁,宅加太忙,特此在网上找女朋友,vx:fan404006308
录播课资料github地址:https://github.com/fry404006308/fry_course_materials