Я столкнулся с проблемой с nginx.
Я хотел бы выделить два случая:
Во-первых, если URL-адрес запроса соответствует / api / (*.), Я хочу вернуть api / index.php
В противном случае, если URL не совпадает, public / index.php должен быть возвращен.
Я пробовал несколько решений, в том числе:
Кто-то может объяснить мне, как этого добиться?
Спасибо 🙂
Мои файлы организованы так:
/var/www/html
|
_ api
| |
| _ index.php
|
|_ public
|
_ index.php
|
_ js
|
_ index.js
Вот моя конфигурация сервера:
server {
listen 80;
server_name _;
index index.php;
rewrite_log on;location / {
root /var/www/html/public;
try_files $uri $uri/ /index.php$is_args$args;
location ~ \.php {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php7.1-fpm.sock;
}
}
location ^~ /api {
root /var/www/html/api;
try_files $uri $uri/ /index.php$is_args$args;
error_log /var/log/nginx/admin-error.log debug;
location ~ \.php {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php7.1-fpm.sock;
}
}
}
Содержимое фрагментов / fastcgi-php.conf:
# regex to split $uri to $fastcgi_script_name and $fastcgi_path
fastcgi_split_path_info ^(.+\.php)(/.+)$;
# Check that the PHP script exists before passing it
try_files $fastcgi_script_name =404;
# Bypass the fact that try_files resets $fastcgi_path_info
# see: http://trac.nginx.org/nginx/ticket/321
set $path_info $fastcgi_path_info;
fastcgi_param PATH_INFO $path_info;
fastcgi_index index.php;
include fastcgi.conf;
А вот файл admin-error.log:
2017/08/14 18:53:31 [debug] 20331#20331: *75 http cl:-1 max:1048576
2017/08/14 18:53:31 [debug] 20331#20331: *75 rewrite phase: 3
2017/08/14 18:53:31 [debug] 20331#20331: *75 post rewrite phase: 4
2017/08/14 18:53:31 [debug] 20331#20331: *75 generic phase: 5
2017/08/14 18:53:31 [debug] 20331#20331: *75 generic phase: 6
2017/08/14 18:53:31 [debug] 20331#20331: *75 generic phase: 7
2017/08/14 18:53:31 [debug] 20331#20331: *75 access phase: 8
2017/08/14 18:53:31 [debug] 20331#20331: *75 access phase: 9
2017/08/14 18:53:31 [debug] 20331#20331: *75 access phase: 10
2017/08/14 18:53:31 [debug] 20331#20331: *75 post access phase: 11
2017/08/14 18:53:31 [debug] 20331#20331: *75 try files phase: 12
2017/08/14 18:53:31 [debug] 20331#20331: *75 http script var: "/api"2017/08/14 18:53:31 [debug] 20331#20331: *75 trying to use file: "/api""/var/www/html/api/api"2017/08/14 18:53:31 [debug] 20331#20331: *75 http script var: "/api"2017/08/14 18:53:31 [debug] 20331#20331: *75 trying to use dir: "/api""/var/www/html/api/api"2017/08/14 18:53:31 [debug] 20331#20331: *75 http script copy: "/index.php"2017/08/14 18:53:31 [debug] 20331#20331: *75 http script var: ""2017/08/14 18:53:31 [debug] 20331#20331: *75 trying to use file:
"/index.php" "/var/www/html/api/index.php"2017/08/14 18:53:31 [debug] 20331#20331: *75 internal redirect:
"/index.php?"
nginx version: nginx/1.12.1
Эта конфигурация работает 🙂
server {
listen 80;
server_name _;
index index.php;
rewrite_log on;
root /var/www/html;location / {
try_files $uri /public/index.php$is_args$args;
}
location ^~ /api {
try_files $uri /api/index.php$is_args$args;
location ~ \.php {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php7.1-fpm.sock;
}
}
location ~ \.php {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php7.1-fpm.sock;
}
}
Других решений пока нет …