ホームページ >バックエンド開発 >PHPチュートリアル >PHPファイルのディレクトリ構成におけるopen_basedirの使用とパフォーマンス解析について
PHP が開くことができるファイルを指定されたディレクトリ ツリーに制限する、ファイル自体も含みます。プログラムが、たとえば fopen() または file_get_contents() を使用してファイルを開く場合、ファイルの場所がチェックされます。ファイルが指定されたディレクトリ ツリーの外にある場合、プログラムはそのファイルを開くことを拒否します。 このコマンドは、セーフ モードのオンまたはオフの影響を受けません。
open_basedir="指定目录"
ini_set('open_basedir', '指定目录');
を使用しますが、この方法は推奨されません
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/”
複数のディレクトリを設定する場合、Windows では; を使用してディレクトリを分割し、Linux では: を使用してディレクトリを分割します。3. open_basedir を使用してディレクトリ アクセスを制限します。
<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>
<?phpecho file_get_contents('../test.txt');?>
警告: file_get_contents(): open_basedir 制限が有効です ファイル(../test.txt) は許可されたパス内にありません。 : ( /home/fdipzone/sites/in.fdipzone.com/) /home/fdipzone/sites/in.fdipzone.com/index.php の 3 行目
4 .open_basedir 設定のパフォーマンス分析
<?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 テストを閉じます
実行時間
137.237072 ミリ秒
open_basedir テストを開く 実行時間
open_basedir を開いた後、実行時間はクローズされます3 回。
概要: open_basedir を使用すると、プログラムが操作できるディレクトリとファイルを制限し、システムのセキュリティを向上させることができます。ただし、I/O パフォーマンスに影響し、システムの実行速度が低下するため、特定のニーズに応じてセキュリティとパフォーマンスのバランスを取る必要があります。
この記事では、ディレクトリ構成を含む php ファイルである open_basedir の使用法とパフォーマンス分析について説明します。関連コンテンツの詳細については、php 中国語 Web サイトを参照してください。関連する推奨事項:
Ajax クロスドメイン アクセスにおける Cookie 損失の解決策の説明
curl を使用して php 経由でアクセスする IP とソースをシミュレートする方法
以上がPHPファイルのディレクトリ構成におけるopen_basedirの使用とパフォーマンス解析についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。