(转载)nginx下支持PATH_INFO详解

本文介绍了如何让Nginx支持PHP的PATH_INFO功能,包括PATH_INFO的基本概念、作用及在ThinkPHP等框架中的应用。此外,还提供了Nginx配置示例,展示了如何通过rewrite规则或fastcgi_split_path_info指令实现PATH_INFO的支持。

原文地址:http://www.nginx.cn/426.html

要想让nginx支持PATH_INFO,首先需要知道什么是pathinfo,为什么要用pathinfo?

pathinfo不是nginx的功能,pathinfo是php的功能。

php中有两个pathinfo,一个是环境变量$_SERVER['PATH_INFO'];另一个是pathinfo函数,pathinfo() 函数以数组的形式返回文件路径的信息;。

nginx能做的只是对$_SERVER['PATH_INFO]值的设置。

下面我们举例说明比较直观。先说php中两种pathinfo的作用,再说如何让nginx支持pathinfo。

php中的两个pathinfo

php中的pathinfo()

pathinfo()函数可以对输入的路径进行判断,以数组的形式返回文件路径的信息,数组包含以下元素。

  • [dirname]  路径的目录
  • [basename] 带后缀 文件名
  • [extension]  文件后缀
  • [filename]  不带后缀文件名(需php5.2以上版本)

例如
[php]
<?php
print_r(pathinfo("/nginx/test.txt"));
?>
[/php]
输出

php中的$_SERVER['PATH_INFO']

PHP中的全局变量$_SERVER['PATH_INFO'],PATH_INFO是一个CGI 1.1的标准,经常用来做为传参载体。

被很多系统用来优化url路径格式,最著名的如THINKPHP框架。

对于下面这个网址:

http://www.test.cn/index.php/test/my.html?c=index&m=search

我们可以得到 $_SERVER['PATH_INFO'] = ‘/test/my.html’,而此时 $_SERVER['QUERY_STRING'] = 'c=index&m=search';

如果不借助高级方法,php中http://www.test.com/index.php?type=search 这样的URL很常见,大多数人可能会觉得不太美观而且对于搜索引擎也是非常不友好的(实际上有没有影响未知),因为现在的搜索引擎已经很智能了,可以收入带参数的后缀网页,不过大家出于整洁的考虑还是想希望能够重写URL,

下面是一段解析利用PATH_INFO的进行重写的非常简单的代码:
[php]
<?php
if(!isset($_SERVER['PATH_INFO']))
{
$pathinfo = 'default';
}
else{
$pathinfo = explode('/', $_SERVER['PATH_INFO']);
}

if(is_array($pathinfo) && !empty($pathinfo))
{
$page = $pathinfo[1];
}
else
{
$page = 'default.php';
}
?>
[/php]
有了以上认识我们就可以介入nginx对$_SERVER['PATH_INFO']支持的问题了。在这之前还要介绍一个php.ini中的配置参数cgi.fix_pathinfo,它是用来对设置cgi模式下为php是否提供绝对路径信息或PATH_INFO信息。没有这个参数之前PHP设置绝对路径PATH_TRANSLATED的值为SCRIPT_FILENAME,没有PATH_INFO值。设置这个参数为cgi.fix_pathinfo=1后,cgi设置完整的路径信息PATH_TRANSLATED的值为SCRIPT_FILENAME,并且设置PATH_INFO信息;如果设为cgi.fix_pathinfo=0则只设置绝对路径PATH_TRANSLATED的值为SCRIPT_FILENAME。cgi.fix_pathinfo的默认值是1。

nginx默认是不会设置PATH_INFO环境变量的的值,需要php使用cgi.fix_pathinfo=1来完成路径信息的获取,但同时会带来安全隐患,需要把cgi.fix_pathinfo=0设置为0,这样php就获取不到PATH_INFO信息,那些依赖PATH_INFO进行URL美化的程序就失效了。

1.可以通过rewrite方式代替php中的PATH_INFO

实例:thinkphp的pathinfo解决方案
设置URL_MODEL=2

2.nginx配置文件中设置PATH_INFO值
请求的网址是/abc/index.php/abc

PATH_INFO的值是/abc
SCRIPT_FILENAME的值是$doucment_root/abc/index.php
SCRIPT_NAME /abc/index.php

旧版本的nginx使用如下方式配置

新版本的nginx也可以使用fastcgi_split_path_info指令来设置PATH_INFO,旧的方式不再推荐使用,在location段添加如下配置。

 

最后可能有人要问为什么apache不会出现这个问题?

apache一般是以模块的方式运行php,apache可以对$_SERVER['PATH_INFO']的值进行设置,不需要另外配置。

### Nginx 配置指令 全局块 详细解释 以下是 Nginx 配置指令中全局块相关参数的详细解释: #### 1. `--prefix` `--prefix` 参数用于指定 Nginx 的安装目录。所有文件和子目录将默认安装到此路径下,除非其他参数另行指定[^1]。 例如:`--prefix=/usr/local/nginx` 表示 Nginx 将安装在 `/usr/local/nginx` 目录下。 #### 2. `--pid-path` `--pid-path` 参数用于设置 Nginx 主进程 PID 文件的存放路径。PID 文件记录了主进程的进程 ID,便于通过脚本或命令管理 Nginx 的启动、停止和重启操作[^2]。 例如:`--pid-path=/usr/local/nginx/logs/nginx.pid` 表示 PID 文件将存储在 `/usr/local/nginx/logs/nginx.pid` 路径下。 #### 3. `--error-log-path` `--error-log-path` 参数用于指定错误日志的存放路径。错误日志记录了 Nginx 运行过程中发生的错误信息,有助于排查问题[^4]。 例如:`--error-log-path=/usr/local/nginx/logs/error.log` 表示错误日志将存储在 `/usr/local/nginx/logs/error.log` 路径下。 #### 4. `--http-log-path` `--http-log-path` 参数用于指定 HTTP 访问日志的存放路径。访问日志记录了客户端对 Nginx 的每次请求信息,包括请求时间、IP 地址、请求 URL 等[^1]。 例如:`--http-log-path=/usr/local/nginx/logs/access.log` 表示访问日志将存储在 `/usr/local/nginx/logs/access.log` 路径下。 #### 5. `--with-http_ssl_module` `--with-http_ssl_module` 参数用于启用 HTTP SSL 模块,支持 HTTPS 协议。该模块允许 Nginx 使用 SSL/TLS 加密通信,确保数据传输的安全性[^2]。 例如:`--with-http_ssl_module` 启用了 SSL 支持。 #### 6. `--with-http_gzip_static_module` `--with-http_gzip_static_module` 参数用于启用静态文件压缩模块。该模块允许 Nginx 自动检测并提供预压缩的 `.gz` 文件,从而减少带宽消耗并提高页面加载速度[^3]。 例如:`--with-http_gzip_static_module` 启用了静态文件压缩功能。 --- ### 示例代码 以下是一个完整的 `configure` 命令示例: ```bash ./configure \ --prefix=/usr/local/nginx \ --pid-path=/usr/local/nginx/logs/nginx.pid \ --error-log-path=/usr/local/nginx/logs/error.log \ --http-log-path=/usr/local/nginx/logs/access.log \ --with-http_ssl_module \ --with-http_gzip_static_module ``` --- ### 注意事项 - 如果未正确配置临时文件路径(如 `--http-client-body-temp-path`),可能会导致大文件上传失败或性能下降。 - 在编译时如果遇到类似 `undefined reference to 'pcre_malloc'` 的错误,通常是因为缺少 PCRE 库或其版本不兼容。需要确保系统已安装正确的 PCRE 库,并在编译前检查版本是否符合要求。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值