Taking Advantage of PHP's Built-in Server
PHP 5.4 built-in web server: simplified development and testing
PHP version 5.4 introduces a built-in web server designed for development and testing, allowing developers to write and test code without the need for a full LAMP configuration. This server can also be used to distribute portable web applications on CD-ROM, USB drive, or as desktop applications.
Key points:
- PHP built-in server is not used in production environments, and the PHP manual recommends not to use it in production environments.
- This server is best for development and testing, can be started from the command line, used to test the code, and shut down after completion.
- To use the built-in server, PHP 5.4 or higher must be installed. The server can be tested by creating a basic
index.php
file and starting the server from the command line. The server can be accessed from the local machine, any interface of the machine, or from a specific IP address. - The built-in server can be customized to build a portable personal development server, which helps quickly test applications. This custom server can handle routing, header, and HTTP errors and can be started from the application directory with one command.
Many people think PHP itself is a language designed for the web, which is not the case with other languages such as Python and Ruby, so it makes more sense to provide other languages with a basic server environment to help start web development. They would argue that PHP does not require a built-in server. In addition, most systems today have a personal web server preinstalled, or can be installed with a few commands or clicks. In fact, the PHP manual emphasizes that the new built-in server is for development purposes only and advises not to use it in production environments. Apart from one (shading the log output sent for the console), there is no special INI directive for it, and the overall tone of the document seems to be "We have a web server now, too, don't bother us anymore". Still, the server is implemented in version 5.4, and I think it is a valuable tool for both development and testing. For example, on my machine I use Apache preinstalled with OSX and use a custom configuration that suits my development style, but sometimes I want to try some new web applications. Using PHP's built-in server, I can test the application directly from my download or temporary directory and then move it to my regular environment only if I really need it. Well, it's not that simple at first, as many applications are written for Apache and use .htaccess
files and mod_rewrite
. But I'm sure someone (maybe one of you, why not?) would write an adapter for this feature and I want to be the first to test it. In this article, I will explain some basic usages of a new built-in server and show you how to build a portable personal development server that can be used to quickly test your application. I believe you are just as eager to start as I do, so let's get started!
Using the built-in server
You need to install PHP 5.4 or higher to use the built-in server. To verify your PHP version, call php -v
in your terminal. You can then determine if the server is available in your version by running php -h
and looking for server-specific -S
and -t
options. You can test the server by creating a basic phpinfo()
file in the current directory that contains the call to index.php
and start the server like this:
[ec2-user@ip-10-229-67-156 ~]$ php -S <localhost 或您的公网IP>:8080
In your browser, you should now be able to see what the built-in server provides.
Every time the client access, a new log line is written in the console window:
<code>[Sun Feb 26 18:55:30 2012] 80.180.55.37:36318 [200]: / [Sun Feb 26 18:56:23 2012] 80.180.55.37:36584 [200]: /</code>
Review PHP's command line options, which are used to specify the address the server will bind to. Its value can be: -S
- – The server is accessible only on local machines
localhost
- – The server can be accessed from any interface of the machine (wired or wireless)
0.0.0.0
Any of your public or private IP addresses – the server can only be accessed at specific addresses
Allows you to tell the server to locate its document root directory to another directory. For example: -t
[ec2-user@ip-10-229-67-156 ~]$ php -S <localhost 或您的公网IP>:8090 -t /home/ec2-user/public
or index.php
files. router.php
[ec2-user@ip-10-229-67-156 ~]$ php -S <localhost 或您的公网IP>:8080 -t /home/ec2-user/public public/index.php
...(The following content is similar to the original text, but the sentence structure, vocabulary and expression have been adjusted to keep the original text meaning unchanged)....
(The rest of the content is similar to the process, the original paragraph is pseudo-original, and the image position and format are not changed)
The above is the detailed content of Taking Advantage of PHP's Built-in Server. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics





Alipay PHP...

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...

How to debug CLI mode in PHPStorm? When developing with PHPStorm, sometimes we need to debug PHP in command line interface (CLI) mode...

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...
