web-dev-qa-db-ja.com

exec()のチェックが正常に実行されるかどうか

私はphpのexec()コマンドが正常に実行されるかどうかを知らせようとしているので、それに応じて特定のメッセージをエコーできます。次のコードを試してみましたが、問題はexec()が正常に実行されるかどうか、常にecho "PDF not created"そして、PDFが正常に作成されたことをエコーし​​ません。 exec()の実行時にチェックを実行する方法を教えてください。それに応じてメッセージをエコーできますありがとう、

<?php
if (exec('C://abc//wkhtmltopdf home.html sample.pdf'))
echo "PDF Created Successfully";
else
echo "PDF not created";
?>
35
soft genic

PHPの exec quickref によると、ポインターを渡してコマンドの出力とステータスを取得できます。

<?php
exec('C://abc//wkhtmltopdf home.html sample.pdf', $output, $return);

// Return will return non-zero upon an error
if (!$return) {
    echo "PDF Created Successfully";
} else {
    echo "PDF not created";
}
?>

発生する可能性のあるエラーを列挙する場合は、 hiteksoftware でコードを見つけることができます

59
Matt Williamson

正しい方法は、$ return_varがゼロに設定されていないことを確認することです。これは、成功した場合にのみゼロに設定されるためです。場合によっては、execが失敗し、return_varが何にも設定されないことがあります。例えば。実行中にサーバーのディスク容量が不足した場合。

<?php
exec('C://abc//wkhtmltopdf home.html sample.pdf', $output, $return_var);
if($return_var !== 0){ // exec is successful only if the $return_var was set to 0. !== means equal and identical, that is it is an integer and it also is zero.
    echo "PDF not created";
}
else{
    echo "PDF Created Successfully";
}

?>

注:$ return_varをゼロに初期化しないでください

13
malhal

簡単なサンプル:

$ip = "192.168.0.2";
$exec = exec( "ping -c 3 -s 64 -t 64 ".$ip, $output, $return );
echo $exec;
echo "<br />----------------<br />";
print_r( $output );
echo "<br />----------------<br />";
print_r( $return );

pingまたはERRORでない場合。(ONE)

----------------
Array ( [0] => PING 192.168.0.2 (192.168.0.2) 64(92) bytes of data. [1] => [2] => --- 192.168.0.2 ping statistics --- [3] => 3 packets transmitted, 0 received, 100% packet loss, time 2016ms [4] => )
----------------
1

成功した場合(ZERO)

rtt min/avg/max/mdev = 4.727/18.262/35.896/13.050 ms
----------------
Array ( [0] => PING 192.168.0.2 (192.168.0.2) 64(92) bytes of data. [1] => 72 bytes from 192.168.0.2: icmp_req=1 ttl=63 time=14.1 ms [2] => 72 bytes from 192.168.0.2: icmp_req=2 ttl=63 time=35.8 ms [3] => 72 bytes from 192.168.0.2: icmp_req=3 ttl=63 time=4.72 ms [4] => [5] => --- 192.168.0.2 ping statistics --- [6] => 3 packets transmitted, 3 received, 0% packet loss, time 2003ms [7] => rtt min/avg/max/mdev = 4.727/18.262/35.896/13.050 ms )
----------------
0
4
deepcell