ホームページ > バックエンド開発 > PHPチュートリアル > PHP の非同期サブ使用によりユーザー エクスペリエンスが向上します

PHP の非同期サブ使用によりユーザー エクスペリエンスが向上します

WBOY
リリース: 2016-06-13 13:06:35
オリジナル
878 人が閲覧しました

PHP 非同期呼び出しによりユーザー エクスペリエンスが向上します

これは、テクノロジーに精通した私の友人によって書かれたもので、php 愛好家の読者や php の学習に興味のある友人が参照できるように、私のブログに公開するよう依頼されました。
?????? ? 例: PHP 言語
ある SNS コミュニティでは、ユーザーが友達にメールを送信します (友達の数は数百人)。送信されたことを示すプロンプトが表示されます。
一般的に使用される PHP 記述メソッド
sendmail.php

<?php
$count=count($emailarr);//$emailarr数组为好友的邮件地址
for($i=0;$i<$count;$i++)
{
  sendmail(.....);//发送邮件
}
echo ''发送完毕';
?>
ログイン後にコピー

?
今回は 100 通のメールが送信されたとします。この操作の結果はどうなりますか?
ユーザー エクスペリエンス: ユーザーは待機します -> 数十のメールを送信します -> システムがタイムアウトになり、エラー メッセージが返されます
この操作では大量のメールを送信する必要があります。 PHP の実行時間が長すぎるため、ユーザーは待ち焦がれています。 Apache または nginx が許容実行時間を超えて待機すると、タイムアウト エラーが返されます。現時点では、ユーザーには操作が成功したかどうか、また送信されたメールの数はわかりません。
このコードのユーザー エクスペリエンスは非常に悪く、タスクをスムーズに完了できないことがわかります。
どのように行うべきですか?
ここでは非同期実行という概念について説明します
ユーザー エクスペリエンス: ユーザーは待機します -> 送信が完了します
友達は、なぜ送信リンクがないのかと尋ねます。
ユーザーがリクエストを送信すると、メール送信タスクはレターの送信を個別に処理する PHP プログラムに転送されます。ユーザーに「送信完了」と表示された時点では、レターはまだ送信されていません。 、メール送信プログラムがバックグラウンドで懸命に動作し、文字を 1 つずつ送信しています
sendmail.php

<?php
$domain="www.***.com";
$url="/system_mail.php";
$par="email=".implode(',',$emailarr)."&........";
$header = "POST $url HTTP/1.0\r\n";
$header .= "Content-Type: application/x-www-form-urlencoded\r\n";
$header .= "Content-Length: " . strlen($par) . "\r\n\r\n";
$fp = @fsockopen ($domain, 80, $errno, $errstr, 30);
fputs ($fp, $header . $par);
fclose($fp);
echo ''发送完毕';
?>
system_mail.php
<?php
ini_set("ignore_user_abort",true);
ignore_user_abort(true);//此处的代码需要php.ini开启相关的选项,保证php执行不超时的,不明白,参考我的另一篇文章 “关闭浏览器后,php脚本会不会继续运行”
/*
获取email地址,发信,此处为发信代码
*/
?>
ログイン後にコピー

?わかりました。非同期モードに変更した後、ユーザーは情報を送信して、すぐに「送信完了」という結果を得ることができます。レターは送信されるまでバックグラウンドで 1 つずつ送信されます
この記事は php 愛好家からのものです http://www.phplover.cn/、元のアドレス: http://www.phplover.cn/post /phpyibugongzuotishengyonghutiyan .html

?

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート