登录
首页 >  文章 >  java教程

UbuntuNginx+PHP404错误?快速排查解决方法!

时间:2025-03-12 17:12:34 103浏览 收藏

Ubuntu下Nginx部署PHP项目时,404错误是常见问题。本文以一个案例分析解决方法:开发者在8088端口部署项目,所有接口均返回404。经排查发现,Nginx配置文件中监听端口与实际端口不符,且PHP处理配置错误。核心问题在于`location`块和`fastcgi`指令配置不正确,导致Nginx无法正确处理PHP请求。文章提供一个修正后的Nginx配置文件示例,并详细解释`root`、`fastcgi_pass`、`rewrite`指令及端口号设置的关键点,帮助开发者快速解决此类问题。 如问题依旧,建议检查PHP-FPM日志获取更多信息。

Ubuntu下Nginx部署PHP项目出现404错误如何解决?

在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已正确安装和启动。

如果问题依然存在,检查PHP-FPM日志文件获取更多错误信息。仔细核对配置文件中的路径和端口设置,确保与项目结构和PHP-FPM配置匹配。

到这里,我们也就讲完了《UbuntuNginx+PHP404错误?快速排查解决方法!》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>