Michael Schröpl: Apache / mod_headers: Header von CGI-Skripten umschreiben

Beitrag lesen

Hallo Leute,

ich versuche gerade, den Apache zu überreden, den HTTP-Header eines CGI-Skripts zu modifizieren.

Das dabei verwendete Modul "mod_headers" zeigt sich allerdings ein wenig störrisch für meinen Geschmack (und meine Kenntnisse in C und Apache-API sind zu erbärmlich, mehr als nur einzelne Zeilen im Quelltext zu ändern und zu sehen, was das bewirkt).

Was ich prima hinkriege, ist das Hinzufügen einzelner Header - sowohl durch explizite Angabe als auch durch implizite (auch mod_expires sitzt mit im Boot - mod_headers alleine kann nur statische Header bauen, und das alleine würde mir nur dann reichen, wenn es keine HTTP/1.0-Clients auf dieser Welt gäbe ...).

Was aber nicht so recht klappen will, ist das Entfernen von HTTP-Headern, welche bereits von dem besagten CGI-Skript erzeugt werden.

Dieses Skript generiert u. a. gzip-komprimierte Ausgaben und realtime-Informationen. Deshalb erzeugt es die beiden ziemlich defensiven HTTP-Header

Cache-Control: no-cache
   Expires: Fri, 22 Aug 1997 11:00:00 GMT

und damit ist "Ende Gelände" für jegliches Caching, egal ob im Browser oder im Proxy-Server.

Nun weiß ich selbst allerdings sehr viel genauer, wann sich der Inhalt der erzeugten Ausgaben dafür eignet, gecached zu werden.
Deshalb möchte ich in bestimmten Fällen diese Header umschreiben:

<Location /das/boese/skript>
    Header         unset     "Cache-control:"
    Header         unset     "Expires:"
    ExpiresDefault "access plus 12 hours"
  </Location>

(ExpiresDefault nehme ich, weil ich ExpiresByType nicht nehmen will - den MIME-Typ dieses Skripts weiß ich nicht sicher genug. Es scheint zwar "text/html" zu sein, aber die entsprechende ExpiresByType-Direktive hat keinen Effekt.)
Ich habe unterschiedliche Locations für verschiedene Instanzen des Skripts, welche ich als Apache-Handler an Dokumente unterschiedlicher Caching-Klassen binde.
(Das wirkt dann so ähnlich, als wenn *.shtml ein SSI-Dokument mit Caching-Befugnis wäre und *.ssi ein SSI-Dokument mit echt dynamischen Daten - nur so als Anschauungsbeispiel. Bei mir sind es halt eigene Dokumentklassen.)

Das Ergebnis ist leider für meine Zwecke bisher unzureichend:

  • ExpiresDefault erzeugt zwar brav sein
      "Cache-Control:" (dem ich per Quelltext-Änderung
      in mod_expires noch schnell ein "private," verpaßt
      habe) und ein "Expires:", aber
  • die beiden "Header unset" haben keinerlei erkennbaren
      Effekt.
    "Header unset" angewendet auf Header, welche ich selbst zuvor per "Header set" erzeugt habe, funktioniert allerdings durchaus.
    Bloß an die Header des CGI-Skripts komme ich nicht ran.

Und die "Location" wird auch wirklich betreten, wie ich an den anderen Header-Modifikationen erkennen kann (ich setze u. a. einen Phantasie-Header, nur um genau das überprüfen zu können).

Als Ergebnis entsteht ein HTTP-Header mit _zwei_ Headern jedes dieser beiden Typen ... und den möchte ich den armen Browsern ungerne um die Ohren hauen.

Deshalb nun meine Fragen:

  • Hat jemand vielleicht schon mal erfolgreich
      mod_headers eingesetzt, um den Inhalt der HTTP-Header
      eines CGI-Skripts (!) nachträglich zu beeinflussen?
  • Hat jemand eine Idee, was ich verkehrt mache?

Viele Grüße
      Michael
(der sich bewußt ist, daß dies hier ein exotisches Randgebiet ist ... aber die Hoffnung stirbt zuletzt)

P.S.: Nein, ich kann _nicht_ einfach das Skript
      umschreiben. Definitiv nicht. Selbst mit UNIX-
      "strings" war in dem Binary nichts zu finden,
      was patchable ausgesehen hätte. :-(