ホームページ  >  記事  >  バックエンド開発  >  PHP は 500、503 エラーを監視し、電子メールでプロンプト コードを送信します

PHP は 500、503 エラーを監視し、電子メールでプロンプト コードを送信します

WBOY
WBOYオリジナル
2016-07-25 08:55:541519ブラウズ
  1. /**

  2. * 監視ログ 500 503 エラー
  3. * by bbs.it-home.org
  4. */
  5. include("PHPMailer/class.phpmailer.php");
  6. //error_reporting(0);
  7. $mail = new PHPMailer();
  8. $mail->IsSMTP(); // SMTP を使用するようにクラスに指示します
  9. $mail->SMTPDebug = 1; // SMTP デバッグ情報を有効にします (テスト用)
  10. // 1 = エラーとメッセージ
  11. // 2 = メッセージのみ
  12. $mail->SMTPAuth = true; // SMTP 認証を有効にする
  13. $mail->Host = "smtp.126.com"; // SMTP サーバーを設定します
  14. $mail->Port = 25; // GMAIL サーバーの SMTP ポートを設定します
  15. $mail->Username = "xxx@126.com"; // SMTP アカウントのユーザー名 邮箱用户名
  16. $mail->Password = "xxxxxxxxx"; // SMTP アカウントのパスワード 秘密
  17. $mail->SetFrom('xxxxxxx@126.com', '报错');//

  18. $now = "u_ex".date("ymdH ").".log";

  19. try{

  20. $log = file("F:/iis-log/W3SVC2/".$now);//日志路径自己修正
  21. } catch(Exception $e){
  22. echo "ファイルがありません ";
  23. exit;
  24. }

  25. $error = array();

  26. $start = date("i",time()- 120);
  27. $end = date("i");
  28. if($start > $end){
  29. exit;
  30. }
  31. $aa = range($start,$end);
  32. $code = mkstr($ aa);
  33. echo $code;
  34. $pattern = "/($code).*(s500s|s503s)/";//这里自己修正
  35. $i = 0;
  36. foreach($log as $k => $v){
  37. if(preg_match($pattern,$v)){
  38. $error[] = $v;
  39. echo $v;
  40. $i += 1;
  41. }
  42. }
  43. if(!empty($error )){
  44. $content = implode("
    ",$error);
  45. $mail->Subject="$i エラー ";
  46. $mail->AddAddress("xxxxxxxxxx@163.com ");
  47. $mail->AddAddress("xxxxxxxx@126.com");
  48. $mail->MsgHTML($content);
  49. $mail->send();
  50. }
  51. echo "nover";
  52. function mkstr($arr){
  53. $code = '';
  54. foreach($arr as $k => $e){
  55. $code .=":$e:|";
  56. }
  57. $code = rtrim ($code,"|");
  58. return $code;
  59. }

复制幣


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。