在Ubuntu系统中使用Nginx部署PHP项目时,404错误是一个常见问题。本文将分析一个案例,并提供有效的解决方案。该案例中,开发者在8088端口部署项目时,所有接口均返回404,即使修改配置文件也未能解决。
开发者提供的Nginx配置文件片段显示其尝试在80端口部署,与问题描述中的8088端口不符。配置文件的核心问题在于PHP处理配置。
正确配置的关键在于location
块和fastcgi
指令。以下是一个修正后的配置文件示例:
server { listen 80; # 需根据实际情况修改为8088 server_name www.h5fiction1.com; root "D:/project/h5_fiction_1/public"; # 确保路径正确指向项目public目录 location / { index index.html index.htm index.php; #autoindex on; if (!-e $request_filename) { rewrite ^(.*)$ /index.php?s=/$1 last; break; } } location ~ .php(.*)$ { fastcgi_pass 127.0.0.1:9000; # 确保PHP-FPM监听此端口 fastcgi_index index.php; fastcgi_split_path_info ^((?U).+.php)(/?.+)$; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info; include fastcgi_params; } }
关键点:
root
指令: 必须准确指向你的PHP项目public
目录(包含index.php
)。fastcgi_pass
指令: 指向PHP-FPM监听的地址和端口(通常是127.0.0.1:9000
,但需根据实际情况调整)。rewrite
指令: 如果你的项目使用如ThinkPHP6等框架并有路由规则,则可能需要调整此指令以匹配你的路由。listen
指令中的端口号必须与实际监听端口一致(80或8088)。如果问题依然存在,检查PHP-FPM日志文件获取更多错误信息。仔细核对配置文件中的路径和端口设置,确保与项目结构和PHP-FPM配置匹配。