Toon posts:

[PHP] php image caching

Pagina: 1
Acties:

Onderwerpen


Anoniem: 414074

Topicstarter
Al geruime tijd ben ik aan het proberen de afbeeldingen die ik weergeef d.m.v. PHP op mijn website te cachen d.m.v. een 304 not modified header. Op tweakers.net staan hier ook al verschillende topics over, maar maar met die v.b. kwam ik er niet uit en ook met bijv. http://dtbaker.com.au/ran...ges-generated-by-php.html niet omdat ik simpelweg nooit de IF_MODIFIED_SINCE header krijg meegestuurd.

Foto's op mijn website geef ik weer d.m.v. /foto/[id]/[breedte][locatie]image.[ext]. Werkt perfect en wanneer de afbeelding niet bestaat wordt die "on the fly" aangemaakt.

Op apache niveau heb ik zowel mod_expires als mod_headers ingesteld:
http://www.askapache.com/...caching-with-both-modules

Omdat ik met bovenstaande aangeef dat alles wat .php te maken heeft niet gecached heeft heb ik het PHP bestand waarmee ik de foto's weergeef als test veranderd in foto.phpc en .phpc ook laten parsen door PHP.

Daarmee krijg ik de volgende headers in FIREBUG terug:

Antwoordheadersbron bekijken
Date	Thu, 07 Jul 2011 06:14:02 GMT
Server	Apache
Last-Modified	Wed, 06 Jul 2011 19:14:59 GMT
Cache-Control	max-age=0, private, no-store, no-cache, must-revalidate
Pragma	no-cache
Etag	"fd27e16d4d166e74df9c9e30a8aa50f6"
Content-Length	426761
Keep-Alive	timeout=4, max=100
Connection	Keep-Alive
Content-Type	image/jpeg
Verzoekheadersbron bekijken
Host	[host]
User-Agent	Mozilla/5.0 (Windows NT 6.1; WOW64; rv:5.0) Gecko/20100101 Firefox/5.0
Accept	image/png,image/*;q=0.8,*/*;q=0.5
Accept-Language	nl,en-us;q=0.7,en;q=0.3
Accept-Encoding	gzip, deflate
Accept-Charset	ISO-8859-1,utf-8;q=0.7,*;q=0.7
Connection	keep-alive
Referer	[host]
Cookie	__utma=7044652.1757543232.1309953137.1309979647.1309988720.3; __utmz=7044652.1309953137.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none);PHPSESSID=b5e57cf1ff759d90dc541214291129f7; __utmc=7044652
Authorization	Basic YWRtaW46YWRtaW4=
Cache-Control	max-age=0


en wanneer ik in de headers van bijv. een js bestand kijk zie ik wel netjes de IF_NOT_MODIFIED_SINCE header en die bestanden krijgen ook allemaal een 304 header:
If-Modified-Since Wed, 06 Jul 2011 17:25:38 GMT
If-None-Match "12d824f-1eb-4a769e38e4880"

Terwijl ik in mijn foto.php (bestand wat dus de foto's toont) ook het volgende heb staan:
PHP:
1
2
3
4
5
6
7
$request_headers=apache_request_headers();  
header('ETag: "' . $etag . '"');
        if (@strtotime($request_headers['HTTP_IF_MODIFIED_SINCE']) == $last_modified_time || 
            trim($request_headers['HTTP_IF_NONE_MATCH']) == $etag) { 
            header("HTTP/1.1 304 Not Modified"); 
            exit; 
        }


Wat doe ik verkeerd waardoor ik de HTTP_IF_MODIFIED_SINCE && HTTP_IF_NONE_MATCH nooit mee krijg?

  • _Rene_
  • Registratie: Augustus 2009
  • Laatst online: 22-05 22:00
Waar definieer je $last_modified_time en $etag ? Op php.net stond eenzelfde stukje code, wel met deze twee gedefinieerd.

Verder vond ik deze op php.net. Op deze manier moet het ook wel lukken volgens mij.(gewoon copypaste scriptje die je miss zelf ook wel gevonden had.)

PHP:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
 
<?php
   // Test image.
    $fn = '/test/foo.png';

    // Getting headers sent by the client.
    $headers = apache_request_headers();

    // Checking if the client is validating his cache and if it is current.
    if (isset($headers['If-Modified-Since']) && (strtotime($headers['If-Modified-Since']) == filemtime($fn))) {
        // Client's cache IS current, so we just respond '304 Not Modified'.
        header('Last-Modified: '.gmdate('D, d M Y H:i:s', filemtime($fn)).' GMT', true, 304);
    } else {
        // Image not cached or cache outdated, we respond '200 OK' and output the image.
        header('Last-Modified: '.gmdate('D, d M Y H:i:s', filemtime($fn)).' GMT', true, 200);
        header('Content-Length: '.filesize($fn));
        header('Content-Type: image/png');
        print file_get_contents($fn);
    }
?>

Anoniem: 414074

Topicstarter
Die definieer ik zo:
PHP:
1
2
$etag = md5_file($photo); 
$last_modified_time = filemtime($photo);


Jouw voorbeeld zou werken wanneer de IF_MODIFIED_SINCE header gevuld zou zijn, maar dat is bij mij dus niet het geval. Die bestaat niet en daar zit het probleem. Waarom bestaat die niet.

  • CodeCaster
  • Registratie: Juni 2003
  • Niet online

CodeCaster

Can I get uhm...

Anoniem: 414074 schreef op donderdag 07 juli 2011 @ 09:22:
Die definieer ik zo:
PHP:
1
2
$etag = md5_file($photo); 
$last_modified_time = filemtime($photo);


Jouw voorbeeld zou werken wanneer de IF_MODIFIED_SINCE header gevuld zou zijn, maar dat is bij mij dus niet het geval. Die bestaat niet en daar zit het probleem. Waarom bestaat die niet.
Ja, bijna. Jij controleert op HTTP_IF_MODIFIED_SINCE, en _Rene_ heeft het over IF_MODIFIED_SINCE. Zoek de verschillen.

Wat geeft een dump van de request-headers?

[Voor 5% gewijzigd door CodeCaster op 07-07-2011 09:25]

https://oneerlijkewoz.nl
I have these thoughts / so often I ought / to replace that slot / with what I once bought / 'cause somebody stole my car radio / and now I just sit in silence


Anoniem: 414074

Topicstarter
Sorry, ik zat te slapen ;-)

