后端是如何存储图片的呢?

  1. 将图片以独立文件的形式存储在服务器的文件夹中,再将该文件路径存入数据库中.
  2. 将图片转化为二进制流,直接存储到数据库的Image类型字段中.

第一种方式存储,则前端可以直接将存储路径赋值给src属性显示图片.
第二种方式存储,则前端得到的是二进制流数据,需将二进制流交由blob对象处理,然后通过blob的API生成临时的URL赋值给src属性来显示图片.

个人认为第一种方式存储更好,一张图片有几M,则大量图片存储在数据库中,则会影响数据库的性能。

第二种方式生成临时URL代码如下:

createURL(blob){ let img=document.createElement('img'); img.onload=function(e){//img的onload事件销毁URLwindow.URL.revokeObjectURL(img.src);
}img.src=window.URL.createObjectURL(blob)//根据blob二进制流数据生成临时URL,且URL以blob开头  document.querySelector('.haha').appendChild(img);
}

假设服务端接口只接收url、base64、blob中的一种格式的图片数据,然而前端得到的图片对象与服务端格式不同,那前端js如何使其转换为相对应的格式呢?

图片的三种格式转换图:

1.url转化base64

//转化原理:利用canvas.toDataURL的API转化成base64urlGetBase64(url){   return new Promise((resolve,reject)=>{   let image=new Image();    image.onload=function(){    let canvas=document.createElement('canvas');    canvas.width=100;     canvas.height=100;   canvas.getContext('2d').drawImage(image,0,0);     let result=canvas.toDataURL('image/png');    resolve(result);   };   image.setAttribute("crossOrigin",'Anonymous');     image.src=url;    image.onerror=()=>{    reject(new Error('图片流异常'));   };   }) }

调用方法:

let imgUrl=`http://aaa.jpg`;this.urlGetBase64(imgUrl).then(res=>{console.log('url转化为base64格式:',res);
})

举例子:在网上找到一张url格式的图片

https://t9.baidu.com/it/u=1761131378,1355750940&fm=79&app=86&size=h300&n=0&g=4n&f=jpeg?sec=1584854630&t=a9403a3590083ce60f15eacf1ffa589e

在vscode运行如下代码:

export class ShowImageComponent implements OnInit {imgData:any="https://t9.baidu.com/it/u=1761131378,1355750940&fm=79&app=86&size=h300&n=0&g=4n&f=jpeg?sec=1584854630&t=a9403a3590083ce60f15eacf1ffa589e"constructor() { }ngOnInit(): void {this.urlGetBase64(this.imgData).then(res=>{this.imgData=res;console.log("图片的base64格式:",res);})}urlGetBase64(url){   return new Promise((resolve,reject)=>{   let image=new Image();    image.onload=function(){    let canvas=document.createElement('canvas');    canvas.width=200;     canvas.height=300;   canvas.getContext('2d').drawImage(image,0,0);     let result=canvas.toDataURL('image/png');    resolve(result);   };   image.setAttribute("crossOrigin",'Anonymous');     image.src=url;    image.onerror=()=>{    reject(new Error('图片流异常'));   };   }) }
}

运行效果+控制台打印并查看base64格式数据

2.base64转换blob

base64GetBlob({base64Data='',contentType='',sliceSize=512}={}){ return new Promise((resolve,reject)=>{   let byteChar=atob(base64Data);    let byteArray=[];   for(let index=0;index<byteChar.length;index+=sliceSize){    let slice=byteChar.slice(index,index+sliceSize);  let byteNumber=[];    for(let i=0;i<slice.length;i++){   byteNumber.push(slice.charCodeAt(i));    }     byteArray.push(new Uint8Array(byteNumber));  }    let result=new Blob(byteArray,{     type:contentType  })    result=Object.assign(result,{   preview:URL.createObjectURL(result),    name:`示例.png`  });resolve(result); })}

调用方法:

let base64=base64.split(',')[1];this.base64GetBlob({base64Data:base64,contentType:'image/png'}).then(res=>{console.log('base64转化为blob格式:',res);
})

举例子:在网上找到一张base64格式的图片

"";

在vscode运行代码:

export class ShowImageComponent implements OnInit {constructor() { }ngOnInit(): void {let base64=this.imgData.split(',')[1];this.base64GetBlob({base64Data:base64,contentType:'image/png'}).then(res=>{console.log('base64转化为blob格式:',res);})}imgData:any="";base64GetBlob({base64Data='',contentType='',sliceSize=512}={}){return new Promise((resolve,reject)=>{   let byteChar=atob(base64Data);    let byteArray=[];   for(let index=0;index<byteChar.length;index+=sliceSize){    let slice=byteChar.slice(index,index+sliceSize);  let byteNumber=[];    for(let i=0;i<slice.length;i++){   byteNumber.push(slice.charCodeAt(i));    }     byteArray.push(new Uint8Array(byteNumber));  }    let result=new Blob(byteArray,{     type:contentType  })    result=Object.assign(result,{   preview:URL.createObjectURL(result),    name:`示例.png`  });resolve(result);})}
}

运行效果+控制台打印并查看blob格式数据

3.blob转换base64:

blobGetBase64(blob){ return new Promise((resolve,reject)=>{   const fileReader=new FileReader();   fileReader.onload=(e)=>{     resolve(e.target.result);   };   fileReader.readAsDataURL(blob);   fileReader.onerror=()=>{     reject(new Error('文件流异常'));   }; });}

调用方法:

this.blobGetBase64(blob).then(res=>{console.log('blob转化为base64格式',res)
})

base64:适合场景是小图片,在多处需要用到该图片时可用

图片获取、格式转换与后台存储相关推荐

  1. docx文档怎么排列图片_格式转换太麻烦?仅需一行命令,搞定图片、音频、视频、文本批量转换!...

    每天12:18准时给大家惊喜! 大家好!我是好奇仔,热衷于搜罗和分享各种好用.实用的软件神器和资源,有手机软件.办公软件.APP,还有网站资源-- 来自:芒种学院(ID:lazy_info)  作者: ...

  2. Python3 Image图片webp格式转换,URL Image Byte字节流操作

    前言 首先图片格式转换的方法有很多,但是转图片字节流的,我搜了一下午终于在 stackoverflow上搜到了 说一下为什么要在线转这个图片格式 图片不需要下载到本地,爬取到图片url后,读取图片字节 ...

  3. FFmpeg 使用命令整理 – 提取音频或视频、提取图片、格式转换等

    提取声音的软件网上搜索有不少,不过最有名最专业的似乎是一个命令行工具:ffmpeg.这个工具功能十分丰富且强大,我所需要的从视频中提取 mp3 的功能只是其中包含的一个.感觉使用起来很复杂因为是命令行 ...

  4. 【FFmpeg 命令】提取音频或视频、提取图片、格式转换等

    文章目录 1. FFmpeg 简介 2. 组件组成 3. 命令参数 3.1 主要参数 3.2 影像参数 4. 实战使用 4.1 格式转换 (将file.avi 转换成output.flv) 4.2 合 ...

  5. 图片怎么格式转换成jpg?介绍几种思路

    在现代数字世界中,图片格式转换是一项非常重要的技能.不同的图片格式适合不同的用途,例如PNG格式适合用于图像透明处理,而JPG格式则适合用于图像压缩和共享.本文将介绍如何将不同格式的图片转换为JPG, ...

  6. 用python实现批量图片的格式转换

    最近在处理数据集的时候参考了别人的代码,用python对图片的格式进行了转换,代码如下: import os from PIL import Image oldpath ='D:\BaiduNetdi ...

  7. python opencv图片读入格式转换

    opencv中提供了图片格式转换的方法,主要是采用cv2.cvtColor函数. 方法如下: import cv2output1=cv2.imread('D:/super_reslution/SRCN ...

  8. python工具包读取图片及格式转换

    关于python怎么读取文件,一直没搞清楚,最近使用tensorboard,搞明白了 1导包和设置图片位置 from PIL import Image from torch.utils.tensorb ...

  9. python图片压缩/格式转换

    前言 昨晚终于把红底换成蓝底了,刚想着兴高采烈地去提交,结果发现201KB交不了- 学院要求(60KB~200KB), 我人傻了,看了一下wps, 啊充钱才可以. 压缩图片 # 代码参考自 https ...

最新文章

  1. 用Python解“龟兔赛跑”题
  2. 现有exe转为服务_方式01
  3. 核显也能玩游戏,OS X Yosemite优化指南
  4. delphi 实现屏幕旋转代码_X86指令混淆之函数分析和代码块粉碎
  5. 网易云信12月大事记
  6. Apache Ant 1.10.6发布–用于junitlauncher的fork模式以及新的jmod和链接任务
  7. 1090. Highest Price in Supply Chain (25) dfs
  8. Java高级面试题!这是一份面向Java开发者的复习指南
  9. MySQL教程(十二)—— 数据的导入与导出
  10. java怎么把照片导出来,JAVA将图片转成base64导出到word中
  11. python2.4无线模块_使用nRF24L01模块进行无线射频通信
  12. Android SoundPool循环播放
  13. Sibelius for Mac 8.2.0 谱曲软件 中文破解版下载
  14. nginx or apache前端禁收录,爬虫,抓取
  15. 动态 Probit 模型及 Stata 实现
  16. 我与AWS Proserve团队的故事
  17. 电脑插上耳机没声音 解决方法
  18. mysql8.0.21官网安装步骤_MySQL8.0.21安装步骤及出现问题解决方案
  19. Spring入门示例
  20. IBM Cloud 2015 - Invoice - 06 账期 Credit term, payment days, Net 30 days terms

热门文章

  1. LKD:定时器和时间管理
  2. (LKD3读书记录)-Chap3:进程管理
  3. 第十六篇 Computed 计算属性的应用
  4. 播音学习如何找到适合自己的稿件,播音稿件推荐
  5. 百度云盘下载慢怎么解决?百度云盘svip账号
  6. 【零基础学机器学习 1】什么是机器学习?
  7. 微信小程序 各类效果(视频)
  8. LabVIEW数据采集:配套视频教程第2集(2.1.1节-2.1.13节)
  9. 南明区以大数据为引领培育发展新动能
  10. 12306 点触验证