首页 > 编程 > PHP > 正文

PHP 5.4 内置web服务器

2019-11-11 07:40:41
字体:
来源:转载
供稿:网友


php是一种脚本语言,它需要PHP解释器来分析运行PHP文件。当把PHP做为CGI服务Web请求时,它需要被嵌入到某种Web服务器里,最常见的是集成到Apache或nginx或IIS等等web容器里,这就是说,在使用PHP前,你需要安装Apache或nginx或IIS,并且正确的配置它们和PHP集成的参数。虽然这种配置已经很规范,文档非常丰富,www.ttlsa.com网站内有大量的这些配置实例,可以参考参考。但我们还是经常在web服务如nginx与PHP集成时遇到问题,而且,有时候我们只想测试一个简单的PHP特征,不想就为此安装、启动相关web服务,如nginx。

据官方文档上说,这个内置的Web服务器只是提供开发测试使用,不推荐使用中生产环境中。因为这个服务器接受处理请求时顺序执行的,不能并发处理。

这个内置的web服务器使用起来非常的方便,你只需要执行下面的命令:

1# php -S localhost:8000

然后就可以访问了。这样启动后,默认的web服务目录是执行命令的当前目录,如果不想使用当前目录,你需要使用 -t 参数来指定。如

1# php -S localhost:8000 -t /data/webroot/www.ttlsa.com/webroot

例1: 启动Web服务器

1234# cd /data/webroot/www.ttlsa.com/webroot# php -S localhost:8000或# php -S localhost:8000 -t /data/webroot/www.ttlsa.com/webroot

如果在启动命令行后面附加一个php脚本文件,那这个文件将会被当成一个“路由器”脚本。这个脚本将负责所有的HTTP请求,如果这个脚本执行时返回FALSE,则被请求的资源会正常的返回。如果不是FALSE,浏览里显示的将会是这个脚本产生的内容。

例2: 使用路由器脚本在这个例子中,对图片的请求会返回相应的图片,但对HTML文件的请求会显示“Welcome to websit: www.ttlsa.com”:

12345678<?php// router.phpif(preg_match('//.(?:png|jpg|jpeg|gif)$/',$_SERVER["REQUEST_URI"])){    returnfalse;    // serve the requested resource as-is.}else {    echo"<p>Welcome to websit: www.ttlsa.com</p>";}?>

1# php -S localhost:8000 router.php

例3: 判断是否是在使用内置web服务器通过程序判断来调整同一个PHP路由器脚本在内置Web服务器中和在生产服务器中的不同行为:

1234567<?php// router.phpif(php_sapi_name()== 'cli-server'){/* route static assets and return false */}/* go on with normal index.php operations */?>

1# php -S localhost:8000 router.php

这个内置的web服务器能识别一些标准的MIME类型资源,它们的扩展有:.CSS, .gif, .htm, .html, .jpe, .jpeg, .jpg, .js, .png, .svg, and .txt。对.htm 和 .svg 扩展到支持是在PHP 5.4.4之后才支持的。

例4: 处理不支持的文件类型如果你希望这个Web服务器能够正确的处理不被支持的MIME文件类型,这样做:

1234567891011<?php// router.php$path= pathinfo($_SERVER["SCRIPT_FILENAME"]);    if($path["extension"]== "ogg"){    header("Content-Type: video/ogg");    readfile($_SERVER["SCRIPT_FILENAME"]);}else {    returnFALSE;}?>

1# php -S localhost:8000 router.php

例5: 远程访问这个内置Web服务器

1# php -S 0.0.0.0:8000

这样就可以通过8000端口远程的访问这个内置的web服务器了。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表