Cache-Control हेडर जनरेटर

सादे टॉगल और मानवीय समय इकाइयों से एक सही HTTP Cache-Control रिस्पॉन्स हेडर बनाएँ, सीधे अपने ब्राउज़र में।

आपका Cache-Control हेडर आपके चुने गए विकल्पों से आपके ब्राउज़र में स्थानीय रूप से इकट्ठा होता है, और जो आप कॉन्फ़िगर करते हैं वह किसी server पर अपलोड या स्टोर नहीं होता।

किसी server को सेट कर रहे हैं? nginx Config Generator आज़माएँ।

Cache-Control हेडर जनरेटर के बारे में

यह cache-control हेडर जनरेटर HTTP caching directives के भ्रमित करने वाले सेट को कुछ सादे टॉगल में बदल देता है। public या private, no-store, no-cache, must-revalidate, proxy-revalidate, या immutable को पलटें, और max-age, s-maxage, stale-while-revalidate और stale-if-error जैसे lifetimes को सेकंड गिनने के बजाय घंटों, दिनों या वर्षों जैसी मानवीय इकाइयों में सेट करें। जैसे-जैसे आप विकल्प बदलते हैं, टूल directives को canonical क्रम में संयोजित करता है, सादी भाषा में बताता है कि मौजूदा हेडर ठीक क्या करता है, और no-store के साथ max-age जैसे विरोधाभासी संयोजनों को चिह्नित करता है। Presets रोज़मर्रा के मामले कवर करते हैं: एक साल का immutable static asset, हमेशा-revalidate HTML, कभी-न-store private data, और एक विभाजित CDN-बनाम-browser नीति। raw हेडर या तैयार nginx, Apache और HTML meta स्निपेट कॉपी करें। सब कुछ आपके डिवाइस पर, ब्राउज़र में चलता है।

विशेषताएँ

Cache-Control हेडर जनरेटर का उपयोग कैसे करें

  1. एक preset चुनें या शुरू से शुरू करें और public या private चुनें।
  2. अपनी ज़रूरत के directives टॉगल करें, जैसे no-cache, must-revalidate या immutable।
  3. max-age जैसे lifetimes को एक संख्या और एक इकाई (घंटे, दिन, वर्ष) से दर्ज करें।
  4. बना हुआ हेडर मान और उसके नीचे की सादी-भाषा व्याख्या पढ़ें।
  5. raw हेडर या आपको जो nginx, Apache या HTML meta स्निपेट चाहिए उसे कॉपी करें।

उदाहरण

इनपुट

public + immutable + max-age = 1 year

आउटपुट

Cache-Control: public, max-age=31536000, immutable

क्लासिक fingerprinted static-asset नीति: एक साल के लिए cache करें और कभी revalidate न करें।

सामान्य त्रुटियाँ और समस्या निवारण

अक्सर पूछे जाने वाले प्रश्न

no-cache और no-store में क्या अंतर है?
no-store का मतलब है रिस्पॉन्स कभी किसी cache में नहीं लिखा जाना चाहिए, इसलिए हर अनुरोध origin पर वापस जाता है। no-cache रिस्पॉन्स स्टोर करने की अनुमति देता है, पर cache को इसे दोबारा परोसने से पहले origin के साथ revalidate करना होता है। no-store एक प्रति न रखने के बारे में है; no-cache हमेशा जाँचने के बारे में है कि रखी हुई प्रति अभी भी वर्तमान है।
Cache-Control हेडर में immutable क्या करता है?
immutable ब्राउज़र को बताता है कि संसाधन अपने max-age की अवधि में कभी नहीं बदलेगा, इसलिए यह revalidation छोड़ सकता है भले ही उपयोगकर्ता reload दबाए। यह app.9f2c.js जैसी versioned या fingerprinted फ़ाइलों के लिए है, जहाँ एक नया build पुराने को अधिलेखित करने के बजाय एक नए URL के तहत आता है।
max-age और s-maxage कैसे भिन्न हैं?
max-age तय करता है कि रिस्पॉन्स किसी भी cache में, ब्राउज़र सहित, कितनी देर fresh रहता है। s-maxage max-age को ओवरराइड करता है पर केवल CDNs और proxies जैसे shared caches के लिए। दोनों सेट करने से आप रिस्पॉन्स को ब्राउज़र में थोड़ी देर cache कर सकते हैं जबकि इसे अपने CDN पर अधिक देर रख सकते हैं।
मुझे public बनाम private कब उपयोग करना चाहिए?
public, CDNs और proxies जैसे shared caches को ब्राउज़र के साथ रिस्पॉन्स स्टोर करने देता है। private स्टोरेज को व्यक्तिगत उपयोगकर्ता के ब्राउज़र तक सीमित करता है, जो व्यक्तिगत या authenticated रिस्पॉन्स के लिए सही विकल्प है जिन्हें किसी shared cache से दूसरे उपयोगकर्ता को नहीं परोसा जाना चाहिए।
stale-while-revalidate क्या करता है?
stale-while-revalidate एक cache को थोड़ा stale रिस्पॉन्स तुरंत परोसने देता है जबकि यह पृष्ठभूमि में एक fresh प्रति लाता है। उपयोगकर्ताओं को तुरंत रिस्पॉन्स मिलता है और cache अगले अनुरोध के लिए खुद को अपडेट कर लेता है, जो किसी संसाधन के समाप्त होने के क्षण को सहज बना देता है।
क्या मेरी कॉन्फ़िगरेशन किसी server पर भेजी जाती है?
नहीं। हेडर, व्याख्या और स्निपेट सभी आपके ब्राउज़र में इकट्ठे होते हैं जैसे-जैसे आप विकल्प टॉगल करते हैं, इसलिए कॉन्फ़िगरेशन आपके डिवाइस पर स्थानीय रूप से प्रोसेस होती है और कुछ भी अपलोड नहीं होता।

संबंधित टूल

सभी ArrayKit टूल