Een dump van de headers geeft dit:

PHP:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Array
(
    [Host] => [host]
    [User-Agent] => Mozilla/5.0 (Windows NT 6.1; WOW64; rv:5.0) Gecko/20100101 Firefox/5.0
    [Accept] => text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
    [Accept-Language] => nl,en-us;q=0.7,en;q=0.3
    [Accept-Encoding] => gzip, deflate
    [Accept-Charset] => ISO-8859-1,utf-8;q=0.7,*;q=0.7
    [Connection] => keep-alive
    [Cookie] => __utma=7044652.1757543232.1309953137.1309988720.1310023626.4; __utmz=7044652.1309953137.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none); PHPSESSID=f955a8c2746978b081e8326c9372c721; __utmc=7044652; __utmb=7044652.1.10.1310023626
    [Authorization] => Basic YWRtaW46YWRtaW4=
    [Pragma] => no-cache
    [Cache-Control] => no-cache
)


Hier geeft hij dus ook aan dat hij hem niet wil cachen doordat zowel Pragma als Cache-Control op no-cache staan. Dat komt denk ik doordat ik in de apache config heb aangegeven dat PHP-bestanden niet gecached mogen worden (zie topic start), maar het bestand wat deze foto weergeeft is nu een phpc bestand die door PHP verwerkt wordt. Je zou dan denken dat die no-cache daar geen betrekking op heeft of klopt mijn aanname niet?

edit:
dat Pragma en Cache-control op no-cache staan komt denk ik doordat ik contrl. f5 gebruikt. Ik krijg nu namelijk dit terug:
PHP:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Array
(
    [Host] => [host]
    [User-Agent] => Mozilla/5.0 (Windows NT 6.1; WOW64; rv:5.0) Gecko/20100101 Firefox/5.0
    [Accept] => text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
    [Accept-Language] => nl,en-us;q=0.7,en;q=0.3
    [Accept-Encoding] => gzip, deflate
    [Accept-Charset] => ISO-8859-1,utf-8;q=0.7,*;q=0.7
    [Connection] => keep-alive
    [Referer] => [host]
    [Cookie] => __utma=7044652.1757543232.1309953137.1309988720.1310023626.4; __utmz=7044652.1309953137.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none);PHPSESSID=b5e57cf1ff759d90dc541214291129f7; __utmc=7044652
    [Authorization] => Basic YWRtaW46YWRtaW4=
    [Cache-Control] => max-age=0
)

[Voor 25% gewijzigd door Anoniem: 414074 op 07-07-2011 10:06]


Anoniem: 414074

Topicstarter
O.a. door de reactie van _Rene_ toch opgelost. De fout zat hem toch in /foto/. foto.php was een symbolic link naar de core foto.phpc (let op de c want die wordt dus niet gecached), maar omdat de bron foto.php heette gaf apache nog steeds de no-cache headers mee. Nu heb ik de symbolic link naam gewijzigd van foto.php naar foto.phpc en nu krijg ik netjes de If-Modified-Since header mee.

Dank!

  • _Rene_
  • Registratie: Augustus 2009
  • Laatst online: 22-05 22:00
Super! Oplossingen zijn vaak simpeler dan je in eerste instantie denkt ;)
Pagina: 1


Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee