Aracılığıyla paylaş


HttpRequestCacheLevel Sabit listesi

Tanım

Köprü Metni Aktarım protokolü (HTTP) kullanılarak elde edilen kaynaklar için önbelleğe alma davranışını belirtir.

public enum class HttpRequestCacheLevel
public enum HttpRequestCacheLevel
type HttpRequestCacheLevel = 
Public Enum HttpRequestCacheLevel
Devralma
HttpRequestCacheLevel

Alanlar

Name Değer Description
Default 0

Kaynağın önbelleğe alınmış kopyasını kullanarak veya sunucuya kaynak için bir istek göndererek bir kaynak isteğini karşılar. Gerçekleştirilen eylem geçerli önbellek ilkesine ve önbellekteki içeriğin yaşına göre belirlenir. Bu, çoğu uygulama tarafından kullanılması gereken önbellek düzeyidir.

BypassCache 1

Sunucuyu kullanarak bir isteği karşılar. Önbelleklerden hiçbir girdi alınmaz, önbelleklere eklenmez veya istemci ile sunucu arasındaki önbelleklerden kaldırılmaz. Önbelleklerden hiçbir girdi alınmaz, önbelleklere eklenmez veya istemci ile sunucu arasındaki önbelleklerden kaldırılmaz. Bu, .NET Framework ile birlikte gelen makine yapılandırma dosyasında belirtilen varsayılan önbellek davranışıdır.

CacheOnly 2

Yerel olarak önbelleğe alınmış kaynağı kullanarak bir isteği karşılar; önbellekte olmayan bir öğe için istek göndermez. Bu önbellek ilkesi düzeyi belirtildiğinde, öğe istemci önbelleğinde değilse bir WebException özel durum oluşturulur.

CacheIfAvailable 3

Kaynak kullanılabilir durumdaysa önbellekten bir kaynak isteğini karşılar; aksi takdirde, sunucuya bir kaynak isteği gönderir. İstenen öğe istemci ile sunucu arasındaki herhangi bir önbellekte kullanılabiliyorsa, istek ara önbellek tarafından karşılanmış olabilir.

Revalidate 4

Önbellekteki kaynağın kopyasını sunucudaki kopyayla karşılaştırır. Sunucudaki kopya daha yeniyse, isteği karşılamak için kullanılır ve önbellekteki kopyanın yerini alır. Önbellekteki kopya sunucu kopyasıyla aynıysa, önbelleğe alınan kopya kullanılır. HTTP önbelleğe alma protokolünde bu, bir koşullu istek kullanılarak elde edilir.

Reload 5

Sunucuyu kullanarak bir isteği karşılar. Yanıt önbelleğe kaydedilebilir. HTTP önbelleğe alma protokolünde bu, önbelleksiz önbellek denetimi yönergesi ve önbelleksiz Pragma üst bilgisi kullanılarak elde edilir.

NoCacheNoStore 6

Önbellekteki kaynakları kullanarak hiçbir zaman bir isteği karşılar ve kaynakları önbelleğe almaz. Kaynak yerel önbellekte varsa kaldırılır. Bu ilke düzeyi, ara önbelleklere kaynağı kaldırmaları gerektiğini gösterir. HTTP önbelleğe alma protokolünde bu, önbelleksiz önbellek denetimi yönergesi kullanılarak elde edilir.

CacheOrNextCacheOnly 7

Yerel bilgisayarın önbelleğinden veya yerel ağ üzerindeki uzak önbellekten bir kaynak isteğini karşılar. İstek karşılanamazsa bir WebException özel durum oluşturulur. HTTP önbelleğe alma protokolünde bu, önbellek denetimi yönergesi only-if-cached kullanılarak elde edilir.

Refresh 8

Sunucuyu veya yerel önbellek dışında bir önbelleği kullanarak isteği karşılar. İsteğin bir ara önbellek tarafından karşılanabilmesi için önce bu önbelleğin önbelleğe alınmış girdisini sunucuyla yeniden doğrulaması gerekir. HTTP önbelleğe alma protokolünde bu, max-age = 0 önbellek denetimi yönergesi ve önbelleksiz Pragma üst bilgisi kullanılarak elde edilir.

Örnekler

Aşağıdaki kod örneği, uygulama etki alanının önbelleğe alma ilkesini Varsayılan olarak ayarlar.

// The following method demonstrates overriding the
// caching policy for a request.
public static WebResponse GetResponseNoCache(Uri uri)
{
    // Set a default policy level for the "http:" and "https" schemes.
    HttpRequestCachePolicy policy = new HttpRequestCachePolicy(HttpRequestCacheLevel.Default);
    HttpWebRequest.DefaultCachePolicy = policy;
    // Create the request.
    WebRequest request = WebRequest.Create(uri);
    // Define a cache policy for this request only.
    HttpRequestCachePolicy noCachePolicy = new HttpRequestCachePolicy(HttpRequestCacheLevel.NoCacheNoStore);
    request.CachePolicy = noCachePolicy;
    WebResponse response = request.GetResponse();
    Console.WriteLine("IsFromCache? {0}", response.IsFromCache);
    return response;
}

Açıklamalar

Bu numaralandırma, nesneler tarafından HttpRequestCachePolicy belirtilen önbellek düzeyini ayarlamak için kullanılır.

Bu BypassCache değer, .NET Framework ile birlikte gelen makine yapılandırma dosyasında belirtilen varsayılan önbellek davranışıdır. Önbelleklerden hiçbir girdi alınmaz, önbelleklere eklenmez veya istemci ile sunucu arasındaki önbelleklerden kaldırılmaz.

HttpWebRequest.DefaultCachePolicy özelliği, örnekler için varsayılan önbellek ilkesini almak veya ayarlamak için HttpWebRequest kullanılır. WebRequest.DefaultCachePolicy özelliği, bir WebRequest örneğin varsayılan önbellek ilkesini almak veya ayarlamak için kullanılır. CachePolicy özelliği, belirli bir istek için önbellek ilkesini almak veya ayarlamak için kullanılır.

Bir kaynağın kopyası yalnızca kaynağın yanıt akışı alınır ve akışın sonuna okunursa önbelleğe eklenir. Bu nedenle, aynı kaynak için başka bir istek, bu isteğin varsayılan önbellek ilkesi düzeyine bağlı olarak önbelleğe alınmış bir kopya kullanabilir.

Şunlara uygulanır

Ayrıca bkz.