PHP-FPM всегда возвращает 200 независимо от кода состояния NGINX

У меня есть конфигурация страницы ошибок на основе PHP с NGINX и PHP-FPM. Однако, когда я запрашиваю, например, example.com/nothing (несуществующая страница), PHP-FPM возвращает код состояния 200, а не правильный код состояния 404, который возвращает NGINX. Это также происходит с другими ошибками (например: example.com/assets возвращая 200 с PHP-FPM, когда статус равен 403 с NGINX). По сути, я хочу, чтобы PHP-FPM отображал код состояния, показанный NGINX (переопределите код состояния 200 на код, показанный NGINX), поэтому на моих страницах ошибок отображается правильная информация. Я знаю, что вы можете изменить код состояния, указав его при использовании http_response_code();, но я бы предпочел, чтобы сервер делал это, не заставляя меня жестко кодировать правильный код состояния.

Страница ошибки: <? echo http_response_code(); ?>

Конфигурация страницы ошибки NGINX:

set $errorDocs "/var/www/GLOBAL_RESOURCES/error";
recursive_error_pages on;
location ^~ $errorDocs {
internal;
alias $errorDocs;
}
#Resolve error asset location 404s
location /errorAssets {
root $errorDocs;
}
error_page 404 /404.php;
location = /404.php {
root $errorDocs;
include /etc/nginx/xenon-conf/headers/fpm-params.conf;
}

Настройки PHP-FPM:

include /etc/nginx/fastcgi_params;
include /etc/nginx/fastcgi.conf;
fastcgi_intercept_errors on;
proxy_intercept_errors on;
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass  unix:/var/run/php-fpm/www.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

Fast-CGI Config:

fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;
fastcgi_param  QUERY_STRING       $query_string;
fastcgi_param  REQUEST_METHOD     $request_method;
fastcgi_param  CONTENT_TYPE       $content_type;
fastcgi_param  CONTENT_LENGTH     $content_length;

fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;
fastcgi_param  REQUEST_URI        $request_uri;
fastcgi_param  DOCUMENT_URI       $document_uri;
fastcgi_param  DOCUMENT_ROOT      $document_root;
fastcgi_param  SERVER_PROTOCOL    $server_protocol;
fastcgi_param  REQUEST_SCHEME     $scheme;
fastcgi_param  HTTPS              $https if_not_empty;

fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;
fastcgi_param  SERVER_SOFTWARE    nginx;

fastcgi_param  REMOTE_ADDR        $remote_addr;
fastcgi_param  REMOTE_PORT        $remote_port;
fastcgi_param  SERVER_ADDR        $server_addr;
fastcgi_param  SERVER_PORT        $server_port;
fastcgi_param  SERVER_NAME        $server_name;

# PHP only, required if PHP was built with --enable-force-cgi-redirect
#fastcgi_param  REDIRECT_STATUS    200;

Конфигурация сайта:

server {
listen 80;
server_name example.com www.example.com;
access_log /var/log/nginx/example.com.access.log;
include /etc/nginx/xenon-conf/headers/php-fpm-enable.conf;
include /etc/nginx/xenon-conf/headers/master-failover.conf;

set $webRoot "/var/www/example.com";
root $webRoot;
}

Конфигурация NGINX:

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

# Load dynamic modules. See /usr/share/doc/nginx/README.dynamic.
include /usr/share/nginx/modules/*.conf;

events {
worker_connections 1024;
}

http {
log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';

access_log  /var/log/nginx/access.log  main;

sendfile            on;
tcp_nopush          on;
tcp_nodelay         on;
keepalive_timeout   65;
types_hash_max_size 4096;

include             /etc/nginx/mime.types;
default_type        application/octet-stream;

# Load modular configuration files from the /etc/nginx/conf.d directory.
# See http://nginx.org/en/docs/ngx_core_module.html#include
# for more information.
include /etc/nginx/conf.d/*.conf;

### CUSTOM HTTP SERVER MASS IMPORTS ###
include /etc/nginx/xenon-conf/websites/*.web;
include /etc/nginx/xenon-conf/mapping/*.map;
}

### CUSTOM GENERIC STREAM MASS IMPORTS ###
include /etc/nginx/xenon-conf/stream/*.conf;

Заранее спасибо!

2

Решение

Если nginx обнаруживает выходные данные из восходящего потока FastCGI, он будет
рассматривать его как действительный ответ, даже если восходящий поток (в этом случае
php-fpm) вызвало ошибку.

Отключение display_errors в пуле PHP-FPM это исправляет.

php_admin_value[display_errors] = Off Это предотвращает PHP-скрипт от
вывод ошибки на экран, что в свою очередь приводит к тому, что nginx
правильно выдает HTTP 500 Internal Server Error.

$  curl -i localhost:8080/test.php?time=`date +%s` HTTP/1.1 500
Internal Server Error Server: nginx ...

(ничего не отображается, пустой ответ) Вы все еще можете записать все ошибки в
файл с директивой error_log.

php_admin_value[error_log] = /var/log/php-fpm/error.log
php_admin_flag[log_errors] = on

Источник

Для того, чтобы передать коды состояния HTTP из nginx в PHP-FPM, вам также необходимо поместить следующее в ваше местоположение обработки PHP:

fastcgi_intercept_errors on;

Согласно руководство, эта директива:

Определяет, должны ли ответы сервера FastCGI с кодами, большими или равными 300, передаваться клиенту или перехватываться и перенаправляться в nginx для обработки с помощью директивы error_page.

3

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]