Итак, я пытаюсь установить новый сайт drupal 6 на nginx. Я успешно настроил файлы conf и db. Когда я пытаюсь получить доступ mysite.com
чтобы я мог следовать пошаговому руководству по установке, оно правильно перенаправляет на mysite.com/install.php
но возвращает 403 запрещенную ошибку.
В моем файле conf я попытался добавить свой IP-адрес в список разрешенных IP-адресов:
location = /install.php {
allow 127.0.0.1;
allow my_ip_address;
deny all;
}
Но затем, когда я пытаюсь получить доступ mysite.com/install.php
, браузер загружает файл вместо его запуска. Что я должен делать?
Я мог бы использовать drush для установки нового сайта, но вместо этого я хотел использовать файл install.php drupal (чтобы показать другу, как это делается).
Спасибо.
server {
server_name www.mysite.com;
return 301 $scheme://mysite.com$request_uri;
} # server domain return.
server {
server_name mysite.com;
root /var/www/mysite.com;
index index.html index.htm index.php;
access_log /var/log/nginx/mysite.access.log;
error_log /var/log/nginx/mysite.error.log;
location = /favicon.ico {
log_not_found off;
access_log off;
}
location = /robots.txt {
allow all;
log_not_found off;
access_log off;
}
# For drush
location = /backup {
deny all;
}
# Prevent user from accessing settings.php directly
location ~ ^/sites/[^/]+/settings.php$ {
deny all;
}
## Replicate the Apache <FilesMatch> directive of Drupal standard
## .htaccess. Disable access to any code files. Return a 404 to curtail
## information disclosure. Hide also the text files.
location ~* ^(?:.+\.(?:htaccess|make|txt|log|engine|inc|info|install|module|profile|po|sh|.*sql|theme|tpl(?:\.php)?|xtmpl)|code-style\.pl|/Entries.*|/Repository|/Root|/Tag|/Template)$ {
return 404;
}
location ~ \..*/.*\.php$ {
return 403;
}
location / {
# This is cool because no php is touched for static content
try_files $uri @rewrite;
}
location @rewrite {
# Some modules enforce no slash (/) at the end of the URL
# Else this rewrite block wouldn't be needed (GlobalRedirect)
#rewrite ^/(.*)$ /index.php?q=$1&$args;
rewrite ^ /index.php last;
}
# Use an SSH tunnel to access those pages. They shouldn't be visible to
# external peeping eyes.
location = /install.php {
allow 127.0.0.1;
deny all;
}
location = /update.php {
allow 127.0.0.1;
deny all;
}
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
#NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_intercept_errors on;
#fastcgi_pass unix:/var/run/php5-cgi/php5.sock;
fastcgi_pass unix:/var/run/php5-fpm.sock;
}
## Drupal 7 generated image handling, i.e., imagecache in core. See:
## https://drupal.org/node/371374
location ~* /sites/.*/files/styles/ {
access_log off;
expires 30d;
try_files $uri @rewrite;
}
# Fighting with ImageCache? This little gem is amazing.
location ~ ^/sites/.*/files/imagecache/ {
try_files $uri @rewrite;
}
location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
expires max;
log_not_found off;
}
}
Ваш явный location = /install.php
перекрывает любые другие location
директивы. За исключением редких случаев, nginx сопоставляет запрос только с одним location
.
Таким образом, ваш запрос соответствует location = /install.php
. Но он не содержит никаких директив для отправки запроса в php-fpm, поэтому он обрабатывается как статический файл и отправляется в браузер.
Нет смысла иметь это location
вообще. Вы должны удалить install.php
файл в любом случае после установки или обновления. Я бы просто удалил эти location
s полностью.