日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

浅析data:image/png;base64的应用

發布時間:2025/5/22 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 浅析data:image/png;base64的应用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

偶爾加入一個網安群的時候,入群題目是這個:



剛開始還是挺懵逼的,誒,是Base64編碼嘛?看樣子好像是圖片轉成Base64的,然后放在搜索引擎一回車,竟然是得到了入群密碼,是不是有點神奇?

?

Return Top 下面的內容是轉載的他人的博客:

data:image/png;base64是什么?

翻閱了一些資料才知道,這是在RFC2397中定義的Data URI scheme,目的是將一些小的數據,直接嵌入到網頁中,從而不用再從外部文件載入。

優點:? ?

  • 減少HTTP請求數,沒有了TCP連接消耗和同一域名下瀏覽器的并發數限制。
  • 對于小文件會降低帶寬。雖然編碼后數據量會增加,但是卻減少了http頭,當http頭的數據量大于文件編碼的增量,那么就會降低帶寬。
  • 對于HTTPS站點,HTTPS和HTTP混用會有安全提示,而HTTPS相對于HTTP來講開銷要大更多,所以Data URI在這方面的優勢更明顯。
  • 可以把整個多媒體頁面保存為一個文件。

缺點:???

  • 無法被重復利用,同一個文檔應用多次同一個內容,則需要重復多次,數據量大量增加,增加了下載時間。
  • 無法被獨自緩存,所以其包含文檔重新加載時,它也要重新加載。
  • 客戶端需要重新解碼和顯示,增加了點消耗。
  • 不支持數據壓縮,base64編碼會增加1/3大小,而urlencode后數據量會增加更多。
  • 不利于安全軟件的過濾,同時也存在一定的安全隱患。
Return Top

Data URI Scheme的基本概念

《HTTP權威指南》對URI和URL的定義:

  • URI(Uniform Resource Identifier):統一資源標識符,服務器資源名被稱為統一資源標識符。
  • URL(Uniform Resource Locator):統一資源定位符,描述了一臺特定服務器上某資源的特定位置。
  • URN(Uniform Resource Name):統一資源名稱。
URL組成: 協議://主機名[:端口]/ 路徑/[:參數] [?查詢]#Fragmentprotocol :// hostname[:port] / path / [:parameters][?query]#fragment

URI,URL,URN三者關系:

URL,URNURI的子集

Return Top

什么是Data URI Scheme

data URI scheme 允許我們使用內聯(inline-code)的方式在網頁中包含數據,目的是將一些小的數據,直接嵌入到網頁中,從而不用再從外部文件載入。常用于將圖片嵌入網頁。

傳統的圖片HTML是這樣用的:

img src="images/image.png"/

Data URI的圖片內嵌式是這樣用的:

img src=""/

Data URI的直接通過url傳遞方式:



在瀏覽器地址欄中輸入以上代碼,可直接顯示那個flag!!!

Return Top

Data URI的格式規范

data:[<mime type>][;charset=<charset>][;<encoding>],<encoded data> 1. data :協議名稱; 2. [<mime type>] :可選項,數據類型(image/pngtext/plain等) 3. [;charset=<charset>] :可選項,源文本的字符集編碼方式 4. [;<encoding>] :數據編碼方式(默認US-ASCIIBASE64兩種) 5. ,<encoded data> :編碼后的數據

目前,Data URI 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圖片數據

Data URI和MHTML兩者的配合可以完整的解決所有的主流瀏覽器,它們由于無法被緩存和重復利用的缺陷,所以并不適合直接在頁面中使用,但在CSS和JavaScript文件中對圖片適當地使用有非常大的優越性:大大減少請求數,現在大型網站的CSS引用了大量的圖片資源。CSS和JavaScript都可以被緩存,間接的實現了數據的緩存。利用CSS可以解決Data URI的重復利用問題。

告別CSS Sprites,CSS Sprites的出現是為了減少請求數,但它除了帶來在不確定情況下的異常外,CSSSprites還需要人為的圖片合并,即使有合并工具也依舊必須人為地在如何有效的拼圖上耗費大量的時間,并帶來維護的困難。當你遵循一定的設計原則后, 你就可以完全拋棄CSS Sprites來編寫CSS,最后使用工具在上傳到服務器環節把圖片轉換成Data URI和MHTML,如《利用data-uri合并樣式表和圖片》中用python實現的工具,這可以節約大量的時間。

base64編碼把圖片文件增加了1/3,Data URI和MHTML同時使用相當于增加了2/3,但CSS和JavaScript可以使用gzip壓縮,其可以節省2/3的數據量,所以使用gzip壓縮后的最終數據量是(1 + 1/3) * 2 * (1/3) = 8/9,所以最終流量是減少的。

它把一些 8-bit 數據翻譯成標準 ASCII 字符,網上有很多免費的base64 編碼和解碼的工具。

在網頁上顯示出來的標準方法是:

<img src=”” />

data:image/png;base64相當于圖片的Data URL,它是利用base64編碼把圖片數據翻譯成標準ASCII字符,等同于<img src="images/image.png"/>?

換句話說我們把圖像文件的內容內置在 HTML 文件中,節省了一個 HTTP 請求。

在 CSS 中使用:

body { background-image: url("");}

關于移動端的性能可以參考 Peter McLachlan在13年寫的一片文章:http://www.mobify.com/blog/data-uris-are-slow-on-mobile/

轉載于:https://www.cnblogs.com/zwshi/p/9251244.html

總結

以上是生活随笔為你收集整理的浅析data:image/png;base64的应用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。