اگه به دنبال این هستید که بیشتر از قابلیتهای HTTP در پروژهها یا اپلیکیشنهاتون استفاده کنید، شاید با فیلدهای Trailer آشنا نباشید. اینها یکی از امکانات جذاب HTTP هستن که به شما اجازه میدن بعضی از هدرها رو بعد از ارسال بدنه پیام HTTP اضافه کنید. حالا چرا ممکنه به این قابلیت احتیاج پیدا کنید؟ خب، ممکنه زمانی وجود داشته باشه که بخواید اطلاعات بیشتری رو بعد از اینکه بخشی از داده ارسال شد، اضافه کنید. این میتونه در مدیریت دادههای بزرگ و یا زمانی که نیاز به حتماً داشتن اطمینان از اینکه ارسال اطلاعات به درستی انجام شده باشه، مفید باشه.
استفاده از فیلدهای Trailer معمولاً در HTTP/1.1 استفاده نمیشه و بیشتر برای HTTP/2 و بعد از اون مفیده. این به شما کمک میکنه که هدرهایی که به زمان بیشتری برای محاسبه نیاز دارن یا برای مرحله بعدی نقل و انتقال نیاز هستن رو داخل Trailer جای بدید. مثلاً فرض کنید اطلاعاتی دارید که نیاز به پردازش بعد از رسیدن پیام اصلی دارن، مثل امضاهای دیجیتال یا تجزیه و تحلیل دادهها.
یک نکته مهم اینه که باید حواسمون باشه از فیلدهای Trailer تنها زمانی استفاده کنیم که طرف گیرنده قادر به تفسیر و پردازش اونها باشه. یعنی اگه میخواهید از این قابلیت استفاده کنید، باید اطمینان حاصل کنید که زیرساخت طرف مقابل HTTP/2 یا نسخههای جدیدتر رو پشتیبانی میکنه.
حالا بیاید کمی بیشتر فنی بشیم و با یه مثال عملی استفاده از فیلدهای Trailer رو بررسی کنیم. در اینجا یه مثال ساده از نحوه تنظیم و استفاده از فیلدهای Trailer آورده شده:
GET /example HTTP/1.1
Host: example.com
TE: trailers
Transfer-Encoding: chunked
4
Wiki
5
pedia
0
Trailer: X-Custom-Header
X-Custom-Header: my-custom-value
توضیح خط به خط کد بالا:
GET /example HTTP/1.1
: درخواست HTTP نوع GET برای مسیر /example رو نشون میده. Host: example.com
: نشاندهنده دامنه یا آدرس وبسایت هدف هست. TE: trailers
: این خط مشخص میکنه که درخواستدهنده قابلیت پردازش فیلدهای Trailer رو داره. Transfer-Encoding: chunked
: انتقال به صورت قطعهای که امکان استفاده از فیلدهای Trailer رو فراهم میکنه. 4
: طول اولین قطعه داده که 4 بایت هست. Wiki
و pedia
: دادههای واقعی در هر قطعه. 0
: نشانه پایان دادههای قطعهای. Trailer: X-Custom-Header
: اعلام اینکه یک فیلد Trailer با عنوان X-Custom-Header اضافه خواهد شد. X-Custom-Header: my-custom-value
: مقدار واقعی فیلد Trailer که در نهایت اضافه شده است.