ブラウザとサーバーは HTTP プロトコルを通じて通信します。これは、リクエストとレスポンスのモデルに基づいたプロトコルです。ブラウザは URL を通じてサーバーへのリクエストを開始し、Web サーバーはリクエストを受信し、プログラムを実行し、対応する HTML コードをクライアントに送信して応答します。
Web サーバーがプログラムを実行するときに、数ミリ秒で完了する場合もあれば、数分以内に完了しない場合もあります。プログラムの実行が遅い場合、ユーザーはそれ以上待つ忍耐力がなくなり、ブラウザを閉じる可能性があります。
場合によっては、これらの時間のかかるスクリプトの戻り結果を気にしないこともありますが、次のステップに進む前に、スクリプトの実行が完了して戻るまで待つ必要があります。
それでは、これらの時間のかかるスクリプトの呼び出しを単純にトリガーして次のステップに進み、これらの時間のかかるスクリプトをサーバー側でゆっくり実行できるようにする方法はあるのでしょうか?
テスト後、いくつかの方法をまとめて共有します。
1. 最も簡単な方法は、クライアントに返される HTML コードに AJAX 呼び出しを埋め込むか、コードを指す src を含む img タグを埋め込むことです。時間のかかるスクリプトが実行されます。
この方法は最も簡単で最速です。サーバーは呼び出しを行う必要はありません。
しかし、一般的に言えば、Ajax は onLoad の後にトリガーされる必要があるという欠点があります。つまり、ユーザーがページをクリックして閉じた場合、バックグラウンド スクリプトはトリガーされないということです。
imgタグを使用した場合、このメソッドは厳密な意味での非同期実行とは言えません。ユーザーのブラウザは、php スクリプトの実行が完了するまで長時間待機します。つまり、ユーザーのブラウザのステータス バーには、常にロード中であることが表示されます。
もちろん、スクリプトタグなど、同様の原理を持つ他のメソッドも使用できます。
2. Popen()
resource Popen (string command, string mode);
//指定されたコマンドコマンドの実行の結果として生じるプロセスを指すパイプを開きます。指定されたコマンドを生成したコマンドの実行によって生成されたプロセスへのパイプを開きます。
したがって、それを呼び出すことはできますが、その出力は無視できます。
pclose(popen("/home/xinchen/backend.php &"
このメソッドは、最初のメソッドの欠点を回避し、高速でもあります。しかし、問題は、このメソッドが HTTP プロトコル経由で別のメソッドをリクエストできないことです。WebService は、ローカルのスクリプトファイルのみを実行するため、一方向にしか開くことができず、呼び出されたスクリプトに大量のパラメータを渡すことができません。また、アクセス量が多い場合には、大量のプロセスが生成されることを考慮する必要があります。
3. CURL を使用します
このメソッドは CUROPT_TIMEOUT を 1 に設定します (最小値は 1 です)。つまり、クライアントは少なくとも 1 秒待機する必要があります$curl_init()。 = array(CURLOPT_URL, 'http://www.example.com/backend.php', CURLOPT_RETURNTRANSFER, 1, CURLOPT_TIMEOUT, 1,); );
4. fsockopen を使用します
この方法は最も完璧なはずですが、欠点は HTTP ヘッダー部分を自分で記述する必要があることです
$fp = fsockopen("www.example.com", 80, $errno, $errstr, 30); if (!$fp) { echo "$errstr ($errno)
n"; } else { $out = "GET /backend.php / HTTP/ 1.1rn "; $out .= "ホスト: www.example.comrn"; $out .= "接続: Closernrn"; fwrite($fp, $out); /*実行結果を無視します (!feof($fp) ) { echo fgets($fp, 128); }*/ fclose($fp); }
したがって、全体として、最も簡単な方法は最初の方法です
最も完璧なものは最後の方法です。もっと複雑ですもっと良い方法がある場合は、ぜひご連絡ください
出典: http://www.laruence.com/2008/04/14/318.html