„Perl Web Server Gateway Interface“ – Versionsunterschied
[gesichtete Version] | [gesichtete Version] |
Frupa (Diskussion | Beiträge) Link auf MetaCPAN |
Acky69 (Diskussion | Beiträge) K zus. Link, zus. Info, Ausdruck Markierung: Begriffsklärungsseiten-Links |
||
Zeile 14: | Zeile 14: | ||
|Website = [https://metacpan.org/pod/PSGI PSGI auf metacpan.org] |
|Website = [https://metacpan.org/pod/PSGI PSGI auf metacpan.org] |
||
}} |
}} |
||
Das '''Perl Web Server Gateway Interface''' ('''''PSGI''''') ist eine Schnittstelle zwischen [[Webserver]]n und [[Webanwendung]]en. |
Das '''Perl Web Server Gateway Interface''' ('''''PSGI''''') ist eine [[Schnittstelle]] zwischen [[Webserver]]n und in [[Perl (Programmiersprache)|Perl]] geschriebenen [[Webanwendung]]en. |
||
Inspiriert von Pythons |
Inspiriert von Pythons [[Web Server Gateway Interface|WSGI]] und Rubys [[Rack (Webserver-Interface)|Rack]] wurde es entwickelt, um die [[Plattformunabhängigkeit]] von Webanwendungen zu fördern und deren Erstellung zu vereinfachen. Es ist eine Art Nachfolger des [[Common Gateway Interface|CGI]]-Moduls, das seit Perl 5.22 nicht mehr im Core-Paket enthalten ist. |
||
PSGI-Server werden oft auch in Anlehnung an [[Servlet|Java Servlets]] ''PSGI Application Container'' genannt. |
PSGI-Server werden oft auch in Anlehnung an [[Servlet|Java Servlets]] ''PSGI Application Container'' genannt. |
||
== Unterschiede zum CGI == |
== Unterschiede zum CGI == |
||
Beim Standard-CGI werden die Daten (z. B. aus [[Webformular]]en) vom Webserver (z. B. [[Apache HTTP Server|Apache]]) via [[Umgebungsvariable]]n an den Perl-[[Interpreter]] übermittelt, der dafür immer wieder in einem neuen [[Prozess (Informatik)|Prozess]] starten muss. |
|||
Bei PSGI dagegen erhält jede Anwendung beim Aufruf eine [[Referenz (Programmierung)|Referenz]] auf einen [[Hashfunktion|Hash]]<nowiki></nowiki>wert (mit [[Variable]]n ähnlich wie bei CGI). Dabei ist der Webserver selbst entweder |
|||
* ein eigener voller Perl-Webserver (wie ''Starman'', ''plackup'' usw.), |
* ein eigener voller Perl-Webserver (wie ''Starman'', ''plackup'' usw.), |
||
* ein Perl-[[Daemon]], welcher von einem Webserver aufgerufen wird (wie ''[[FastCGI]]'') oder |
* ein Perl-[[Daemon]], welcher von einem Webserver aufgerufen wird (wie ''[[FastCGI]]'') oder |
||
* ein im Webserver eingebetteter Perl-Prozess (wie ''[[mod_perl]]''). |
* ein im Webserver eingebetteter Perl-Prozess (wie ''[[mod_perl]]''). |
||
CGI erwartet von den Applikationen |
CGI erwartet von den Applikationen, dass diese die [[HTTP-Header]] und den eigentlichen Inhalt nach [[Standard-Datenströme #STDOUT|STDOUT]] schreiben. Dagegen erwartet PSGI von den Anwendungen ein [[Feld (Datentyp)|Array]] mit drei Elementen, die u. a. den [[HTTP-Statuscode]] enthalten. |
||
PSGI wurde |
PSGI wurde bewusst ähnlich wie CGI aufgebaut, um einen Umstieg und eine Weiterverwendung von CGI-Anwendungen zu ermöglichen. |
||
== Verwendung == |
== Verwendung == |
||
Viele Perl-[[Web-Framework]]s verwenden PSGI, z. B. |
|||
* ''[[Catalyst Web Framework|Catalyst]]'' ([[British Broadcasting Corporation|BBC]] iPlayer)<ref>[http://www.catalystframework.org/#sites Catalyst] Sites (abgerufen im November 2015)</ref> |
|||
* ''[[Mason (Perl)|Mason]]/Poet'' ([[Amazon.com]], [[Delicious]], [[Hearst Corporation|Hearst Magazines]], DynDNS)<ref>[http://www.masonhq.com/sites Mason] Sites (abgerufen im November 2015)</ref> |
|||
* ''Dancer''. |
|||
== Beispiel == |
== Beispiel == |
||
Das folgende |
Das folgende Beispiel fügt jeder PSGI-Anwendung das [[Liste der HTTP-Headerfelder|HTTP-Header-Feld]] ''X-Hello-World'' hinzu (und gibt den Inhalt ''Hello World'' zurück an den Client). |
||
<syntaxhighlight lang="perl"> |
<syntaxhighlight lang="perl"> |
||
# $app ist eine einfache PSGI-Anwendung |
# $app ist eine einfache PSGI-Anwendung |
Version vom 15. Oktober 2022, 21:37 Uhr
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 |
Das Perl Web Server Gateway Interface (PSGI) ist eine Schnittstelle zwischen Webservern und in Perl geschriebenen Webanwendungen.
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
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
Viele Perl-Web-Frameworks verwenden PSGI, z. B.
- Catalyst (BBC iPlayer)[1]
- Mason/Poet (Amazon.com, Delicious, Hearst Magazines, DynDNS)[2]
- Dancer.
Beispiel
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
Weblinks
- 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)