저는 PHP mail()기능을 사용하고 있습니다.
어떤 이유로 든 메일이 전송되지 않으면 오류 메시지를 표시하고 싶습니다. 어떻게할까요?
같은 것
$this_mail = mail('example@example.com', 'My Subject', $message);
if($this_mail) echo 'sent!';
else echo error_message;
감사!
답변:
SMTP를 사용하는 Windows에서는 false를 반환 error_get_last()할 때 사용할 수 있습니다 mail(). 이것은 PHP의 기본 mail () 함수에서는 작동하지 않습니다.
$success = mail('example@example.com', 'My Subject', $message);
if (!$success) {
$errorMessage = error_get_last()['message'];
}
을 사용 print_r(error_get_last())하면 다음과 같은 결과를 얻을 수 있습니다.
[type] => 2
[message] => mail () : "xxxx"포트 25에서 메일 서버에 연결하지 못했습니다. php.ini에서 "SMTP"및 "smtp_port"설정을 확인하거나 ini_set () 사용
[파일] = > C : \ www \ X \ X.php
[줄] => 2
error_get_last()반환 NULL!! 그러나 메일 함수는 true를 반환합니다!
제 경우에는 내가 무엇을하든 ( error_get_last(), 또는 ini_set('display_errors',1);) 오류 메시지를 표시하지 않더라도 PHP 스크립트에서 오류 메시지를 얻을 수 없습니다.
이 게시물 에 따르면
$ mail의 반환 값은 서버의 메일 링 시스템이 배달을 위해 메시지를 수락했는지 여부 만 나타내며 유효한 인수를 제공하는지 여부를 알 수 없으며 알 수 없습니다. 예를 들어, sendmail이 제대로로드되지 않은 경우 (예 : 제대로 설치되지 않은 경우) 반환 값은 false이지만 sendmail이 제대로로드되었지만 수신자 주소가 존재하지 않으면 true를 반환합니다.
mail()내 PHP 스크립트에서 사용하려는 시도가 실패한 후 sendmail내 컴퓨터에 설치되지 않았지만 php.ini 변수 sendmail_path는/usr/sbin/sendmail -t -i
1- 패키지 관리자에서 sendmail을 설치했습니다. shell> dnf install sendmail
2- 나는 그것을 시작했다 shell> service sendmail start
3- 이제 PHP mail()기능이 실패하면 디렉토리에 sendmail기록 된 프로그램 의 오류를 찾습니다 /var/mail/. 사용자 당 파일 1 개
예를 들어이 스 니펫은 내 /var/mail/root파일 에서 가져옵니다.
The original message was received at Sun, 29 Jul 2018 22:37:51 +0200
from localhost [127.0.0.1]
----- The following addresses had permanent fatal errors -----
<no-one@errorerrorerrorerror51248562221e542.com>
(reason: 550 Host unknown)
내 시스템은 apache2.4 및 PHP 7.2가 설치된 Linux Fedora 28입니다.
$e=error_get_last();
if($e['message']!==''){
// An error function
}
error_get_last (); -발생한 마지막 오류를 반환
다른 사람들이 말했듯이, 보내는 메일에 대한 오류 추적은 없으며 보내는 큐에 메일을 추가 한 부울 결과를 반환합니다. 진정한 성공 실패를 추적하려면 Swift Mailer, Zend_Mail 또는 phpmailer와 같은 메일 라이브러리와 함께 SMTP를 사용해보십시오.
이 시도. 파일에 오류가 있으면 이메일 ID에 오류 메일이 표시됩니다. 두 개의 파일을 index.php만들고 checkErrorEmail.php서버에 업로드합니다. 그런 다음 index.php브라우저로 로드 하십시오.
Index.php
<?php
include('checkErrorEmail.php');
include('dereporting.php');
$temp;
echo 'hi '.$temp;
?>
checkErrorEmail.php
<?php
// Destinations
define("ADMIN_EMAIL", "pradeep.callus7@hotmail.com");
//define("LOG_FILE", "/my/home/errors.log");
// Destination types
define("DEST_EMAIL", "1");
//define("DEST_LOGFILE", "3");
/* Examples */
// Send an e-mail to the administrator
//error_log("Fix me!", DEST_EMAIL, ADMIN_EMAIL);
// Write the error to our log file
//error_log("Error", DEST_LOGFILE, LOG_FILE);
/**
* my_error_handler($errno, $errstr, $errfile, $errline)
*
* Author(s): thanosb, ddonahue
* Date: May 11, 2008
*
* custom error handler
*
* Parameters:
* $errno: Error level
* $errstr: Error message
* $errfile: File in which the error was raised
* $errline: Line at which the error occurred
*/
function my_error_handler($errno, $errstr, $errfile, $errline)
{
echo "<br><br><br><br>errno ".$errno.",<br>errstr ".$errstr.",<br>errfile ".$errfile.",<br>errline ".$errline;
if($errno)
{
error_log("Error: $errstr \n error on line $errline in file $errfile \n", DEST_EMAIL, ADMIN_EMAIL);
}
/*switch ($errno) {
case E_USER_ERROR:
// Send an e-mail to the administrator
error_log("Error: $errstr \n Fatal error on line $errline in file $errfile \n", DEST_EMAIL, ADMIN_EMAIL);
// Write the error to our log file
//error_log("Error: $errstr \n Fatal error on line $errline in file $errfile \n", DEST_LOGFILE, LOG_FILE);
break;
case E_USER_WARNING:
// Write the error to our log file
//error_log("Warning: $errstr \n in $errfile on line $errline \n", DEST_LOGFILE, LOG_FILE);
break;
case E_USER_NOTICE:
// Write the error to our log file
// error_log("Notice: $errstr \n in $errfile on line $errline \n", DEST_LOGFILE, LOG_FILE);
break;
default:
// Write the error to our log file
//error_log("Unknown error [#$errno]: $errstr \n in $errfile on line $errline \n", DEST_LOGFILE, LOG_FILE);
break;
}*/
// Don't execute PHP's internal error handler
return TRUE;
}
// Use set_error_handler() to tell PHP to use our method
$old_error_handler = set_error_handler("my_error_handler");
?>