![](/img/trans.png)
[英]NGINX and PHP-FPM is downloading index.php instead of processing it
[英]nGinx and PHP-FPM downloads index.php
我具有以下配置以侦听端口80,但重定向到https。 然后,要通过index.php文件路由所有内容,但是,当我转到页面时,它只是下载index.php文件或在主页上显示403 forbidden
。
有任何想法吗?
server {
listen 80;
server_name www.mydomain.com mydomain.com;
rewrite ^ https://$server_name$request_uri? permanent;
}
server {
listen 443;
server_name www.mydomain.com;
root /var/www/mydomain/public;
ssl on;
ssl_certificate mydomain.crt;
ssl_certificate_key mydomain.key;
ssl_session_timeout 5m;
ssl_protocols SSLv3 TLSv1;
ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv3:+EXP;
ssl_prefer_server_ciphers on;
location / {
if (!-e $request_filename){
rewrite \.(jpeg|jpg|gif|png)$ /public/404.php break;
}
if (!-e $request_filename){
rewrite ^(.*)$ /index.php break;
}
}
location ~ \.php {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index /index.php;
include /etc/nginx/fastcgi_params;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_param PATH_INFO $fastcgi_path_info;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
location ~* ^/(css|img|js|flv|swf|download)/(.+)$ {
root /var/www/mydomain/public;
}
location ~ /\.ht {
deny all;
}
}
rewrite/break
导致重写的URI在相同的位置( location /
)而非location ~ \\.php
。 请参阅重写文档。
location /
块看起来很奇怪,有两个相同的if
块。
您可以考虑将其分为两个块:
location / {
try_files $uri /index.php;
}
location ~ \.(jpeg|jpg|gif|png)$ {
try_files $uri /public/404.php;
}
如果/public/404.php
是所有404错误的默认处理程序,则可以改用error_page
指令:
error_page 404 /public/404.php;
location / {
try_files $uri /index.php;
}
location ~ \.(jpeg|jpg|gif|png)$ {
try_files $uri =404;
}
有关更多信息,请参见location , try_files和error_page文档。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.