Call PHP from virtual/custom "web server"
Asked Answered
M

2

5

Basically, I'm trying to figure out how PHP can be called from a "web server".

I've read the documentation, but it didn't help much.

As far as I can tell, there are three ways to invoke PHP:

  • via command line (eg: php -f "/path/to/script.php")
  • via CGI(??) / via FastCGI (???)
  • via a web server (eg: Apache) module

So let's start with CGI. Maybe I'm just blind, but the spec doesn't mention how on Earth the web server passes data (headers & callbacks) to the thing implementing CGI. The situation is even worse with FastCGI.

Next up, we have server-specific modules, which, I don't even know what to search for since all leads end up nowhere.

Modest answered 12/8, 2011 at 23:35 Comment(7)
Have you considered reading the code? All of these things in your question are open source.Fortunate
@Dan I'm trying to do that right now. But it's proving difficult for several reasons: (1) I can't find all the code (2) the code is in c/c++ (3) the code is very old and/or messy.Modest
@Dan says who?? I could do it in Assembler or ADA if I wanted to (or FPC, which I'm planning to).Modest
Yelling at the wind won't help you. tools.ietf.org/html/draft-robinson-www-interface-00Fortunate
Here is a CGI module written in PHP, might be easier to follow than the typical guides: code.google.com/p/nanoweb-instant/source/browse/work/five_tani/… - Don't bother with FastCGI, not worth the effort (and PHP doesn't support the simpler SCGI.)Misleading
@Dan - Seen that already, see my 3rd para.Modest
@Misleading - Thanks, excellent response, as always.Modest
M
7

Invoking a CGI script is pretty simple. PHP has a few peculiarities, but you basically only need to setup a list of environment variables, then call the PHP-CGI binary:

setenv GATEWAY_INTERFACE="CGI/1.1"
setenv SCRIPT_FILENAME=/path/to/script.php
setenv QUERY_STRING="id=123&name=title&parm=333"
setenv REQUEST_METHOD="GET"
...

exec /usr/bin/php-cgi

Most of them are boilerplate. SCRIPT_FILENAME is how you pass the actual php filename to the PHP interpreter, not as exec parameter. Crucial for PHP is also the non-standard variable REDIRECT_STATUS=200.

For a GET request you only need the environment variables. For a POST request, you simply pipe the HTTP request body as stdin to the executed php-cgi binary. The returned stdout is the CGI response consisting of an incomplete HTTP header, \r\n\r\n, and the page body.

(Just from memory. There maybe a few more gotchas.)

Misleading answered 13/8, 2011 at 0:7 Comment(1)
I faced the issue then you need to populate PATH_INFO and SCRIPT_PATH variables explicitly. Please check my question for detailsLeucomaine
K
1

FastCGI is probably the best option since it's so wisely used, it would give you language independence (you could drop in Ruby later, for example) and it's well documented with lots of examples.

You could write your own Server API if you really want, but it's trickier than implementing FastCGI and has several disadvantages.

I wouldn't bother at all with straight CGI, FastCGI exists for a reason.

Kathie answered 13/8, 2011 at 0:5 Comment(3)
OK, how does the web server do IPC with the PHP executable? local(loopback) connection?Modest
@Modest it could be on a different host (an arbitrary TCP/IP connection) or at the other end of a unix pipe. Do read the spec I linked to, it's quite plainly written.Kathie
I'll give it a good look after a few hours' sleep. It's 2:30am already :/Modest

© 2022 - 2024 — McMap. All rights reserved.