در نحوه رسیدگی برخی از مرورگرها به درخواستهای داراییهای رسانه-یعنی URL مشخص شده در ویژگی src
عناصر <video>
و <audio>
- که میتواند منجر به رفتار نادرست سرویس دهی شود، مگر اینکه مراحل خاصی را هنگام پیکربندی Workbox انجام دهید، وجود دارد.
مشکل
پیچیدگیهای مشکلی که مرورگرها در مورد ارائه داراییهای صوتی و تصویری دارند در این بحث مربوط به GitHub به تفصیل توضیح داده شده است. تصویر کامل پیچیده است، اما نکات کلیدی عبارتند از:
- باید به Workbox گفته شود که با استفاده از ماژول
workbox-range-requests
برای استراتژی مورد استفاده به عنوان کنترل کننده به سرصفحه های درخواستRange
احترام بگذارد. - عناصر
<video>
یا<audio>
باید با ویژگیcrossorigin
وارد حالت CORS شوند. - اگر میخواهید رسانهها را از حافظه پنهان ارائه کنید، باید به صراحت آن را از قبل به حافظه پنهان اضافه کنید. شما می توانید این کار را با پیش کش کردن یا با
cache.add()
یا با استفاده از متد warmStrategyCache در جعبه دستور العمل ها انجام دهید. ذخیره کردن دارایی رسانه در هنگام پخش جریانی در زمان اجرا کار نخواهد کرد، زیرا فقط محتوای جزئی در طول پخش از شبکه واکشی می شود.
در اینجا نحوه تطبیق این الزامات در Workbox، با نشانه گذاری مناسب برای دارایی رسانه، آمده است:
<!-- In your page: -->
<!-- You need to set `crossorigin`, even for same-origin URLs! -->
<video src="movie.mp4" crossorigin="anonymous"></video>
<audio src="song.mp3" crossorigin="anonymous"></audio>
سپس در سرویسکار خود، از افزونه workbox-range-request
استفاده کنید تا بر اساس آن داراییهای رسانه را مدیریت کنید:
// sw.js
import {registerRoute} from 'workbox-routing';
import {CacheFirst} from 'workbox-strategies';
import {CacheableResponsePlugin} from 'workbox-cacheable-response';
import {RangeRequestsPlugin} from 'workbox-range-requests';
// In your service worker:
// It's up to you to either precache, use warmRuntimeCache, or
// explicitly call cache.add() to populate the cache with media assets.
// If you choose to cache media assets up front, do so with care,
// as they can be quite large and exceed storage quotas.
//
// This route will go to the network if there isn't a cache match,
// but it won't populate the cache at runtime because the response for
// the media asset will be a partial 206 response. If there is a cache
// match, then it will properly serve partial responses.
registerRoute(
({request}) => {
const {destination} = request;
return destination === 'video' || destination === 'audio'
},
new CacheFirst({
cacheName: 'your-cache-name-here',
plugins: [
new CacheableResponsePlugin({
statuses: [200]
}),
new RangeRequestsPlugin(),
],
}),
);
با این رویکرد، میتوانید اطمینان حاصل کنید که داراییهای رسانهای وبسایتتان بهدرستی توسط کارمند خدماتتان واکشی و ذخیره میشوند، در حالی که درخواستهای محدوده و سایر مشکلات احتمالی مرتبط با درخواستهای رسانه را در نظر میگیرید.