الگوی داده‌ای یوآرآی

از ویکی‌پدیا، دانشنامهٔ آزاد
پرش به: ناوبری، جستجو

الگوی داده‌ای یوآرآی، یک الگوی یوآرآی یا به عبارتی الگوی نشانی وب است که راهی‌ست برای وارد کردن داده با قالبی خاص در داخل یک صفحه وب، بصورتی که انگار آنها منابع خارجی مانند تصاویر هستند. این روش به ما اجازه میدهد برای فراخوانی یک صفحه وب، بجای ارسال چند بار درخواست اچ‌تی‌تی‌پی، برای احضار چند منبع (مثلاً احضار و فراخوانی فایلهای تصاویر، سی‌اس‌اس، جاوااسکریپت و ...) تنها یکبار دستور درخواست اچ‌تی‌تی‌پی را ارسال نماییم، که میتواند به بهره‌بری بالاتری منجر گردد.

گاه یوآرآی علی‌رغم اینکه به محلی در خارج اشاره نمی‌کنند، با نشانی وب (به انگلیسی:Uniform Resource Locator یا URL) اشتباه گرفته میشوند. الگوی یوآرآی در استاندارد RFC2397 تعریف گردیده است.

پشتیبانی در مرورگرهای وب[ویرایش]

از فروردین ۱۳۹۱ مرورگرهای زیر الگوی داده‌ای یوآرآی را پشتیبانی میکنند:

پشتیبانی در برنامه‌های مدیریت پست الکترونیک یا کلاینت ایمیل[ویرایش]

برنامه‌های زیر داده‌های یوآرآی که برای تصویر باشند را پشتیبانی می‌کنند:

  • Apple Mail 4
  • BlackBerry Curve
  • HTC HD7
  • iPad 2
  • iPhone 3GS
  • LG Optimus
  • Lotus Notes 8
  • Me.com
  • Nokia N96
  • Outlook 2003
  • Thunderbird 3
  • Yahoo! Mail

مزایا[ویرایش]

  • درخواست اچ‌تی‌تی‌پی و ترافیک Header برای این نوع داده وجود ندارد.
  • برای انتقال تعداد زیادی از فایلهای کوچک، این روش میتواند سریعتر باشد. انتقال میتواند با سرعت کمتری صورت پذیرد اگر هر فایل بصورت جداگانه درخواست اچ‌تی‌تی‌پی خود را ارسال نمایند.
  • برای مرور صفحات امنی که از پروتکل امن انتقال ابرمتن یا HTTPS استفاده میکنند، همیشه استفاده از ترکیبی از منابع امن و غیرامن یک نگرانی بوده است. بنابراین با استفاده از این روش بیشتر عناصر یک صفحه را بدون نیاز به فراخوانی از منابع غیرامن میتوان انتقال داد. به اضافه اینکه، در یک سرور امن با تنظیمات بد، فشار یک درخواست HTTPS همیشه بیشتر از HTTP معمولی است و با قرار دادن داده‌های یوآرآی در یک صفحه، نیاز به ارسال تعداد زیادی درخواست HTTPS امن به سرور را از بین برده و سرعت را افزایش می‌دهیم.
  • مرورگرها اصولاً بصورتی تنظیم گردیده‌اند که تعداد مشخصی از ارتباطات HTTP همزمان را با یک دامنه ایجاد مینمایند. پس با اینکار نیاز به استفاده بیش از حد از ارتباطات همزمان برای دامنه هدف را از بین میبریم و باعث افزایش بهره‌بری خواهد شد.
  • از این روش میتوان در محیطهایی که دارای محدودیت یا جلوگیری از دسترسی به منابع خارجی دارند در زمانی که اجازه دسترسی به خارج وجود ندارد میتوان استفاده نمود. بطور مثال یک موسسه ویرایشگر پیشرفته HTML به منظور مخفی کردن پیچیدگی منابع خارجی برای کاربر، میتواند یک تصویر را گرفته و به داده یوآرآی تبدیل نموده و در صفحه وب مورد نظر قرار دهد.
  • این روش استفاده از تنها یک صفحه را برای ایجاد صفحات چندرسانه‌ای امکان‌پذیر مینماید.
  • الگوی پیام رایانامه میتواند محتوی تصاویری (برای پشت‌صحنه و امضاء) باشد بدون اینکه فایل پیوستی به پیام قابل دید باشد.[۱]

