base64格式的图片数据如何转成图片

news/2024/7/1 5:54:10

base64格式的图片数据如何转成图片

一、总结

一句话总结:不仅要去掉前面的格式串,还需要base64_decode()解码才行。

 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编码表

码值字符 码值字符 码值字符 码值字符
0A16Q32g48w
1B17R33h49x
2C18S34i50y
3D19T35j51z
4E20U36k520
5F21V37l531
6G22W38m542
7H23X39n553
8I24Y40o564
9J25Z41p575
10K26a42q586
11L27b43r597
12M28c44s608
13N29d45t619
14O30e46u62+
15P31f47v63/

 

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=”data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHgAAAB4CAMAAAAOus
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代码 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图片数据

 

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格式然后拿来测试)

  • 2.我们接收到之后需要进行一个简单的写入和存储操作。

  • 3.代码如下

// $base_img是获取到前端传递的值
$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,这样就搞定了。你可以将路径信息返回给前端使用。
参考:将base64数据流文件转换为图片文件 - CSDN博客
https://blog.csdn.net/gu_wen_jie/article/details/79050287

三、将图片转换base64格式,data:image/png;base64是什么?

一、我们在看代码时经常在img或css背景图片中看到:
src=”data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHgAAAB4CAMAAAAOus
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代码
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图片数据

三、js将图片转化为base64(2种方法)

  1. 利用canvas 将图片转化为base64 编码格式
var canvas = document.createElement("canvas");
var ctx = canvas.getContext('2d'),img = new Image;img.src="./vheider.jpg";//  img.setAttribute('crossOrigin', 'anonymous')  // 图片跨域时有用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 中

HTML

<input type="file" id="file"  multiple="multiple">
<div id="imgDiv"></div>       

JS

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) // 打印出转换后的 file 文件对象}  
}
参考:将图片转换base64格式,data:image/png;base64是什么? - CSDN博客
https://blog.csdn.net/webxiaoma/article/details/70053444

四、base64格式图片数据上传到服务器并转图片(测试成功)

1、截图

 

 

 

2、代码

ajax上传数据代码

$.post("index.php", { dataURL: dataURL},function(data){alert("Data Loaded: " + data);
});

 

后台php处理数据代码(我的数据格式是jpeg)

 1 <?php
 2 //print_r($_POST);
 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);
14   ?>

 

 

 


http://lihuaxi.xjx100.cn/news/236301.html

相关文章

自动化运维—saltstack

2019独角兽企业重金招聘Python工程师标准>>> 自动化运维——saltstack 、ansible 一、自动化运维介绍 传统运维&#xff1a;传统运维效率低&#xff0c;大多工作需要人工完成&#xff0c;工作繁琐&#xff0c;容易出错&#xff0c;每日重复做相同的事情&#xff0c;…

java简单的ID生成器

2019独角兽企业重金招聘Python工程师标准>>> https://www.cnblogs.com/hongdada/p/9324473.html https://github.com/apache/incubator-shardingsphere 转载于:https://my.oschina.net/u/3005325/blog/3006311

linux进行主机发现,linux – 网络上所有计算机的主机名发现

SSH不关心是否给出了要连接的主机名或IP地址(当有特定于主机的配置时,不确定是否适用).大多数MPI实现也不关心,例如在Open MPI连接中,URI地址都是数字,因此具有IP的主机文件可以正常使用.另一方面,HTTP服务器关心的是虚拟主机事件,其中许多不同站点解析为相同的IP地址,但服务器…

网站基于vs,复选框,单选款

前端代码&#xff1a; <% Page Language"C#" AutoEventWireup"true" CodeFile"Default2.aspx.cs" Inherits"Default2" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.or…

如何让你的回调更具Kotlin风味

简述: 这应该是2019年的第一篇文章了&#xff0c;临近过年回家一个月需求是真的很多&#xff0c;正如康少说的那样&#xff0c;一年的需求几乎都在最后一两月写完了。所以写文章也搁置了很久&#xff0c;当然再忙每天都会刷掘金。很久就一直在使用Kotlin写项目&#xff0c;说实…

linux blfs安装桌面,【Linux】Ubuntu14.04安装bridge-utils安装brctl

1、下载bridge-utils http://www.linuxfromscratch.org/blfs/view/svn/basicnet/bridge-utils.html2、放到/usr/src 目录下输入&#xff1a;su以root运行输入&#xff1a;cp /home/joanna/桌面/bridge-utils-1.5.tar.gz /usr/src/bridge-utils-1.5.tar.gzbridge-utils拷贝到/…

bzoj1227: [SDOI2009]虔诚的墓主人(树状数组,组合数)

传送门 首先&#xff0c;对于每一块墓地&#xff0c;如果上下左右各有$a,b,c,d$棵树&#xff0c;那么总的虔诚度就是$C_k^a*C_k^b*C_k^c*C_k^d$ 那么我们先把所有的点都给离散&#xff0c;然后按$x$为第一关键字&#xff0c;$y$为第二关键字&#xff0c;那么同一横坐标的一定在…

linux 源码安装浏览器,vps+linux+安装浏览器

弹性云服务器 ECS弹性云服务器(Elastic Cloud Server)是一种可随时自助获取、可弹性伸缩的云服务器&#xff0c;帮助用户打造可靠、安全、灵活、高效的应用环境&#xff0c;确保服务持久稳定运行&#xff0c;提升运维效率三年低至5折&#xff0c;多种配置可选了解详情什么是弹性…