2012-03-09 10 views
5

Czy można używać pamięci podręcznej sprawdzania poprawności w ESI z Symfony 2?Edge Side Includes i pamięć podręczna weryfikacji w Symfony 2

Jeśli spojrzeć klasę HttpFoundation Response, można zobaczyć, jak isNotModified działa:

/** 
* Determines if the Response validators (ETag, Last-Modified) match 
* a conditional value specified in the Request. 
* 
* If the Response is not modified, it sets the status code to 304 and 
* removes the actual content by calling the setNotModified() method. 
* 
* @param Request $request A Request instance 
* 
* @return Boolean true if the Response validators match the Request, false otherwise 
* 
* @api 
*/ 
public function isNotModified(Request $request) 
{ 
    $lastModified = $request->headers->get('If-Modified-Since'); 
    $notModified = false; 
    if ($etags = $request->getEtags()) { 
     $notModified = (in_array($this->getEtag(), $etags) || in_array('*', $etags)) && (!$lastModified || $this->headers->get('Last-Modified') == $lastModified); 
    } elseif ($lastModified) { 
     $notModified = $lastModified == $this->headers->get('Last-Modified'); 
    } 

    if ($notModified) { 
     $this->setNotModified(); 
    } 

    return $notModified; 
} 

Problemem jest to, że ESI $ request-> headers-> get ('If-Modified-Since'); i $ request-> getEtags() nie zwracają nic w ESI ... więc pamięć podręczna nigdy nie jest świeża!

Masz więc rozwiązanie dla zapytania $?

Jeśli weryfikacja pamięci podręcznej HTTP nie może działać w ESI, czy istnieje inny sposób buforowania częściowego?

Dziękujemy!

Odpowiedz

1

Nie użyłem ESI z Symfony2 (jeszcze) - ale artykuł z dokumentacją Symfony2 Using Edge Side Includes wydaje się sugerować, że jest to dość prosty proces.

+0

Tak, z pamięcią podręczną ważności jest to naprawdę łatwe i działa! Ale wygląda na to, że nie działa przy korzystaniu z pamięci podręcznej sprawdzania poprawności ... więc próbowałem go debugować i wydaje się, że nie jest możliwe ... – Sybio

Powiązane problemy