open_basedir 將php所能開啟的檔案限制在指定的目錄樹中,包括檔案本身。當程式要使用例如fopen()或file_get_contents()開啟一個檔案時,這個檔案的位置將會被檢查。當檔案在指定的目錄樹之外,程式將拒絕開啟。
本指令不受安全模式開啟或關閉的影響。
1.在php.ini 加入
open_basedir="指定目录"
2.在程序中使用
ini_set('open_basedir', '指定目录');
但不建議使用這種方法
3.在apache的httpd.conf中的Directory設定
php_admin_value open_basedir "指定目录"
#httpd.conf中的VritualHost
php_admin_value open_basedir "指定目录"
4.nginx fastcgi.conf
fastcgi_param PHP_VALUE "open_basedir=指定目录"
用open_basedir指定的限制其實是前綴,不是目錄名。
也就是說open_basedir=/home/fdipzone 也會允許存取/home/fdipzone_abc,如果要將存取限制為目錄,請使用斜線結束路徑名,例如:open_basedir=”/home/fdipzone/”
如果要設定多個目錄,window使用;分隔目錄,linux使用:分隔目錄。
先建立一個VirtualHost,
設定open_basedir 為/home/fdipzone/sites/in.fdipzone.com/
<VirtualHost *:80> ServerAdmin webmaster@localhost DocumentRoot /home/fdipzone/sites/in.fdipzone.com ServerName in.fdipzone.com php_admin_value open_basedir "/home/fdipzone/sites/in.fdipzone.com/" <Directory "/home/fdipzone/sites/in.fdipzone.com"> allow from all Options + Indexes </Directory></VirtualHost>
在上一層目錄/home/fdipzone/sites/ 中建立一個test.txt檔案,在in.fdipzone.com中建立php執行以下程式碼
aab63d905649160d5980449e23070acf
#因為test.txt不在在限定的目錄範圍內,因此php提示警告
Warning: file_get_contents(): open_basedir restriction in effect. File(../test.txt) is not within the allowed path(s): (/home/ fdipzone/sites/in.fdipzone.com/) in /home/fdipzone/sites/in.fdipzone.com/index.php on line 3
open_basedir開啟後會影響I/O,因為每個呼叫的檔案都需要判斷是否在限制目錄內。
測試程序,讀取限制目錄內相同檔案10000次
<?php// 记录开始时间$starttime = getMicrotime();// 读取10000次文件for($i=0; $i<10000; $i++){ file_get_contents('test.txt'); }// 记录结束时间$endtime = getMicrotime(); printf("run time %f ms\r\n", ((float)($endtime)-(float)($starttime))*1000);function getMicrotime(){ list($usec, $sec) = explode(' ', microtime()); return (float)$usec + (float)$sec; }?>
#關閉open_basedir測試
run time 137.237072 ms
#開啟open_basedir測試
run time 404.207945 ms
#開啟open_basedir後,執行時間是關閉的3倍。
總結:使用open_basedir可以限製程式可操作的目錄和文件,提高系統安全性。但會影響I/O效能導致系統執行變慢,因此需要根據具體需求,在安全性與效能上進行平衡。
本文說明了php檔案包含目錄配置open_basedir的使用與效能分析,更多相關內容請關注php中文網。
相關推薦:
以上是php檔案包含目錄配置open_basedir的使用與效能分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!