معایب[ویرایش]

معایبی نیز برای این روش ذکر میگردد مانند:

  • عدم پشتیبانی یا پشتیبانی کم در برخی مرورگرها خصوصاً اینترنت اکسپلرر مایکروسافت
  • عدم قرار گرفتن در حافظه کش این نوع داده بصورت جداگانه از فایلی (فایل CSS یا HTML) که محتوی آن است
  • افزایش ۱/۳ حجم اطلاعات با کد شدن بر اساس Base64 در مقیاس با شکل دودویی آن داده‌ها (هرچند این افزایش حجم میتواند به اندازه ۲-۳٪ کل آن کاهش پیدا کند اگر وب سرور، پاسخ‌های ارسالی را با استفاده از جی‌زیپ یا gzip فشرده نماید.)
  • نیاز به ارجاع دادن به یک داده یوآرآی یکسان در یک صفحه، منجر به کپی کردن چندین بار آن کد در آن صفحه میشود. در حالیکه با استفاده از یک منبع خارجی، ما تنها یکبار آن منبع را فراخوانده و یکبار هم آن در Decode میکنیم.
  • تشخیص داده‌های یوآرآی توسط نرم‌افزارها و دستگاههای امنیتی برای فیلتر کردن محتویات مخرب بسیار دشوارتر میگردد

ترکیب و قالب مورد استفاده[ویرایش]

 data:[<MIME-type>][;charset=<encoding>][;base64],<data>

مثالها[ویرایش]

اچ‌تی‌ام‌ال[ویرایش]

در کد زیرین یک نقطه قرمز رنگ مانند Red-dot-5px.png به کد تبدیل شده است که اگر کد داخل علامت نقل قول که بعد از src آمده است را در قسمت آدرس مرورگری که داده یوآرآی را پشتیبانی میکند کپی نماییم این نقطه قرمز رنگ را با قالب تصویری PNG نمایش میدهد:
<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUA
AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot">
یا در زیر کد یک خط که میتواند برای تشکیل پشت‌صحنه یک جعبه متنی مثل فرم ورود اطلاعات کاربر مورد استفاده قرار گیرد آمده است:
<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAA0CAAAAACF
/rZIAAAAM0lEQVQIW63CsQ0AEBRAwfeTV1lKbVrjGEMnCsIKCpdz
48aFEwd2bFgwHvJ1xYQZD4LBBVKOCciNazFCAAAAAElFTkSuQmCC" alt="TextBox Line">

چنانچه در مثالهای بالا میبینید یک کد داده یوآرآی میتواند محتوی فضای خالی نیز باشد و فضای خالی در بین کد تاثیری در آن ندارد.

CSS[ویرایش]

یک دستور Background-image در سی‌اس‌اس:

ul.checklist li.complete {
    padding-left: 20px;
    background: white url('data:image/png;base64,iVBORw0KGgoAA
AANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAABlBMVEUAAAD///+l2Z/dAAAAM0l
EQVR4nGP4/5/h/1+G/58ZDrAz3D/McH8yw83NDDeNGe4Ug9C9zwz3gVLMDA/A6
P9/AFGGFyjOXZtQAAAAAElFTkSuQmCC') no-repeat scroll left top;
}
در فایرفاکس ۵، گوگل کروم ۱۷، و آی‌ای ۹، داده یوآرآی نباید محتوی خط جدید باشد.

JavaScript[ویرایش]

یک عبارت جاوااسکریپت، که یک زیر ویندوز را باز میکند:

window.open('data:text/html;charset=utf-8,%3C%21DOCTYPE%20' +
  'html%3E%0D%0A%3Chtml%20lang%3D%22en%22%3E%0D%0A%3Chead%' +
  '3E%3Ctitle%3EEmbedded%20Window%3C%2Ftitle%3E%3C%2Fhead%' +
  '3E%0D%0A%3Cbody%3E%3Ch1%3E42%3C%2Fh1%3E%3C%2Fbody%3E%0A' +
  '%3C%2Fhtml%3E%0A%0D%0A','_blank','height=300,width=400');
این مثال با اینترنت اکسپلرر ۸ کار نمی‌کند.

جستارهای وابسته[ویرایش]

منابع[ویرایش]

  1. "Data URI scheme,"، Wikipedia contributors.