今天在lnmp上調試php項目,之前已經在上面測試過tp5框架,可以正常訪問。但是新項目由於項目中有些路徑是寫固定路徑的。為了不去修改代碼。配置新項目的時候,為新項目設置新的目錄。問題就出現了,網頁提示 no input file specified。nginx 的error_log 中顯示Operation not permitted in Unknown on line 0 Unable to open primary script:
反復檢查nginx中的server配置,確認root配置確實是項目所在目錄,而且之前的tp5框架所在目錄可以正常訪問。百度搜索了很多很多答案,試了都不行。最后問題解決了,是open_basedir設置的問題,導致php沒有權限讀取新項目所在目錄。
解決思路及過程
訪問php文件 nginx 服務器提示這個錯誤,具體原因有多種。
總的來說,是nginx 或者php fastcgi進程無法找到訪問的php文件。
要快速找出具體原因,可以進行一些設置。
php.ini 開啟錯誤記錄。
error_reporting = E_ALL
display_errors = On
og_errors = On
error_log = /www/logs/php_error.log
nginx.conf 配置中開啟 error_log /home/wwwlogs/nginx_error.log info;
info 表示開啟詳細的nginx服務器錯誤提示。可以打開這個文件看到具體的錯誤信息。
具體原因主要有兩種,
第一,保證nginx中的 server塊配置中的
server_name example.com;
root /opt/webroot;
就是監聽的域名和域名對應的網站根目錄和項目實際目錄要對應
第二是 open_basedir
的設置限制了php進程不能讀取open_basedir 設置的目錄之外的文件。這個設置主要是為了服務器安全。
open_basedir 在php.ini 和nginx中都可以配置。
在nginx中的配置格式(這個是lnmp環境中的fastcgi.conf中的配置)
fastcgi_param PHP_ADMIN_VALUE "open_basedir=/opt/webroot:/tmp/:/proc/";
: 冒號是路徑的分割符。上面配置代表了open_basedir包含三個目錄。/opt/webroot 代表webroot目錄及其根目錄 ,路徑后有斜杠 /proc/ 表示只能訪問 /proc目錄,不能訪問子目錄。
還可以針對一個項目在項目的document_root 下面創建一個 .user.ini 文件,配置當前項目的open_basedir
.
文件中寫上這樣一句話
open_basedir=/home/wwwroot/default:/tmp/:/proc/
在php.ini中配置 在前面加分號,將它注釋掉。
;open_basedir =
另外
在nginx.conf 中 ( 有時候獨立出來在fastcgi.conf中)
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
配置語句之前,要先有$document_root 的定義
$document_root 代表是就是
server_name example.com;
root /webroot;
index index.php;
中root定義的項目根目錄
另外檢查一些,項目目錄的權限,nginx或者php進程是否有權限讀取目錄,通過chmod 或者 chown修改文件權限。