この記事の例は、PHP でシェルを呼び出す方法を説明しており、参考のために皆さんと共有されています。具体的な方法は以下の通りです
1. 構成
php.iniの設定で、主に以下の3箇所でセーフモードがオンになっているか確認してください
safe_mode = (これがオフの場合、次の 2 つは気にする必要はありません)
機能を無効にする =
safe_mode_exec_dir=
2.使用する
PHPは基本的にWEBプログラムの開発に使用されるため、セキュリティは重要な考慮点となっています。そこで、PHP 設計者は PHP への扉、つまりセーフ モードを追加しました。セーフ モードで実行する場合、PHP スクリプトには次の 4 つの制限が適用されます:
①外部コマンドを実行する
② ファイルを開く際にいくつかの制限があります
③ MySQLデータベースに接続
④HTTPベースの認証
セーフ モードでは、特定のディレクトリ内の外部プログラムのみが実行でき、他のプログラムへの呼び出しは拒否されます。このディレクトリは、php.ini ファイルのsafe_mode_exec_dir ディレクティブを使用するか、PHP のコンパイル時に --with-exec-dir オプションを追加することで指定できます。デフォルトは /usr/local/php/bin です。
結果を出力できるはずの外部コマンド (PHP スクリプトにエラーがないことを意味します) を呼び出しても空白が表示される場合は、ネットワーク管理者が PHP をセーフ モードで実行している可能性があります。
3.どうやって行うのですか?
PHP で外部コマンドを呼び出すには、次の 3 つの方法を使用できます:
1) PHPが提供する特殊関数を利用する
PHP は、外部コマンドを実行するために、system()、exec()、および passthru() という合計 3 つの特殊な関数を提供します。
システム()
プロトタイプ: string システム (string command [, int return_var])
system() 関数は他の言語の関数と似ており、指定されたコマンドを実行し、結果を出力して返します。 2 番目のパラメーターはオプションであり、コマンドの実行後にステータス コードを取得するために使用されます。
例:
実行()
プロトタイプ: string exec (string command [, string array [, int return_var]])
exec() 関数は system() に似ており、指定されたコマンドも実行しますが、結果は出力せず、結果の最後の行を返します。コマンド結果の最後の行のみを返しますが、2 番目のパラメーター配列を使用すると、配列の末尾に結果を 1 行ずつ追加することで完全な結果を取得できます。したがって、配列が空でない場合は、呼び出す前に unset() を使用して配列をクリアするのが最善です。第3パラメータは第2パラメータを指定した場合のみ、コマンド実行時のステータスコードを取得できます。
例:
この記事で説明した内容が皆様の PHP プログラミング設計に役立つことを願っています。
php には、外部コマンドを呼び出すための system()、exec()、および passthru() の 3 つの関数が用意されています。
これら 3 つのコマンドは Linux システムのシェル コマンドを実行できますが、実際には異なります。
system() の出力とシェル結果の最後の行を返します。
exec() は結果を出力せず、シェル結果の最後の行を返します。すべての結果は返された配列に保存できます。
passthru() はコマンドを呼び出すだけで、コマンドの実行結果をそのまま標準出力装置に出力します。
類似点: コマンド実行のステータスコードを取得できます
例: system("/usr/local/bin/webalizer/webalizer");
sysyem() passthru() exec() などの関数のロックを解除します。
passthru('ps -ef'); を実行して、このコマンドの出力を取得します。必要なものを定期的に取得し、これらの関数を呼び出して操作を実行します。具体的な使用方法についてはマニュアルを参照してください。