ホームページ > php教程 > php手册 > Nginx+php fastcgi 发生 Access Denied

Nginx+php fastcgi 发生 Access Denied

WBOY
リリース: 2016-06-06 19:46:15
オリジナル
1247 人が閲覧しました

原因分析: php官方从5.3.9开始,加入了一个配置security.limit_extensions(/usr/local/php/etc/php-fpm.conf),默认状态下只允许执行扩展名为.php的文件,造成了其他类型的文件不支持的问题。 如果你请求的 地址是 css js png这种资源 会被 php 拒绝,如

原因分析:

php官方从5.3.9开始,加入了一个配置"security.limit_extensions"(/usr/local/php/etc/php-fpm.conf),默认状态下只允许执行扩展名为".php"的文件,造成了其他类型的文件不支持的问题。

如果你请求的 地址是  css js png这种资源 会被 php 拒绝,如果你请求的是 http://localhost/user   (暗含  http://localhost/user/index.php)也是不行的。


解决方式

1,有的人修改 php的配置文件 将 允许的扩展 都加上 比如security.limit_extensions=.php .html .js .css .jpg .jpeg .gif .png .htm#

但是这样其实是不好的 因为静态资源本来就不应该让php fast-cgi处理

2,(推荐)使用nginx的rewrite

location  ~ \.(js|css|gif|jpg|jpeg|png)$ {
    root   D:/tmp;
}
location  ~ \.php$ {
            root           html;
            fastcgi_pass   127.0.0.1:3344;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  D:/tmp/$fastcgi_script_name;
            include        fastcgi_params;
}
location   / {
            root           D:/tmp/film;
            fastcgi_pass   127.0.0.1:3344;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  D:/tmp/film/$fastcgi_script_name;
            include        fastcgi_params;
            rewrite        ^(.*)$      $1/index.php;
}

如此可以较好解决问题 第一个location过滤类型 可能不够,可以根据自己的需求添加

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート