使用Nginx,fastcgi和php设置开发环境时,我从php服务器收到“无效请求(格式错误的HTTP请求)”

前端之家收集整理的这篇文章主要介绍了使用Nginx,fastcgi和php设置开发环境时,我从php服务器收到“无效请求(格式错误的HTTP请求)” 前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在设置一个使用Nginx的开发环境,并使用fastcgi将请求转发到命令行PHP服务器.当我直接向PHP服务器发送请求时,它会正确处理它们. Nginx服务器可以正确处理对非PHP文件的请求.但是,当我通过Nginx发送PHP请求时,PHP服务器被命中,但返回“无效请求(格式错误的HTTP请求)”.

抱歉附加所有配置文件,但我不确定从哪里开始.所有文件都位于$PROJECT_PATH / dev-config /中.

这是我的Nginx配置的相关部分.

  1. http {
  2. ...
  3. server {
  4. root .;
  5. listen 8123;
  6. server_name localhost;
  7. location / {
  8. index index.PHP;
  9. }
  10. location ~ \.PHP${
  11. try_files $fastcgi_script_name =404;
  12. fastcgi_param SCRIPT_FILENAME $request_filename;
  13. fastcgi_pass 127.0.0.1:9123;
  14. fastcgi_index index.PHP;
  15. include fastcgi_params; # this file is the default
  16. }
  17. }
  18. }

这是运行(重新)启动NginxPHP的脚本:

  1. #!/bin/bash
  2. PROJECT_PATH="$(dirname $0)/../"
  3. Nginx -s stop || true
  4. Nginx -c dev-config/Nginx.conf -p $PROJECT_PATH
  5. PHP -c PHP-dev.ini -t $PROJECT_PATH -S 127.0.0.1:9123

我发送的文件是test.PHP

  1. <? echo 'YAY!' ?>

在我的Nginx错误日志中,我收到如下消息:

  1. 2017/10/27 08:12:56 [error] 68934#0: *1 upstream prematurely closed connection while reading response header from upstream,client: 127.0.0.1,server: localhost,request: "GET /test.PHP HTTP/1.1",upstream: "fastcgi://127.0.0.1:9123",host: "localhost:8123"

同时,PHP正在发送如下消息:

  1. [Fri Oct 27 08:12:56 2017] 127.0.0.1:52470 Invalid request (Malformed HTTP request)

这表明该请求由Nginx处理,并继续发送到PHP服务器.但是该请求在某种程度上是不正确的.

>如何发送格式正确的请求?
>或者,如果现在无法告诉我,我该怎么做才能从PHP获得有关请求的确切信息,确切的说,是什么?

明确地说,这是要在笔记本电脑的开发环境中运行,而每个用户的配置都不会更改.

最佳答案
我遇到的问题是命令行PHP服务器没有运行fastcgi.由于命令行服务器已经是服务器,因此我完全不需要fastcgi.相反,我可以proxy_pass到它.

我将PHP位置块更改为此,并且它起作用了:

  1. location ~ \.PHP${
  2. proxy_pass http://127.0.0.1:9123;
  3. }

猜你在找的Nginx相关文章