Base64
انکودینگ Base64 مکانیزیمی است که در اصل به منظور انکودینگ داده های باینری به فرمت متنی ایجاد شد. انکودینگ Base64 ابتدا در سیستم های ایمیل که نیاز به پیوست داده های باینری همچون تصویر و اسناد متنی داشتند استفاده شد. چرا که این نوع پیوست ها بایستی به فرمت اسکی (ASCII) ارسال می شد.
مجموعه کاراکتری انکودینگ Base64
Base64 حاوی یک مجموعه کاراکتری از کاراکترهای اسکی قابل چاپ می باشد. ۶۲ مقدار اصلی در تمام انواع انکودینگ Base64 یکسان می باشد که شامل :
- کاراکترهای حروف بزرگ زبان انگلیسی A تا Z
- کاراکترهای حروف کوچک زبان انگلیسی a-z
- اعداد ۰ تا ۹
کاراکتر های موجود در ایندکس ۶۲ و ۶۳ بر اساس نوع انکودینگ متفاوت می باشد. این کاراکترها شامل + / , – _ . : ! ~ می باشد. جدول زیر کاراکترهای نسخه اصلی Base64 را نشان می دهد :
فرآیند انکودینگ Base64
برای انکودینگ یک رشته اسکی به صورت زیر عمل می کنیم :
- داده های باینری یا غیرباینری از سمت چپ به راست خوانده شده
- سه جفت داده هشت بیتی جداگانه از ورودی گرفته شده تا در مجموعه یک گروه ۲۴ بیتی را ایجاد کند.
- این گروه ۲۴ بیتی در ادامه به ۴ گروه ۶ بیتی تقسیم می شود.
- اکنون هر کدام از این شش بیت جداگانه توسط انکودینگ Base64 با استفاده از جدول ایندکس بالا فرمت دهی می شود. چگونه ؟
در مثال زیر واضح توضیح می دهیم . به جدول زیر دقت کنید. در اینجا می خواهیم کلمه God انکودینگ کنیم.
ابتدا با استفاده از جدول اسکی اعداد که در زیر آمده معادل باینری هر کاراکتر ایجاد شده و در قالب سه گروه هشت بیتی نوشته می شود.
سپس باینری به گروههای ۶ بیتی تبدیل شده. عدد باینری به دسیمال تبدیل شده و بر اساس جدول ایندکس ها معادل آن نوشته می شود. مثلا ایندکس ۱۷ متعلق به کاراکتر R و ایندکس ۳۶ متعلق به کاراکتر k و….
نتیجه اینکه معادل Base64 کلمه God می شود R29k
هرچند یک مشکلی در اینجا پدیدار می شود. اگر حرف ما بر اساس الگوی ۲۴ بیتی نباشد چه باید کرد ؟ مثلا کلمه Netamooz نمی توان آن را با این الگو تطبیق داد. Net می شود ۲۴ بیت , amo می شود ۲۴ بیت و oz می شود ۱۶ بیت !! با ۸ بیت آخر چه باید کرد.
این همان جایی است که مکانیزم پدینگ (Padding) وارد می شود.
پدینگ در انکودینگ Base64
هر کجا که ۸ بیت خالی بماند برای تبدیل شدن آن به یک مجموعه ۲۴ بیتی بایستی با کاراکتر = پر شود. و اگر ۱۶ بیت خالی باشد دو کاراکتر مساوی == اضافه می شود. دقیقا شبیه جدول زیر که به این مکانیزم پدینگ گویند.
انکودینگ Base64
شیوه های کدگذاری
استفاده از base64 برای inline کردن عکس
از base64 برای encode کردن باینری به متن استفاده می شود. با استفاده از این تکنیک این امکان وجود دارد که هر عکسی را به صورت داده های متنی ذخیره کرد. خوشبختانه مرورگرهای مختلف می توانند base64 را decode کنند. به عبارت دیگر اگر شما یک عکس را به صورت base64 به صورت inline در فایل HTML در <img> بنویسید، مرورگرها می توانند آن عکس را در صفحه HTML رندر کرده و به کاربر نمایش دهند. به عبارت دیگر با استفاده از این تکنیک، دیگر درخواست جداگانه برای لود عکس به سرور ارسال نمی شود و عکس به صورت قسمتی از متن صفحه HTML در مرورگر لود شده و در نهایت رندر و به کاربر نمایش داده می شود.
مزیت inline کردن عکس
همان طور که در ابتدای متن توضیح داده شد با استفاده از تکنیک inline کردن عکسها می توانید از تعداد درخواستها به سرور برای بارگذاری یک صفحه بکاهید که این امر در هنگام وجود تعداد زیادی کاربر همزمان در سایت به دلیل پایین آوردن زمان پاسخگویی سرور یا همان response time بسیار مفید خواهد بود.
ایراد inline کردن عکس
وقتی عکس به صورت فایل در یک صفحه لود شود، مرورگر می تواند آن عکس را کش کرده و برای دفعات بعد برای بارگذاری عکس به سرور درخواستی ارسال نکند و عکس را از کش لوکال بارگذاری کند. در نتیجه همه کاربران جدیدی که وارد صفحه مورد نظر می شوند برای بارگذاری عکس به سرور request ارسال می کنند ولی کاربران تکراری برای لود عکس از حافظه کش خودشان استفاده می کنند. ولی وقتی از تکنیک inline کردن عکس استفاده می کنید، مرورگر آن عکس را کش نمی کند و هر بار برای لود عکس باید کاراکترهای base64 درون HTML را بخواند. در نتیجه برای عکسهایی که در صفحات گوناگون استفاده می شوند، استفاده از تکنیک اینلاین کردن عکس ها در HTML کار منطقی به نظر نمی رسد.
توجه داشته باشید که اگر عکسی به صورت base64 به عنوان بکگراند در CSS آمده باشد، به دلیل کش شدن فایلهای CSS توسط مرورگرها، آن عکس نیز کش خواهد شد.
بهینه سازی سایت با inline کردن عکس
فرض کنید شما یک داده ی باینری دارید و می خواهید آن را در بستر شبکه انتقال دهید. به طور کلی شما این کار را تنها از طریق Stream کردن بیت ها و بایت های خام انجام نخواهید داد. چرا؟ زیرا ابزارهایی برای Stream کردن متن وجود دارد. شما هرگز اطلاع ندارید که برخی از پروتکل ها ممکن است داده های باینری شما را به عنوان کاراکترهای کنترلی تفسیر کنند ( درست به مانند یک مودم) و یا برخی دیگر از پروتکل ها همانند FTP ممکن است تصور کنند که شما یک کاراکتر خاص مانند ending را وارد کرده اید.
بنابراین برای مقابله با این مشکلات داده های باینری را به رشته ای از کاراکترها کد گذاری (encode) می کنند. Base64 یکی از انواع این گونه کد گذاری می باشد. چرا Base64؟ زیرا با استفاده از آن شما می توانید همواره بر ۶۴ کاراکتری که در اغلب مجموعه کاراکترها (character set) ارائه می شود حساب کنید و بنابراین از نحوه ی صحیح نمایش داده های خود در سمت گیرنده اطمینان بیشتری کسب کنید.
استفاده از Base64 برای طراحان وب کاربردهای بسیار مفیدی دارد. بعنوان مثال می توان برای جلوگیری از ارسال یک Request اضافه از سمت Client آیکون معروف به Favicon را به جای فایل درون تگ جاسازی نمود که در زیر نمونه آن را می بینیم:
<link href=”. …” rel=”icon” type=”image/x-icon”>
حتماً این سوال برایتان به وجود می آید که در مثال بالا چطور می توانید یک تصویر را به Base64 تبدیل کنید. برای این کار راه های مختلفی وجود دارد ولی یکی از در دسترس ترین راه ها استفاده از اپلیکیشن های آنلاین است که در زیر یکی از آنها را می توانید ملاحظه کنید:
https://www.base64-image.de/
Base 64 چیست و چه کاربردی دارد؟
چگونه مبنای 64 بهسرعت صفحات کمک میکند؟
مزیت اصلی این کدگذاری این است که صفحه وب، یک عکس خارجی را بارگذاری
نمیکند. وقتی چیزهایی که یک صفحه وب باید بارگذاری میکند را کاهش دهیم
بهطور طبیعی سرعت صفحات افزایش پیدا میکند.
یک صفحه وب با دو تصویر وجود دارد. این صفحه برای بارگذاری به 4 چیز نیاز دارد:
- HTML
- CSS
- اولین تصویر
- دومین تصویر
اینجا یک صفحه وب دیگر با تصاویر بر مبنای 64 وجود دارد. این صفحه برای بارگذاری تنها به دو چیز نیاز دارد.
- HTML
- CSS
تأثیر Base64 بر سئو چگونه است؟
تأثیر اصلی که تصاویر Base64 بر سئو میگذارد این است که تصاویر توسط گوگل شناخته نمیشوند. به این معنی که تصاویری که شما بر مبنای 64 استفاده کردید توسط جستجوی تصاویر گوگل نمایش داده نمیشوند و یا همچنین در موتورهای جستجوی دیگر نیز نمایش داده نمیشوند.
پس چرا از آن استفاده میکنیم؟
بسیاری از تصاویری که در صفحه شما وجود دارد مهم نیستند و اگر آنها
شناخته نشوند تأثیری بر روی ترافیک شما ندارند. بهترین مثال میتواند
آیکونهای اجتماعی باشد، تعداد آنها کم است مانند Twitter، Google+،
Facebook و غیره.
تصاویر واقعاً کوچک هستند و نیاز به شناخته شدن ندارند. شما هرگز از ترافیک
آیکون کوچک توییتر سود نمیبرید. در مورد تصاویری که فقط برای طراحی
استفاده میشوند مانند «دکمه پایین»، «نقلقول» فکر کنید، چیزهایی شبیه به
اینها برای سئو مهم نیستند؛ اما سرعت بارگذاری صفحاتتان را کم میکنند.
درهروب سایت 8 تا 12 آیکون اجتماعی وجود دارد که هرکدام از آنها یک
درخواست را به HTTP میفرستند درحالیکه اگر شما از Base64 استفاده کنید
نیاز نیست که آنها دانلود شوند.
سایر ملاحظات
بهتر است که تنها برای تصاویر کوچک از Base64 استفاده کنیم. اگر شما سعی میکنید که تصاویر بزرگ را بر مبنای 64 بیاورید آنگاه شما با یک مقدار بزرگی کد در HTML روبرو هستید که مزیت عملکرد Base64 را از دست میدهید.
چگونه در این سایت از Base 64 استفاده کردهایم؟
همانطور که ذکر شد من از Base64 به مقدار گسترده استفاده کردهام. هر صفحه در این سایت بهطور وسیع از Base64 استفادهشده است. ازآنجاکه من برای مدت طولانی از Base64 برای بسیاری از تصاویر استفاده کردهام یاد گرفتهام که چگونه بین موضوع سئو و عملکرد تعادل برقرار کنم.
چگونه گوگل Base64 را شناسایی میکند؟
همانطورکه قبلاً ذکرشد گوگل تصاویرکدگذاری شده برمبنای 64 را نمیتواند بشناسد. دراین مقاله چندعکس بزرگ وجود دارد. همه آنها توسط گوگل شناساییشدهاند.
چگونه من این کار را انجام دادم؟
یکراه این است که یک پوشه تصاویر که همه تصاویر آن کدگذاری شدهاند را داشته باشید، سپس شما آن را روی هاست خود آپلود کنید، در قسمت HEAD در HTML از نشانههای Opengraph برای جهتدهی گوگل به آن تصاویر استفاده کنید.
اینجا کدهایی را که در قسمت HEAD در HTML این صفحه آوردهام را قرار دادهام.
<!DOCTYPE html>
<html lang="en-US" prefix="og: http://ogp.me/ns#" xmlns:og="http://opengraphprotocol.org/schema/" xmlns:fb="http://www.facebook.com/2008/fbml" itemscope itemtype="http://schema.org/Article">
<head>
<meta name=viewport content="width=device-width, initial-scale=1">
<meta property="og:image" content="https://shift.ir/pagespeed/images/base64-image.png">
در بخش اول این کدهای بههمریخته، Opengraph ها آورده شدهاند و در بخش آخر تصویر معرفیشده است، نتیجه این کار این است که تصاویر من در گوگل شناختهشده است.
<meta property="og:image" content="https://shift.ir/pagespeed/images/base64-image.png">
مسائل مربوط بهاندازه
نتیجه کدگذاری یک فایل عکس 2kb بر مبنای 64 2.5 یا 3kb است. بااینحال اگر شما باید فایلتان را فشرده کنید. در پایان سایزی در حدود همان سایز فایل عکس به دست میآورید. من توصیه نمیکنم که برای عکسهای بزرگتر از 5kb از کدگذاری بر مبنای 64 استفاده کنید.
چگونه از Base64 استفاده کنیم؟
یک عکس معمولی در HTML شما وجود دارد.
مکان فایل (بهطور مثال Example.com) را با اطلاعات SRC بهدستآمده از
ابزار Base64 جایگزین کنید. اکنون منبع عکس شما از یک فایل خارجی دیگری
نیست در عوض آن، دادههای کدگذاری شده در SRC قرار دارد.
ابزار
برای تست کار با Base64، لطفاً از ابزار رایگان base64 image encoder tool استفاده کنید.
سلام . خیلی خوب بود.. ممنونم.