Perl Web Server Gateway Interface

Das Perl Web Server Gateway Interface (PSGI) ist eine Schnittstelle zwischen Webservern und in Perl geschriebenen Webanwendungen.

PSGI: Perl Web Server Gateway Interface
Basisdaten

Entwickler Tatsuhiko Miyagawa und andere
Aktuelle Version 1.102
Betriebssystem plattformunabhängig
Programmiersprache Perl
Kategorie Middleware
Lizenz Creative Commons by-sa
PSGI auf metacpan.org

Inspiriert von Pythons WSGI und Rubys Rack wurde es entwickelt, um die Plattformunabhängigkeit von Webanwendungen zu fördern und deren Erstellung zu vereinfachen. Es ist eine Art Nachfolger des CGI-Moduls, das seit Perl 5.22 nicht mehr im Core-Paket enthalten ist.

PSGI-Server werden oft auch in Anlehnung an Java Servlets PSGI Application Container genannt.

Unterschiede zum CGI Bearbeiten

Beim Standard-CGI werden die Daten (z. B. aus Webformularen) vom Webserver (z. B. Apache) via Umgebungsvariablen an den Perl-Interpreter übermittelt, der dafür immer wieder in einem neuen Prozess starten muss.

Bei PSGI dagegen erhält jede Anwendung beim Aufruf eine Referenz auf einen Hashwert (mit Variablen ähnlich wie bei CGI). Dabei ist der Webserver selbst entweder

  • ein eigener voller Perl-Webserver (wie Starman, plackup usw.),
  • ein Perl-Daemon, welcher von einem Webserver aufgerufen wird (wie FastCGI) oder
  • ein im Webserver eingebetteter Perl-Prozess (wie mod_perl).

CGI erwartet von den Applikationen, dass diese die HTTP-Header und den eigentlichen Inhalt nach STDOUT schreiben. Dagegen erwartet PSGI von den Anwendungen ein Array mit drei Elementen, die u. a. den HTTP-Statuscode enthalten.

PSGI wurde bewusst ähnlich wie CGI aufgebaut, um einen Umstieg und eine Weiterverwendung von CGI-Anwendungen zu ermöglichen.

Verwendung Bearbeiten

Viele Perl-Web-Frameworks verwenden PSGI, z. B.

Beispiel Bearbeiten

Das folgende Beispiel fügt jeder PSGI-Anwendung das HTTP-Header-Feld X-Hello-World hinzu (und gibt den Inhalt Hello World zurück an den Client).

# $app ist eine einfache PSGI-Anwendung
my $app = sub {
    my $env = shift;
    return [ '200',
             [ 'Content-Type' => 'text/plain' ],
             [ "Hello World" ] ];
};

# $xheader ist ein Stück sogenannte Middleware um $app herum
my $xheader = sub {
    my $env = shift;
    my $res = $app->($env);
    push @{$res->[1]}, 'X-Hello-World' => 1;
    return $res;
};

Einzelnachweise Bearbeiten

  1. Catalyst Sites (abgerufen im November 2015)
  2. Mason Sites (abgerufen im November 2015)

Weblinks Bearbeiten

  • PSGI auf metacpan.org (englisch)
  • Johnson, Lee: Documentation for alternative solutions to CGI.pm (auf CPAN, engl., abgerufen im November 2015)
  • Miyagawa, Tatsuhiko: Vortrag (Slides) auf der O’Reilly OSCON im Juli 2010 (engl., abgerufen im November 2015)
  • PSGI/Plack, Superglue interface between perl web application frameworks and web servers, just like Perl is the duct tape of the internet. (engl., abgerufen im November 2015)