Base64圖片編碼原理,base64圖片工具介紹,圖片在線轉換Base64


Base64圖片編碼原理,base64圖片工具介紹,圖片在線轉換Base64

DataURI 允許在HTML文檔中嵌入小文件,可以使用 img 標簽或 CSS 嵌入轉換后的 Base64 編碼,減少 HTTP 請求,加快小圖像的加載時間。

經過Base64 編碼后的文件體積一般比源文件大 30% 左右。

// Base64 在CSS中的使用
.box{ background-image: url("..."); } // Base64 在HTML中的使用 <img src="..." />

圖片在線轉換Base64,圖片編碼base64
https://www.css-js.com/tools/base64.html

支持Base64(DataURI)的瀏覽器

Chrome 4+  
Android Chrome 57+
Firefox 2+
Android Firefox 52+
Safari 3.1+
IOS Safari 3.2+
Opera 9+ Opera9~11 限制為 64K
IE 8+ IE8 限制為 32KB
Mobile IE10+  
Edge12+
Android UC11+
QQ Browser1.2+

base64圖片編碼大小與原圖文件大小之間的聯系

有時候我們需要把canvas畫布的圖畫轉換成圖片輸出頁面,而用canvas生成的圖片就是base64編碼的,它是由數字、字母等一大串的字符組成的,但是我們需要獲取它的文件流大小該怎么辦呢?

Base64圖片編碼原理:

Base64編碼要求把3個8位字節(3*8=24)轉化為4個6位的字節(4*6=24),之后在6位的前面補兩個0,形成8位一個字節的形式。 如果剩下的字符不足3個字節,則用0填充,輸出字符使用’=’,因此編碼后輸出的文本末尾可能會出現1或2個’=’

詳情請閱讀- base64原理 本地圖片base64編碼及大小[h5]

http://gj.3gwen.com/tpbase64.html?kbl=

  • Base64是網絡上最常見的用於傳輸8Bit字節代碼的編碼方式之一,Base64編碼可用於在HTTP環境下傳遞較長的標識信息。采用Base64編碼具有不可讀性,即所編碼的數據不會被人用肉眼所直接看到。
  • 在MIME格式的電子郵件中,base64可以用來將binary的字節序列數據編碼成ASCII字符序列構成的文本。使用時,在傳輸編碼方式中指定base64。使用的字符包括大小寫字母各26個,加上10個數字,和加號“+”,斜杠“/”,一共64個字符,等號“=”用來作為后綴用途。
  • Base64編碼要求把3個8位字節(3*8=24)轉化為4個6位的字節(4*6=24),之后在6位的前面補兩個0,形成8位一個字節的形式。 如果剩下的字符不足3個字節,則用0填充,輸出字符使用'=',因此編碼后輸出的文本末尾可能會出現1或2個'='。
  • 為了保證所輸出的編碼位可讀字符,Base64制定了一個編碼表,以便進行統一轉換。編碼表的大小為2^6=64,這也是Base64名稱的由來。

    base64圖片工具介紹

    • 支持 PNG、GIF、JPG、BMP、ICO 格式。
    • 支持查看圖片的具體大小。上傳過程無需網絡。
    • 將圖片轉換為Base64編碼,可以讓你很方便地在沒有上傳文件的條件下將圖片插入其它的網頁、編輯器中。 這對於一些小的圖片是極為方便的,因為你不需要再去尋找一個保存圖片的地方。
    • 假定生成的代碼為“data:image/jpeg;base64, .....”,那么你只需要全部復制,然后在插入圖片的時候,地址填寫這段代碼即可。
    • CSS中使用:
      background-image: url("...");
    • HTML中使用:
      <img src="..." />
    • 圖片轉換Base64,無線開發、HTML5、CSS3必備的工具,CSS DataURI Base64 工具。
    • 將圖片轉換成base64編碼的,在web網上一般用於小圖片上,不僅可以減少圖片的請求數量(集合到js、css代碼中),還可以防止因為一些相對路徑等問題導致圖片404錯誤。

當我們知道base64編碼的圖片的字符大小,怎么計算圖片的文件流大小呢??

通過base64編碼原理我們知道,base64的圖片字符流中的每8個字符就有兩個是用0補充,而且字符流的末尾還可能存在‘=’號,我們可以通過這個原理計算圖片的文件流大小。

下面舉例:

這是一張圖片的base64編碼:

.....
AAA==

為了方便,我們用str代替上面編碼。

1.需要計算文件流大小,首先把頭部的data:image/png;base64,(注意有逗號)去掉。

var str = base64pic.split(",")[1];

2.找到等號,把等號也去掉

var equalIndex= str.indexOf(‘=’);
if(str.indexOf(‘=’)>0)
{
    str=str.substring(0, equalIndex);

}

3.原來的字符流大小,單位為字節

var strLength=str.length;

4.計算后得到的文件流大小,單位為字節

var fileLength=parseInt(strLength-(strLength/8)*2);


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM