Ein Modul zur Nutzung der Browscap.ini auf dem Apache 2 Webserver
Hier nun meine erste Variante eines Apache Moduls zur Nutzung der Browscap.ini Datei, sicherlich stehe ich mit diesem Projekt zur Zeit noch ganz am Anfang, da es mein erstes Apache Modul ist, welches ich mit Free Pascal unter Windows entwickele, was auch unter Linux laufen soll. Also das bedeutet Cross-Kompilieren ich habe mir die benötigten Dateien aus dem Unix /lib Verzeichnis besorgt und einfach kompiliert ob das nun von Erfolg gekrönt ist weiß ich nicht da mir zur Zeit keine unterschiedlichen Linux Testumgebungen zur Verfügung stehen, darum bin ich auf Eure Mithilfe angewiesen!
Doch nun zu meinem Ansatz, ich lade die browscap.ini die im Apache Verzeichnis liegen muss, während des Serverstarts in den Speicher und erzeuge eine vorsortierte Liste der Sections. Bei einer Abfrage wird der User-Agent aus dem Request-Header gelesen und mit Hilfe der geladenen Browscap.ini die Eigenschaften ermittelt. Anschließend werden ein paar von mir als relevant befundene Eckwerte dem Request-Header hinzugefügt, wodurch sie dann allen folgenden Aktionen zur Verfügung stehen. Falls jemand von Euch eine bessere Idee hat an welcher Stelle ich sonst die Werte für eine folgende Bearbeitung z.B. durch PHP zur verfügung stellen könnte immer heraus damit.
Schön wäre es natürlich die Werte in einer "Session"-Datei auf dem Server abzulegen und dann dem Header lediglich eine Cookie zu setzen der Auskunft über die Datei gibt.
Erforderliche Eintrag in der httpd.conf damit das Modul überhaupt geladen wird:
Aktivieren des Moduls, in einem Bereich <VirtualHost>, <Directory>, <Location>, <Files>, .htaccess (All) , damit es an dieser Stelle zum Einsatz kommt.
Die Apache Module .so Datei gehört in das /apache/modules Verzeichnis, hier zwei unterschiedliche Versionen, die erste Datei funktioniert in meiner lokalen UwAmp installation unter Windows, die zeite Datei ist ungetestet!
Download der browscap.ini von browscap.org die Variante der INI-Datei sollte egal sein. In der mod_browscap.ini muss der Pfad zur browscap.ini angepasst werden, das setzen von debug auf 1 oder 0 aktiviert oder deaktiviert die Debug-Zeilen in der Apache error.log. Die Zuordnung in der Section 'fields' steuert die Übergabe der Werte in Request-Header.
Ein Beipiel was unter PHP die von dem Modul zur Verfügung gestellten Werte ausgibt:
<?php echo 'client name: '.$_SERVER['HTTP_X_CLIENT_NAME'].'<br />'; echo 'client version: '.$_SERVER['HTTP_X_CLIENT_VERSION'].'<br />'; echo 'client is mobile device: '.$_SERVER['HTTP_X_CLIENT_IS_MOBILE_DEVICE'].'<br />'; echo 'client is tablet: '.$_SERVER['HTTP_X_CLIENT_IS_TABLET'].'<br />'; echo 'client is crawler: '.$_SERVER['HTTP_X_CLIENT_IS_CRAWLER'].'<br />'; ?>
Die Ausgabe:
client name: Firefox client version: 29.0 client is mobile device: false client is tablet: false client is crawler: false
Der Logfile Auszug:
[Tue May 27 01:26:20 2014] [notice] Apache/2.2.22 (Win32) PHP/5.3.25 configured -- resuming normal operations [Tue May 27 01:26:20 2014] [notice] Server built: Jan 28 2012 11:16:39 [Tue May 27 01:26:20 2014] [notice] Parent: Created child process 2416 [Tue May 27 01:26:20 2014] [debug] mpm_winnt.c(477): Parent: Sent the scoreboard to the child [Tue May 27 01:26:21 2014] [debug] mod_browscap.so(146): createDirConfig(C:/UwAmp/www/test/) [Tue May 27 01:26:21 2014] [debug] mod_browscap.so(182): createServerConfig(test.localhost) [Tue May 27 01:26:21 2014] [debug] mod_browscap.so(212): cmd_browscap() [Tue May 27 01:26:21 2014] [debug] mod_browscap.so(200): mergeServerConfig(SVR(),SVR(test.localhost)) [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(146): createDirConfig(C:/UwAmp/www/test/) [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(182): createServerConfig(test.localhost) [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(212): cmd_browscap() [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(200): mergeServerConfig(SVR(),SVR(test.localhost)) [Tue May 27 01:26:22 2014] [notice] Child 2416: Child process is running [Tue May 27 01:26:22 2014] [debug] mpm_winnt.c(398): Child 2416: Retrieved our scoreboard from the parent. [Tue May 27 01:26:22 2014] [info] Parent: Duplicating socket 220 and sending it to child process 2416 [Tue May 27 01:26:22 2014] [debug] mpm_winnt.c(595): Parent: Sent 1 listeners to child 2416 [Tue May 27 01:26:22 2014] [debug] mpm_winnt.c(554): Child 2416: retrieved 1 listeners from parent [Tue May 27 01:26:22 2014] [notice] Child 2416: Acquired the start mutex. [Tue May 27 01:26:22 2014] [notice] Child 2416: Starting 64 worker threads. [Tue May 27 01:26:22 2014] [notice] Child 2416: Starting thread to listen on port 80. [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(114): get header(User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:29.0) Gecko/20100101 Firefox/29.0) [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(127): add header(X-Client-Name: Firefox) [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(127): add header(X-Client-Version: 29.0) [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(127): add header(X-Client-Is-Mobile-Device: false) [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(127): add header(X-Client-Is-Tablet: false) [Tue May 27 01:26:22 2014] [debug] mod_browscap.so(127): add header(X-Client-Is-Crawler: false)
ToDo:
Überprüfen der auf Cookies basierenden Variante
Tests besonders unter UNIX/Linux
Der Quelltext:
Autor: Udo Schmal, veröffentlicht: , letzte Änderung:
Kontakt
Udo Schmal Softwareentwickler Ellerndiek 26 24837Schleswig Schleswig-Holstein Germany