با میزبانی Firebase، می توانید رفتار میزبانی سفارشی را برای درخواست های سایت خود پیکربندی کنید.
چه چیزی را می توانید برای هاست پیکربندی کنید؟
مشخص کنید که کدام فایل ها را در فهرست پروژه محلی خود می خواهید در میزبانی Firebase مستقر کنید. یاد بگیرند که چگونه.
ارائه یک صفحه سفارشی 404/Not Found. یاد بگیرند که چگونه.
redirects
برای صفحاتی که منتقل یا حذف کرده اید تنظیم کنید. یاد بگیرند که چگونه.rewrites
برای هر یک از این اهداف تنظیم کنید:یک محتوا را برای چندین URL نشان دهید. یاد بگیرند که چگونه.
یک تابع را ارائه دهید یا از یک URL میزبانی به یک محفظه Cloud Run دسترسی پیدا کنید. یاد بگیرید چگونه: تابع یا ظرف .
یک دامنه سفارشی پیوند پویا ایجاد کنید. یاد بگیرند که چگونه.
headers
را اضافه کنید تا اطلاعات اضافی در مورد یک درخواست یا پاسخ ارسال شود، مانند اینکه مرورگرها چگونه باید صفحه و محتوای آن را مدیریت کنند (احراز هویت، ذخیره سازی، رمزگذاری و غیره). یاد بگیرند که چگونه.بازنویسی های بین المللی (i18n) را برای ارائه محتوای خاص بر اساس ترجیح زبان و/یا کشور کاربر تنظیم کنید. یاد بگیرید چگونه (صفحه مختلف).
پیکربندی هاست خود را کجا تعریف می کنید؟
شما پیکربندی میزبانی Firebase خود را در فایل firebase.json
خود تعریف می کنید. هنگامی که فرمان firebase init
را اجرا می کنید، Firebase به طور خودکار فایل firebase.json
شما را در ریشه دایرکتوری پروژه شما ایجاد می کند.
میتوانید یک نمونه کامل از پیکربندی firebase.json
(که فقط میزبانی Firebase را پوشش میدهد) در پایین این صفحه پیدا کنید. توجه داشته باشید که یک فایل firebase.json
میتواند شامل پیکربندیهایی برای سایر سرویسهای Firebase نیز باشد.
با استفاده از Hosting REST API می توانید محتوای firebase.json
مستقر شده را بررسی کنید.
ترتیب اولویت پاسخ های میزبانی
گزینه های مختلف پیکربندی میزبانی Firebase که در این صفحه توضیح داده شده است گاهی اوقات ممکن است با هم همپوشانی داشته باشند. اگر تضاد وجود داشته باشد، میزبانی پاسخ خود را با استفاده از ترتیب اولویت زیر تعیین می کند:
- فضاهای نام رزرو شده که با یک بخش مسیر
/__/*
شروع می شوند - تغییر مسیرهای پیکربندی شده
- محتوای ثابت با تطابق دقیق
- بازنویسی های پیکربندی شده
- صفحه سفارشی 404
- صفحه پیش فرض 404
اگر از بازنویسیهای i18n استفاده میکنید، ترتیب تطابق دقیق و اولویت رسیدگی به 404 برای مطابقت با محتوای i18n شما گسترش مییابد.
مشخص کنید که کدام فایل ها مستقر شوند
ویژگیهای پیشفرض - public
و ignore
- موجود در فایل firebase.json
پیشفرض، تعریف میکنند که کدام فایلها در فهرست پروژه شما باید در پروژه Firebase شما مستقر شوند.
پیکربندی پیش فرض hosting
در یک فایل firebase.json
به شکل زیر است:
"hosting": {
"public": "public", // the only required attribute for Hosting
"ignore": [
"firebase.json",
"**/.*",
"**/node_modules/**"
]
}
عمومی
ضروری
مشخصه public
مشخص می کند که کدام دایرکتوری در میزبانی Firebase مستقر شود. مقدار پیشفرض دایرکتوری با نام public
است، اما میتوانید مسیر هر دایرکتوری را تا زمانی که در فهرست پروژه شما وجود دارد، مشخص کنید.
زیر نام پیش فرض مشخص شده دایرکتوری برای استقرار است:
"hosting": {
"public": "public"
// ...
}
می توانید مقدار پیش فرض را به دایرکتوری که می خواهید استقرار دهید تغییر دهید:
"hosting": {
"public": "dist/app"
// ...
}
چشم پوشی
اختیاری
ویژگی ignore
فایل هایی را که در هنگام استقرار نادیده گرفته می شوند را مشخص می کند. می تواند globs را به همان روشی که Git با .gitignore
اداره می کند، بگیرد.
مقادیر زیر مقادیر پیشفرض برای نادیده گرفتن فایلها هستند:
"hosting": {
// ...
"ignore": [
"firebase.json", // the Firebase configuration file (the file described on this page)
"**/.*", // files with a leading period should be hidden from the system
"**/node_modules/**" // contains dependencies used to create your site but not run it
]
}
یک صفحه 404/Not Found را سفارشی کنید
اختیاری
وقتی کاربر سعی میکند به صفحهای که وجود ندارد دسترسی پیدا کند، میتوانید خطای سفارشی 404 Not Found
را ارائه کنید.
یک فایل جدید در فهرست public
پروژه خود ایجاد کنید، نام آن را 404.html
بگذارید، سپس محتوای سفارشی 404 Not Found
خود را به فایل اضافه کنید.
اگر مرورگر خطای 404 Not Found
را در دامنه یا زیر دامنه شما ایجاد کند، میزبانی Firebase محتوای این صفحه سفارشی 404.html
را نمایش می دهد.
تغییر مسیرها را پیکربندی کنید
اختیاری
اگر صفحهای را جابهجا کردهاید، از تغییر مسیر URL برای جلوگیری از شکستن لینکها استفاده کنید یا URLها را کوتاه کنید. برای مثال، میتوانید مرورگر را از example.com/team
به example.com/about.html
هدایت کنید.
با ایجاد یک ویژگی redirects
که حاوی آرایه ای از اشیاء است (به نام "قوانین تغییر مسیر") تغییر مسیرهای URL را مشخص کنید. در هر قانون، یک الگوی URL را مشخص کنید که اگر با مسیر URL درخواست مطابقت داشته باشد، میزبانی را تحریک می کند تا با تغییر مسیر به URL مقصد مشخص شده پاسخ دهد.
در اینجا ساختار اصلی برای یک ویژگی redirects
آمده است. این مثال با ایجاد یک درخواست جدید به /bar
، درخواست ها را به /foo
هدایت می کند.
"hosting": {
// ...
// Returns a permanent redirect to "/bar" for requests to "/foo" (but not "/foo/**")
"redirects": [ {
"source": "/foo",
"destination": "/bar",
"type": 301
} ]
}
"hosting": {
// ...
// Add the "redirects" attribute within "hosting"
"redirects": [ {
// Returns a permanent redirect to "/bar" for requests to "/foo" (but not "/foo/**")
"source": "/foo",
"destination": "/bar",
"type": 301
}, {
// Returns a permanent redirect to "/bar" for requests to both "/foo" and "/foo/**"
"source": "/foo{,/**}"
"destination": "/bar"
"type": 301
}, {
// Returns a temporary redirect for all requests to files or directories in the "firebase" directory
"source": "/firebase/**",
"destination": "https://firebase.google.com/",
"type": 302
}, {
// A regular expression-based redirect equivalent to the above behavior
"regex": "/firebase/.*",
"destination": "https://firebase.google.com/",
"type": 302
} ]
}
ویژگی redirects
شامل آرایه ای از قوانین تغییر مسیر است که در آن هر قانون باید فیلدهای جدول زیر را شامل شود.
میزبانی Firebase source
یا مقدار regex
را با تمام مسیرهای URL در شروع هر درخواست مقایسه می کند (قبل از اینکه مرورگر تعیین کند که آیا یک فایل یا پوشه در آن مسیر وجود دارد یا خیر). اگر مطابقت پیدا شد، سرور اصلی میزبانی Firebase یک پاسخ تغییر مسیر HTTPS را ارسال میکند و به مرورگر میگوید یک درخواست جدید در URL destination
ارسال کند.
رشته | شرح | |
---|---|---|
redirects | ||
source (توصیه می شود)یا regex | یک الگوی URL که اگر با URL درخواست اولیه مطابقت داشته باشد، میزبانی را برای اعمال تغییر مسیر تحریک می کند
| |
destination | یک URL ثابت که در آن مرورگر باید درخواست جدیدی ارائه کند این URL می تواند یک مسیر نسبی یا مطلق باشد. | |
type | کد پاسخ HTTPS
|
بخش های URL را برای تغییر مسیرها ضبط کنید
اختیاری
گاهی اوقات، ممکن است لازم باشد بخشهای خاصی از الگوی URL یک قانون تغییر مسیر (مقدار source
یا regex
) را ضبط کنید، سپس دوباره از این بخشها در مسیر destination
قانون استفاده کنید.
اگر از یک فیلد source
استفاده میکنید (یعنی یک glob برای الگوی URL خود مشخص میکنید)، میتوانید با گنجاندن یک پیشوند :
برای شناسایی بخش، بخشها را ضبط کنید. اگر همچنین باید مسیر URL باقیمانده را بعد از بخش ثبت کنید، یک *
بلافاصله بعد از بخش اضافه کنید. مثلا:
"hosting": { // ... "redirects": [ { "source": "/blog/:post*", // captures the entire URL segment beginning at "post" "destination": "https://blog.myapp.com/:post", // includes the entire URL segment identified and captured by the "source" value "type": 301 }, { "source": "/users/:id/profile", // captures only the URL segment "id", but nothing following "destination": "/users/:id/newProfile", // includes the URL segment identified and captured by the "source" value "type": 301 } ] }
اگر از یک فیلد regex
استفاده میکنید (یعنی یک عبارت منظم RE2 برای الگوی URL خود مشخص میکنید)، میتوانید بخشهایی را با استفاده از گروههای ضبط RE2 نامدار یا بدون نام ضبط کنید. گروههای ضبط نامدار را میتوان در فیلد destination
با پیشوند :
استفاده کرد، در حالی که گروههای ضبط بدون نام را میتوان با شاخص عددی در مقدار regex
، نمایهسازی شده از 1، ارجاع داد.
"hosting": { // ... "redirects": [ { "regex": "/blog/(?P<post>.+)", // if you're familiar with PCRE, be aware that RE2 requires named capture groups to begin with ?P "destination": "https://blog.myapp.com/:post", // includes the entire URL segment identified and captured by the `regex` value "type": 301 }, { "regex": "/users/(\d+)/profile", // uses the \d directive to only match numerical path segments "destination": "/users/:1/newProfile", // the first capture group to be seen in the `regex` value is named 1, and so on "type": 301 } ] }
بازنویسی ها را پیکربندی کنید
اختیاری
از یک بازنویسی برای نمایش محتوای یکسان برای چندین URL استفاده کنید. بازنویسی ها به ویژه در تطبیق الگو مفید هستند، زیرا می توانید هر URL را که با الگو مطابقت دارد بپذیرید و اجازه دهید کد سمت مشتری تصمیم بگیرد که چه چیزی را نمایش دهد.
همچنین میتوانید از بازنویسیها برای پشتیبانی از برنامههایی که از HTML5 pushState برای پیمایش استفاده میکنند، استفاده کنید. هنگامی که یک مرورگر سعی می کند یک مسیر URL را باز کند که با الگوی URL source
یا regex
مشخص شده مطابقت دارد، به جای آن، محتوای فایل در URL destination
به مرورگر داده می شود.
با ایجاد یک ویژگی rewrites
که حاوی آرایهای از اشیاء است (به نام «قوانین بازنویسی») بازنویسیهای URL را مشخص کنید. در هر قانون، یک الگوی URL را مشخص کنید که اگر با مسیر URL درخواست مطابقت داشته باشد، میزبانی را فعال میکند تا به گونهای پاسخ دهد که گویی URL مقصد مشخص شده به سرویس داده شده است.
در اینجا ساختار اصلی یک ویژگی rewrites
است. این مثال index.html
را برای درخواست هایی به فایل ها یا دایرکتوری هایی که وجود ندارند ارائه می کند.
"hosting": {
// ...
// Serves index.html for requests to files or directories that do not exist
"rewrites": [ {
"source": "**",
"destination": "/index.html"
} ]
}
"hosting": { // ... // Add the "rewrites" attribute within "hosting" "rewrites": [ { // Serves index.html for requests to files or directories that do not exist "source": "**", "destination": "/index.html" }, { // Serves index.html for requests to both "/foo" and "/foo/**" // Using "/foo/**" only matches paths like "/foo/xyz", but not "/foo" "source": "/foo{,/**}", "destination": "/index.html" }, { // A regular expression-based rewrite equivalent to the above behavior "regex": "/foo(/.*)?", "destination": "/index.html" }, { // Excludes specified pathways from rewrites "source": "!/@(js|css)/**", "destination": "/index.html" } ] }
ویژگی rewrites
حاوی آرایهای از قوانین بازنویسی است که هر قانون باید شامل فیلدهای جدول زیر باشد.
میزبانی Firebase تنها زمانی قانون بازنویسی را اعمال میکند که فایل یا دایرکتوری در مسیر URL وجود نداشته باشد که با source
مشخص شده یا الگوی URL regex
مطابقت داشته باشد. هنگامی که یک درخواست یک قانون بازنویسی را راه اندازی می کند، مرورگر محتوای واقعی فایل destination
مشخص شده را به جای تغییر مسیر HTTP برمی گرداند.
رشته | شرح | |
---|---|---|
rewrites | ||
source (توصیه می شود)یا regex | یک الگوی URL که اگر با URL درخواست اولیه مطابقت داشته باشد، میزبانی را تحریک می کند تا بازنویسی را اعمال کند
| |
destination | یک فایل محلی که باید وجود داشته باشد این URL می تواند یک مسیر نسبی یا مطلق باشد. |
درخواست های مستقیم به یک تابع
می توانید rewrites
برای ارائه یک تابع از URL میزبانی Firebase استفاده کنید. مثال زیر گزیده ای از ارائه محتوای پویا با استفاده از توابع ابری است.
به عنوان مثال، برای هدایت همه درخواست ها از صفحه /bigben
در سایت میزبانی خود برای اجرای تابع bigben
:
"hosting": {
// ...
// Directs all requests from the page `/bigben` to execute the `bigben` function
"rewrites": [ {
"source": "/bigben",
"function": {
"functionId": "bigben",
"region": "us-central1" // optional (see note below)
"pinTag": true // optional (see note below)
}
} ]
}
اگر
region
از یک بلوکfunction
پیکربندیhosting.rewrites
حذف شود، Firebase CLI تلاش میکند تا به طور خودکار منطقه را از کد منبع تابع شناسایی کند که در صورت نامشخص بودن، پیشفرضus-central1
است. اگر کد منبع تابع در دسترس نباشد، CLI سعی می کند منطقه را از تابع مستقر شده تشخیص دهد. اگر تابع در چندین منطقه باشد، CLI نیاز دارد کهregion
در پیکربندیhosting.rewrites
مشخص شود.
ویژگی
pinTag
فقط در Cloud Functions برای Firebase (نسل دوم) موجود است. با استفاده از این ویژگی، می توانید اطمینان حاصل کنید که هر تابع برای تولید محتوای پویا سایت شما با منابع میزبانی استاتیک و پیکربندی هاست شما هماهنگ است. همچنین، این ویژگی به شما امکان میدهد بازنویسیهای خود را برای عملکردهای موجود در کانالهای پیشنمایش میزبانی پیشنمایش کنید.اگر
"pinTag": true
به یک بلوکfunction
hosting.rewrites
اضافه کنید، آنگاه تابع "پین" به همراه منابع و پیکربندی استاتیک میزبانی شما مستقر میشود، حتی در هنگام اجرای. اگر نسخهای از سایت خود را به عقب برگردانید، عملکرد "پین" نیز بازگردانده میشود.
firebase deploy --only hosting این ویژگی به تگ های Cloud Run متکی است که دارای محدودیت 1000 برچسب در هر سرویس و 2000 برچسب در هر منطقه هستند. این بدان معناست که پس از صدها استقرار، قدیمیترین نسخههای یک سایت ممکن است از کار بیفتند.
پس از افزودن این قانون بازنویسی و استقرار در Firebase (با استفاده از firebase deploy
)، تابع شما از طریق URL های زیر قابل دسترسی است:
زیر دامنه های Firebase شما:
PROJECT_ID .web.app/bigben
وPROJECT_ID .firebaseapp.com/bigben
هر دامنه سفارشی متصل:
CUSTOM_DOMAIN /bigben
هنگام هدایت مجدد درخواست ها به توابع با میزبانی، روش های درخواست HTTP پشتیبانی شده عبارتند از GET
، POST
، HEAD
، PUT
، DELETE
، PATCH
و OPTIONS
. روش های دیگر مانند REPORT
یا PROFIND
پشتیبانی نمی شوند.
درخواستها را به یک کانتینر Cloud Run مستقیم کنید
میتوانید rewrites
برای دسترسی به محفظه Cloud Run از URL میزبانی Firebase استفاده کنید. مثال زیر گزیده ای از ارائه محتوای پویا با استفاده از Cloud Run است.
به عنوان مثال، برای هدایت همه درخواستها از صفحه /helloworld
در سایت میزبانی خود برای راهاندازی و اجرای یک نمونه کانتینر helloworld
:
"hosting": {
// ...
// Directs all requests from the page `/helloworld` to trigger and run a `helloworld` container
"rewrites": [ {
"source": "/helloworld",
"run": {
"serviceId": "helloworld", // "service name" (from when you deployed the container image)
"region": "us-central1" // optional (if omitted, default is us-central1)
}
} ]
}
با استفاده از این ویژگی، می توانید اطمینان حاصل کنید که تجدید نظر در سرویس Cloud Run برای تولید محتوای پویا سایت شما با منابع میزبانی ثابت و پیکربندی هاست شما همگام می شود. همچنین، این ویژگی به شما این امکان را می دهد که پیش نمایش بازنویسی های خود را در Cloud Run در کانال های پیش نمایش میزبانی وب مشاهده کنید.
اگر
"pingTag": true
به یک بلوکrun
از پیکربندیhosting.rewrites
اضافه کنید، منابع و پیکربندی استاتیک میزبانی شما به آخرین ویرایش سرویس Cloud Run در زمان استقرار پین خواهد شد. اگر نسخهای از سایت خود را به عقب برگردانید، بازبینی سرویس Cloud Run "پین شده" نیز بازگردانده میشود.این ویژگی به تگ های Cloud Run متکی است که دارای محدودیت 1000 برچسب در هر سرویس و 2000 برچسب در هر منطقه هستند. این بدان معناست که پس از صدها استقرار، قدیمیترین نسخههای یک سایت ممکن است از کار بیفتند.
پس از افزودن این قانون بازنویسی و استقرار در Firebase (با استفاده از firebase deploy
)، تصویر کانتینر شما از طریق URL های زیر قابل دسترسی است:
زیر دامنه های Firebase شما:
PROJECT_ID .web.app/helloworld
وPROJECT_ID .firebaseapp.com/helloworld
هر دامنه سفارشی متصل:
CUSTOM_DOMAIN /helloworld
هنگام هدایت مجدد درخواست ها به کانتینرهای Cloud Run با میزبانی، روش های درخواست HTTP پشتیبانی شده عبارتند از GET
، POST
، HEAD
، PUT
، DELETE
، PATCH
و OPTIONS
. روش های دیگر مانند REPORT
یا PROFIND
پشتیبانی نمی شوند.
برای بهترین عملکرد، سرویس Cloud Run خود را با هاستینگ با استفاده از مناطق زیر یکجا قرار دهید:
-
us-west1
-
us-central1
-
us-east1
-
europe-west1
-
asia-east1
بازنویسی در Cloud Run از Hosting در مناطق زیر پشتیبانی می شود:
-
asia-east1
-
asia-east2
-
asia-northeast1
-
asia-northeast2
-
asia-northeast3
-
asia-south1
-
asia-south2
-
asia-southeast1
-
asia-southeast2
-
australia-southeast1
-
australia-southeast2
-
europe-central2
-
europe-north1
-
europe-southwest1
-
europe-west1
-
europe-west12
-
europe-west2
-
europe-west3
-
europe-west4
-
europe-west6
-
europe-west8
-
europe-west9
-
me-central1
-
me-west1
-
northamerica-northeast1
-
northamerica-northeast2
-
southamerica-east1
-
southamerica-west1
-
us-central1
-
us-east1
-
us-east4
-
us-east5
-
us-south1
-
us-west1
-
us-west2
-
us-west3
-
us-west4
-
us-west1
-
us-central1
-
us-east1
-
europe-west1
-
asia-east1
ایجاد پیوندهای پویا دامنه سفارشی
می توانید rewrites
برای ایجاد پیوندهای پویا دامنه سفارشی استفاده کنید. برای اطلاعات دقیق در مورد راه اندازی یک دامنه سفارشی برای پیوندهای پویا، از مستندات پیوندهای پویا دیدن کنید.
از دامنه سفارشی خود فقط برای پیوندهای پویا استفاده کنید
"hosting": { // ... "appAssociation": "AUTO", // required for Dynamic Links (default is AUTO if not specified) // Add the "rewrites" attribute within "hosting" "rewrites": [ { "source": "/**", // the Dynamic Links start with "https://CUSTOM_DOMAIN/" "dynamicLinks": true } ] }
پیشوندهای مسیر دامنه سفارشی را برای استفاده برای پیوندهای پویا مشخص کنید
"hosting": { // ... "appAssociation": "AUTO", // required for Dynamic Links (default is AUTO if not specified) // Add the "rewrites" attribute within "hosting" "rewrites": [ { "source": "/promos/**", // the Dynamic Links start with "https://CUSTOM_DOMAIN/promos/" "dynamicLinks": true }, { "source": "/links/share/**", // the Dynamic Links start with "https://CUSTOM_DOMAIN/links/share/" "dynamicLinks": true } ] }
پیکربندی پیوندهای پویا در فایل firebase.json
به موارد زیر نیاز دارد:
رشته | شرح | |
---|---|---|
appAssociation | باید روی
| |
rewrites | ||
source | مسیری که می خواهید برای پیوندهای پویا استفاده کنید برخلاف قوانینی که مسیرهای URL را بازنویسی میکنند، قوانین بازنویسی برای پیوندهای پویا نمیتوانند شامل عبارات منظم باشند. | |
dynamicLinks | باید روی true تنظیم شود |
هدرها را پیکربندی کنید
اختیاری
هدرها به مشتری و سرور اجازه می دهند اطلاعات اضافی را همراه با درخواست یا پاسخ ارسال کنند. برخی از مجموعههای هدر میتوانند بر نحوه مدیریت مرورگر صفحه و محتوای آن، از جمله کنترل دسترسی، احراز هویت، حافظه پنهان و رمزگذاری تأثیر بگذارند.
با ایجاد یک ویژگی headers
که حاوی آرایه ای از اشیاء هدر است، سرصفحه های پاسخ سفارشی و خاص فایل را مشخص کنید. در هر شی، یک الگوی URL را مشخص کنید که اگر با مسیر URL درخواست مطابقت داشته باشد، میزبانی را برای اعمال هدرهای پاسخ سفارشی مشخص شده فعال می کند.
در اینجا ساختار اصلی برای ویژگی headers
آمده است. این مثال هدر CORS را برای همه فایل های فونت اعمال می کند.
"hosting": {
// ...
// Applies a CORS header for all font files
"headers": [ {
"source": "**/*.@(eot|otf|ttf|ttc|woff|font.css)",
"headers": [ {
"key": "Access-Control-Allow-Origin",
"value": "*"
} ]
} ]
}
"hosting": { // ... // Add the "headers" attribute within "hosting" "headers": [ { // Applies a CORS header for all font files "source": "**/*.@(eot|otf|ttf|ttc|woff|font.css)", "headers": [ { "key": "Access-Control-Allow-Origin", "value": "*" } ] }, { // Overrides the default 1 hour browser cache with a 2 hour cache for all image files "source": "**/*.@(jpg|jpeg|gif|png)", "headers": [ { "key": "Cache-Control", "value": "max-age=7200" } ] }, { // A regular expression-based rewrite equivalent to the above behavior "regex": ".+/\w+\.(jpg|jpeg|gif|png)$", "headers": [ { "key": "Cache-Control", "value": "max-age=7200" } ] }, { // Sets the cache header for 404 pages to cache for 5 minutes "source": "404.html", "headers": [ { "key": "Cache-Control", "value": "max-age=300" } ] } ] }
ویژگی headers
شامل آرایه ای از تعاریف است که در آن هر تعریف باید فیلدهای جدول زیر را شامل شود.
رشته | شرح | ||
---|---|---|---|
headers | |||
source (توصیه می شود)یا regex | یک الگوی URL که اگر با URL درخواست اولیه مطابقت داشته باشد، میزبانی را برای اعمال هدر سفارشی فعال می کند
برای ایجاد هدر متناسب با صفحه سفارشی 404 خود، از | ||
آرایه ای از headers (زیر) | هدرهای سفارشی که هاست در مسیر درخواست اعمال می کند هر عنوان فرعی باید شامل یک جفت | ||
key | نام هدر، برای مثال Cache-Control | ||
value | مقدار هدر، برای مثال max-age=7200 |
میتوانید در مورد Cache-Control
در بخش Hosting که ارائه محتوای پویا و میکروسرویسهای میزبانی را توضیح میدهد، اطلاعات بیشتری کسب کنید. همچنین میتوانید درباره سرصفحههای CORS اطلاعات بیشتری کسب کنید.
پسوندهای .html
کنترل کنید
اختیاری
ویژگی cleanUrls
به شما امکان می دهد کنترل کنید که آیا URL ها باید شامل پسوند .html
باشند یا نه.
هنگامی که true
، میزبانی به طور خودکار پسوند .html
را از URL های فایل آپلود شده حذف می کند. اگر یک پسوند .html
به درخواست اضافه شود، هاستینگ یک تغییر مسیر 301
به همان مسیر انجام می دهد اما پسوند .html
را حذف می کند.
در اینجا نحوه کنترل گنجاندن .html
در URL ها با گنجاندن ویژگی cleanUrls
آورده شده است:
"hosting": {
// ...
// Drops `.html` from uploaded URLs
"cleanUrls": true
}
اسلش های انتهایی را کنترل کنید
اختیاری
ویژگی trailingSlash
به شما امکان می دهد کنترل کنید که آیا URL های محتوای ثابت باید دارای اسلش های انتهایی باشند یا خیر.
- وقتی
true
، میزبانی URL ها را برای اضافه کردن یک اسلش دنباله هدایت می کند. - وقتی
false
، میزبانی URL ها را برای حذف یک اسلش دنباله هدایت می کند. - وقتی نامشخص باشد، میزبانی فقط از اسلش های انتهایی برای فایل های فهرست دایرکتوری استفاده می کند (مثلا
about/index.html
).
در اینجا نحوه کنترل اسلش های انتهایی با افزودن ویژگی trailingSlash
آورده شده است:
"hosting": {
// ...
// Removes trailing slashes from URLs
"trailingSlash": false
}
ویژگی trailingSlash
بر بازنویسی محتوای پویا که توسط توابع Cloud یا Cloud Run ارائه میشود، تأثیری ندارد.
تطبیق الگوی گلوب
گزینههای پیکربندی میزبانی Firebase از نماد تطبیق الگوی glob با extglob استفاده گستردهای میکنند، مشابه نحوه مدیریت Git با قوانین gitignore
و Bower که قوانین ignore
میشود. این صفحه ویکی مرجع دقیق تری است، اما در زیر توضیحاتی درباره نمونه های استفاده شده در این صفحه آورده شده است:
firebase.json
- فقط با فایلfirebase.json
در ریشه دایرکتوریpublic
مطابقت دارد**
- با هر فایل یا پوشه ای در یک زیر شاخه دلخواه مطابقت دارد*
- فقط فایل ها و پوشه های موجود در ریشه دایرکتوریpublic
را منطبق می کند**/.*
- با هر فایلی که با.
(معمولاً فایل های پنهان، مانند پوشه.git
) در یک زیر شاخه دلخواه**/node_modules/**
- با هر فایل یا پوشه ای در یک زیرشاخه دلخواه یک پوشهnode_modules
مطابقت دارد، که خود می تواند در یک زیر شاخه دلخواه دایرکتوریpublic
باشد.**/*.@(jpg|jpeg|gif|png)
- با هر فایلی در یک زیرشاخه دلخواه که دقیقاً با یکی از موارد زیر ختم می شود مطابقت دارد:.jpg
،.jpeg
،.gif
، یا.png
نمونه تنظیمات میزبانی کامل
در زیر یک مثال کامل از پیکربندی firebase.json
برای میزبانی Firebase آورده شده است. توجه داشته باشید که یک فایل firebase.json
میتواند شامل پیکربندیهایی برای سایر سرویسهای Firebase نیز باشد.
{
"hosting": {
"public": "dist/app", // "public" is the only required attribute for Hosting
"ignore": [
"firebase.json",
"**/.*",
"**/node_modules/**"
],
"redirects": [ {
"source": "/foo",
"destination": "/bar",
"type": 301
}, {
"source": "/firebase/**",
"destination": "https://www.firebase.com",
"type": 302
} ],
"rewrites": [ {
// Shows the same content for multiple URLs
"source": "/app/**",
"destination": "/app/index.html"
}, {
// Configures a custom domain for Dynamic Links
"source": "/promos/**",
"dynamicLinks": true
}, {
// Directs a request to Cloud Functions
"source": "/bigben",
"function": "bigben"
}, {
// Directs a request to a Cloud Run containerized app
"source": "/helloworld",
"run": {
"serviceId": "helloworld",
"region": "us-central1"
}
} ],
"headers": [ {
"source": "**/*.@(eot|otf|ttf|ttc|woff|font.css)",
"headers": [ {
"key": "Access-Control-Allow-Origin",
"value": "*"
} ]
}, {
"source": "**/*.@(jpg|jpeg|gif|png)",
"headers": [ {
"key": "Cache-Control",
"value": "max-age=7200"
} ]
}, {
"source": "404.html",
"headers": [ {
"key": "Cache-Control",
"value": "max-age=300"
} ]
} ],
"cleanUrls": true,
"trailingSlash": false,
// Required to configure custom domains for Dynamic Links
"appAssociation": "AUTO",
}
}