图片的base64编码就是可以将一副图片数据编码成一串字符串,使用该字符串代替图像地址。
这样做有什么意义呢?我们知道,我们所看到的网页上的每一个图片,都是需要消耗一个 http 请求下载而来的。
没错,不管如何,图片的下载始终都要向服务器发出请求,要是图片的下载不用向服务器发出请求,而可以随着 HTML 的下载同时下载到本地那就太好了,而base64正好能解决这个问题。
Base64 虽有优点,但是缺点也很明显,在使用上存在一些明显的缺陷。
是的,使用Base64的好处是能够减少一个图片的 HTTP 请求,然而,与之同时付出的代价则是CSS文件体积的增大。
而CSS文件体积的增大意味着什么呢?意味着 CRP 的阻塞。
CRP(Critical Rendering Path,关键渲染路径):当浏览器从服务器接收到一个HTML页面的请求时,到屏幕上渲染出来要经过很多个步骤。浏览器完成这一系列的运行,或者说渲染出来我们常常称之为“关键渲染路径”。
通俗而言,就是图片不会导致关键渲染路径的阻塞,而转化为 Base64 的图片大大增加了CSS文件的体积,CSS 文件的体积直接影响渲染,导致用户会长时间注视空白屏幕。HTML和CSS会阻塞渲染,而图片不会。
下面通过代码对对图片进行base64编码和解码:
# -!- coding: utf-8 -!-
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
#作者:cacho_37967865
#博客:https://blog.csdn.net/sinat_37967865
#文件:baseModel.py
#日期:2019-07-02
#备注:图片进行base64编码,解码
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''import base64
import osdef encode_base64(file):with open(file,'rb') as f:img_data = f.read()base64_data = base64.b64encode(img_data)print(type(base64_data))#print(base64_data)# 如果想要在浏览器上访问base64格式图片,需要在前面加上:data:image/jpeg;base64,base64_str = str(base64_data, 'utf-8') print(base64_str)return base64_datadef decode_base64(base64_data):with open('./images/base64.jpg','wb') as file:img = base64.b64decode(base64_data)file.write(img)if __name__ == '__main__':img_path = './images/background.jpg'base64_data = encode_base64(img_path)decode_base64(base64_data)
# 如果想要在浏览器上访问base64格式图片,需要在前面加上:data:image/jpeg;base64,
备注:base64格式图片常用于尺寸较小、多处使用的、背景类图片。