配置nginx支持PATH_INFO

解决Nginx下路径解析问题:自定义解析路径信息
本文将详细说明如何在Nginx环境下解决无法获取path_info的问题,通过自定义配置实现路径信息的正确解析,确保ThinkPHP或CI框架下页面的正常访问。

apache下path_info是可以直接取到,但nginx下就比较蛋疼了,对于thinkphp或CI来说更是如此,path_info是取不到的,路由不正常所以很多页面都会404,据说用fix_pathinfo的方法会有安全问题,因此让nginx自己解析吧,这是示例~

server {
    listen       80;
    server_name  admin.test.com;

    root /Users/ha/www/html/test/admin.test.com/;

        location / {
                if (!-e $request_filename) {
                        rewrite  ^/(.*)$  /index.php/$1  last;
                        break;
                }
        }

location ~ \.php {
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_index index.php;
        include /usr/local/etc/nginx/fastcgi.conf;
        set $real_script_name $fastcgi_script_name;
        if ($fastcgi_script_name ~ "^(.+?\.php)(/.+)$") {
                set $real_script_name $1;
                set $path_info $2;
        }
        fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
        fastcgi_param SCRIPT_NAME $real_script_name;
        fastcgi_param PATH_INFO $path_info;
}


}

如果只应用于特定host 则不需要修改fastcgi.conf的配置文件,别忘记重新加载nginx配置

nginx -s reload


### 配置 `client_body_temp_path` 并设置文件夹权限 Nginx 在处理客户端请求体时,若请求体大小超过 `client_body_buffer_size` 的设置值,则会将请求体写入临时文件中,这些文件的存储路径由 `client_body_temp_path` 指定。为确保 Nginx 能正常写入临时文件,需正确配置该路径并设置合适的访问权限。 #### 配置 `client_body_temp_path` `client_body_temp_path` 可在 `http`、`server` 或 `location` 块中定义,用于指定客户端请求体的临时存储目录。该路径支持最多三层子目录结构,以提高文件访问效率。例如: ```nginx http { client_body_temp_path /var/nginx/client_body 1 2; } ``` 上述配置中,`/var/nginx/client_body` 是主目录,其下可创建最多两层子目录结构,临时文件路径可能为 `/var/nginx/client_body/7/45/00000123457`。此设置适用于大多数生产环境,但需确保目录存在并具有正确权限[^3]。 #### 设置目录权限 为避免权限问题,应确保 Nginx 进程对该路径具有读写权限。通常,Nginx 以 `nginx` 用户身份运行(也可能为 `www-data` 或其他用户),因此需更改目录所属用户和组: ```bash mkdir -p /var/nginx/client_body chown nginx:nginx /var/nginx/client_body chmod 700 /var/nginx/client_body ``` 若 Nginx 以其他用户运行,则需将 `nginx` 替换为实际运行用户。权限设置为 `700` 表示仅该用户可访问,若需更宽松的权限,可设置为 `755`,但需注意安全性影响。 若 Nginx 启动失败并提示 `Permission denied` 错误,可能是因为临时目录权限不足,或 SELinux、AppArmor 等安全模块限制了访问。可通过临时禁用这些模块进行排查: - **SELinux**: ```bash setenforce 0 ``` - **AppArmor**: ```bash systemctl stop apparmor ``` 排查确认后,应根据实际情况调整安全策略,而非长期禁用。 #### 配置建议与注意事项 - `client_body_buffer_size` 应根据实际业务需求调整,避免频繁写入临时文件影响性能。例如,上传大文件时可适当增大缓冲区大小: ```nginx location /upload { client_body_buffer_size 32k; } ``` - 若临时文件写入失败,Nginx 将返回 500 错误。可通过日志文件 `error.log` 查看具体错误信息,结合 `access.log` 和后端服务日志进行综合分析[^4]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值