appserver-io / webserver
Multithreaded webserver for php written in php
Installs: 5 644
Dependents: 1
Suggesters: 0
Security: 0
Stars: 45
Watchers: 14
Forks: 14
Open Issues: 9
Requires
- php: >=5.4.0
- appserver-io-psr/http-message: ~1.0
- appserver-io-psr/socket: ~1.0
- appserver-io/concurrency: ~0.1
- appserver-io/fastcgi: ~2.0
- appserver-io/http: ~2.0
- appserver-io/logger: ~2.0
- appserver-io/server: ~10.0
- psr/log: *
- rhumsaa/uuid: ~2.8
Requires (Dev)
- appserver-io/build: ~1.0
- dev-master
- 5.1.5
- 5.1.4
- 5.1.3
- 5.1.2
- 5.1.1
- 5.1.0
- 5.0.4
- 5.0.3
- 5.0.2
- 5.0.1
- 5.0.0
- 4.0.9
- 4.0.8
- 4.0.7
- 4.0.6
- 4.0.5
- 4.0.4
- 4.0.3
- 4.0.2
- 4.0.1
- 4.0.0
- 3.4.3
- 3.4.2
- 3.4.1
- 3.4.0
- 3.3.2
- 3.3.1
- 3.3.0
- 3.2.4
- 3.2.3
- 3.2.2
- 3.2.1
- 3.2.0
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.1
- 3.0.0
- 2.0.x-dev
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- 1.0.1
- 1.0.0
- 0.4.3
- 0.4.2
- 0.4.1
- 0.4.0
- 0.3.9
- 0.3.8
- 0.3.7
- 0.3.6
- 0.3.5
- 0.3.4
- 0.3.3
- 0.3.2
- 0.3.1
- 0.3.0
- 0.2.5
- 0.2.4
- 0.2.3
- 0.2.2
- 0.2.1
- 0.2.0
This package is auto-updated.
Last update: 2025-01-18 03:41:12 UTC
README
Introduction
Are you serious? A web server written in pure PHP for PHP? Ohhhh Yes! :) This is a HTTP/1.1 compliant webserver written in php. And the best... it has a php module and it's multithreaded!
We use this in the appserver.io
project as a server component for handling HTTP requests.
Installation
If you want to use the web server with your application add this
{ "require": { "appserver-io/webserver": "dev-master" } }
to your composer.json
and invoke composer update
in your project.
Usage
If you can satisfy the requirements it is very simple to use the webserver. Just do this:
git clone https://github.com/appserver-io/webserver
cd webserver
PHP_BIN=/path/to/your/threadsafe/php-binary bin/webserver
If you're using appserver.io
the start line will be:
bin/webserver
Goto http://127.0.0.1:9080 and if all went good, you will see the welcome page of the php webserver. It will startup on insecure http port 9080 and secure https port 9443.
To test a php script just goto http://127.0.0.1:9080/info.php and see what happens... ;)
Additionally you can pass two arguments to the startup script. The first one is the path to a custom configuration file, the second one to a custom autoloader file. For example, if you want to use your own configuration and autoloader files start the webserver with
bin/webserver path/to/your/configuration.xml path/to/your/autoloader.php
Both files can be absolute or relative to the webserver's root directory.
Please be aware, that the autoloader MUST be able to load the webserver classes too, as it is not complementary but a replacement for the default composer autoloader.
Semantic versioning
This library follows semantic versioning and its public API defines as follows:
- The public API, configuration and entirety of its modules
- The public interface of the
\AppserverIo\WebServer\ConnectionHandlers\HttpConnectionHandler
class - The public interfaces within the
\AppserverIo\WebServer\Interfaces
namespace
External Links
- Documentation at appserver.io