图片获取、格式转换与后台存储

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

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

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

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

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

createURL(blob){ 
   let img=document.createElement('img'); 
   img.onload=function(e){//img的onload事件销毁URL
   window.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转化成base64
    urlGetBase64(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:适合场景是小图片,在多处需要用到该图片时可用

猜你喜欢

转载自blog.csdn.net/weixin_43334673/article/details/104864796
今日推荐