이 답변의 일부만 사용에 적용되지만mail()
기능 자체 이러한 문제 해결 단계 중 많은 부분이 모든 PHP 메일 시스템에 적용될 수 있습니다.
스크립트가 이메일을 보내지 않는 것처럼 보이는 데는 여러 가지 이유가 있습니다. 명백한 구문 오류가 없으면 이러한 것들을 진단하기가 어렵습니다. 하나가 없으면 아래의 점검표를 검토하여 발생할 수있는 잠재적 인 함정을 찾으십시오.
오류보고가 활성화되어 있고 모든 오류를보고하도록 설정되어 있는지 확인하십시오.
오류보고는 코드의 버그와 PHP에서 발생하는 일반적인 오류를 근절하기 위해 필수적입니다. 이러한 오류를 수신하려면 오류보고를 활성화해야합니다. PHP 파일 상단 (또는 마스터 구성 파일)에 다음 코드를 배치하면 오류보고가 활성화됩니다.
error_reporting(-1);
ini_set('display_errors', 'On');
set_error_handler("var_dump");
PHP에서 유용한 오류 메시지를 얻는 방법을 참조하십시오 . — 이 답변 대한 자세한 내용은 을 참조하십시오.
mail()
함수가 호출 되었는지 확인하십시오
어리석은 것처럼 보일 수 있지만 일반적인 오류는 실제로 mail()
코드에 함수를 배치하는 것을 잊어 버리는 것 입니다. 그것이 있고 주석 처리되지 않았는지 확인하십시오.
mail()
함수가 올바르게 호출되었는지 확인하십시오
bool mail (문자열 $ to, 문자열 $ subject, 문자열 $ message [, 문자열 $ additional_headers [, 문자열 $ additional_parameters]])
메일 기능에는 세 가지 필수 매개 변수와 선택적으로 네 번째 및 다섯 번째 매개 변수가 사용됩니다. 당신의 전화mail()
3 개 이상의 매개 변수가 없으면 실패합니다.
당신의 전화 mail()
올바른 순서로 올바른 매개 변수가 없으면 실패합니다.
서버의 메일 로그 확인
웹 서버는 이메일을 통한 모든 이메일 전송 시도를 기록해야합니다. 이러한 로그의 위치는 다양하지만 (서버 관리자에게 로그 위치를 물어봐야 할 수도 있음) 일반적으로의 사용자 루트 디렉토리에서 찾을 수 있습니다 logs
. 내부에는 서버가 이메일 전송 시도와 관련하여보고 한 오류 메시지가 있습니다.
포트 연결 실패 확인
포트 차단은 SMTP를 사용하여 이메일을 전송하기 위해 코드를 통합하는 동안 대부분의 개발자가 직면하는 매우 일반적인 문제입니다. 그리고 이것은 서버 메일 로그에서 쉽게 추적 할 수 있습니다 (메일 로그의 서버 위치는 위에서 설명한 것처럼 서버마다 다를 수 있습니다). 공유 호스팅 서버에있는 경우 포트 25 및 587은 기본적으로 차단 된 상태로 유지됩니다. 이 차단은 호스팅 제공 업체가 의도적으로 수행 한 것입니다. 이것은 일부 전용 서버에서도 마찬가지입니다. 이러한 포트가 차단되면 포트 2525를 사용하여 연결을 시도하십시오. 해당 포트도 차단 된 경우 유일한 해결책은 호스팅 제공 업체에 문의하여 해당 포트를 차단 해제하는 것입니다.
대부분의 호스팅 제공 업체는 이러한 이메일 포트를 차단하여 네트워크에서 스팸 이메일을 보내지 않도록 보호합니다.
일반 / TLS 연결에는 포트 25 또는 587을, SSL 연결에는 포트 465를 사용하십시오. 대부분의 사용자는 일부 호스팅 제공 업체가 설정 한 속도 제한을 피하기 위해 포트 587을 사용하는 것이 좋습니다.
오류 억제 연산자를 사용하지 마십시오
때 오류 억제 연산자는 @
PHP의 표현식 앞에 추가됩니다, 그 표현에 의해 발생 될 수있는 오류 메시지는 무시됩니다. 이 연산자를 사용해야하는 상황이 있지만 메일을 보내는 것이 그 중 하나 가 아닙니다 .
코드에 포함 된 경우 @mail(...)
이를 디버깅하는 데 도움이되는 중요한 오류 메시지가 숨겨져있을 수 있습니다. 를 제거하고 @
오류가보고되는지 확인하십시오.
구체적인 실패 를error_get_last()
바로 확인한 후에 만 권장합니다 .
mail()
반환 값 확인
mail()
기능 :
TRUE
메일 발송이 성공적으로 수락되었는지 여부를 반환 합니다 FALSE
. 우편물 배달이 허용되었다고해서 실제로 우편물이 의도 한 목적지에 도달한다는 것을 의미하지는 않습니다.
다음과 같은 이유로주의해야합니다.
- 당신이
FALSE
반환 값 을받을 경우 오류는 서버가 메일을 수락에 있음을 알고 있습니다. 코딩 문제가 아니라 서버 구성 문제 일 수 있습니다. 왜 이런 일이 발생하는지 알아 보려면 시스템 관리자에게 문의해야합니다.
- 당신이
TRUE
반환 값을 받을 경우 당신 의 이메일이 확실히 전송되는 것은 아닙니다. 단지 이메일이 PHP에 의해 서버의 해당 핸들러로 성공적으로 전송되었음을 의미합니다. PHP가 통제 할 수없는 외부에는 여전히 이메일이 전송되지 않는 더 많은 실패 지점이 있습니다.
따라서 FALSE
올바른 방향으로 안내하는 데 도움이되지만 반드시 이메일이 성공적으로 전송 된 TRUE
것은 아닙니다 . 이것은 중요합니다!
호스팅 제공 업체가 이메일을 보내도록 허용하고 메일 전송을 제한하지 않도록하십시오
많은 공유 웹 호스트, 특히 무료 웹 호스팅 공급자는 서버에서 전자 메일을 보내거나 특정 기간 동안 보낼 수있는 양을 제한합니다. 이는 스패머가 더 저렴한 서비스를 이용할 수 없도록 제한하려는 노력 때문입니다.
호스트에 이메일 제한이 있다고 생각하거나 이메일 전송을 차단하는 경우 FAQ를 확인하여 해당 제한이 나열되어 있는지 확인하십시오. 그렇지 않으면 이메일 전송과 관련하여 제한이 있는지 확인하기 위해 지원에 문의해야 할 수도 있습니다.
스팸 폴더를 확인하십시오. 이메일이 스팸으로 표시되는 것을 방지
여러 가지 이유로 종종 PHP (및 기타 서버 측 프로그래밍 언어)를 통해 전송 된 전자 메일은 수신자의 스팸 폴더에있게됩니다. 코드 문제를 해결하기 전에 항상 확인하십시오.
PHP를 통해 전송 된 메일이 수신자의 스팸 폴더로 전송되는 것을 방지하기 위해, PHP 코드 및 이메일로 스팸으로 표시 될 가능성을 최소화하기 위해 수행 할 수있는 다양한 작업이 있습니다. Michiel de Mare의 유용한 팁은 다음과 같습니다.
- SPF 및 DKIM 과 같은 이메일 인증 방법을 사용 하여 이메일과 도메인 이름이 함께 속해 있음을 증명하고 도메인 이름 스푸핑을 방지하십시오. SPF 웹 사이트에는 사이트의 DNS 정보를 생성하는 마법사가 포함되어 있습니다.
- 확인 하여 역 DNS를 메일을 보내는 데 사용하는 도메인 이름에 확인 메일 서버 포인트의 IP 주소를 확인합니다.
- 사용중인 IP 주소가 블랙리스트에 없는지 확인하십시오
- 회신 주소가 유효한 기존 주소인지 확인하십시오.
- 이메일 주소뿐만 아니라받는 사람 필드에 주소의 전체 실명을 사용하십시오 (예 :)
"John Smith" <john@blacksmiths-international.com>
.
- abuse@yourdomain.com 및 postmaster@yourdomain.com과 같은 남용 계정을 모니터링하십시오. 즉, 이러한 계정이 존재하는지 확인하고 전송 된 내용을 읽고 불만에 대해 조치를 취하십시오.
- 마지막으로 구독을 취소하기가 정말 쉽습니다. 그렇지 않으면 스팸 버튼 을 눌러 사용자의 구독을 취소 하면 평판에 영향을 미칩니다.
프로그래밍 방식으로 보낸 전자 메일이 자동으로 스팸으로 표시되지 않도록하려면 어떻게합니까?를 참조하십시오 . 이 주제에 대한 자세한 내용은
모든 메일 헤더가 제공되었는지 확인하십시오
일부 스팸 소프트웨어는 "보낸 사람"및 "답장"과 같은 공통 헤더가없는 경우 메일을 거부합니다.
$headers = array("From: from@example.com",
"Reply-To: replyto@example.com",
"X-Mailer: PHP/" . PHP_VERSION
);
$headers = implode("\r\n", $headers);
mail($to, $subject, $message, $headers);
메일 헤더에 구문 오류가 없는지 확인
유효하지 않은 헤더는 헤더가없는 것만 큼 나쁩니다. 잘못된 문자 하나만 있으면 전자 메일을 탈선시킬 수 있습니다. PHP가 이러한 오류를 포착 하지 않으므로 구문이 올바른지 다시 확인하십시오 .
$headers = array("From from@example.com", // missing colon
"Reply To: replyto@example.com", // missing hyphen
"X-Mailer: "PHP"/" . PHP_VERSION // bad quotes
);
가짜 From:
발신자를 사용하지 마십시오
메일이에서을을 가지고 있어야하지만 : 보낸 사람, 당신은 사용할 수 없습니다 임의의 값입니다. 특히 사용자가 보낸 발신자 주소는 메일을 차단할 수있는 확실한 방법입니다.
$headers = array("From: $_POST[contactform_sender_email]"); // No!
이유 : @hotmail 또는 @gmail 주소를 담당하는 것처럼 가장하여 웹 또는 메일 서버를 보내는 것이 SPF / DKIM 허용 목록에 없습니다. From:
구성되지 않은 발신자 도메인이있는 메일을 자동으로 삭제할 수도 있습니다 .
수신자 값이 올바른지 확인하십시오
때로는 이메일 수신자에게 잘못된 값을 갖는 것만 큼 문제가 간단 할 수 있습니다. 잘못된 변수를 사용했기 때문일 수 있습니다.
$to = 'user@example.com';
// other variables ....
mail($recipient, $subject, $message, $headers); // $recipient should be $to
이것을 테스트하는 또 다른 방법은 수신자 값을 mail()
함수 호출 에 하드 코딩하는 것입니다 .
mail('user@example.com', $subject, $message, $headers);
이것은 모든 mail()
매개 변수에 적용될 수 있습니다 .
여러 계정으로 보내기
이메일 계정 문제를 배제하려면 다른 이메일 제공 업체의 여러 이메일 계정으로 이메일을 보내십시오 . 이메일이 사용자의 Gmail 계정에 도착하지 않으면 동일한 이메일을 Yahoo 계정, Hotmail 계정 및 일반 POP3 계정 (예 : ISP 제공 이메일 계정)으로 보내십시오.
전자 메일이 다른 전자 메일 계정의 일부 또는 전부에 도착하면 코드에서 전자 메일을 보내고 있지만 전자 메일 계정 공급자가 어떤 이유로 든 차단하고있을 가능성이 있습니다. 이메일이 이메일 계정에 도착하지 않으면 코드와 관련된 문제 일 가능성이 높습니다.
코드가 양식 메소드와 일치하는지 확인하십시오
양식 방법을로 설정 한 경우 양식 값을 찾는 POST
데 사용하고 있는지 확인하십시오 $_POST
. 설정 GET
하거나 설정하지 않은 경우 $_GET
양식 값을 찾는 데 사용하십시오 .
양식 action
값이 올바른 위치를 가리키는 지 확인하십시오
양식 action
속성에 PHP 메일 코드를 가리키는 값이 포함되어 있는지 확인하십시오 .
<form action="send_email.php" method="POST">
웹 호스트가 이메일 전송을 지원하는지 확인하십시오
일부 웹 호스팅 제공 업체는 서버를 통한 이메일 전송을 허용하거나 활성화하지 않습니다. 그 이유는 다양 할 수 있지만 메일 전송을 비활성화 한 경우 타사를 사용하여 해당 이메일을 전송하는 다른 방법을 사용해야합니다.
기술 지원에 대한 이메일 (온라인 지원 또는 FAQ 방문 후)은 서버에서 이메일 기능을 사용할 수 있는지 확인해야합니다.
localhost
메일 서버가 구성되어 있는지 확인하십시오
WAMP, MAMP 또는 XAMPP를 사용하여 로컬 워크 스테이션에서 개발중인 경우 이메일 서버가 워크 스테이션에 설치되지 않았을 수 있습니다. 하나도 없으면 PHP는 기본적으로 메일을 보낼 수 없습니다.
기본 메일 서버를 설치하여이를 극복 할 수 있습니다. Windows의 경우 무료 Mercury Mail을 사용할 수 있습니다 .
SMTP를 사용하여 이메일을 보낼 수도 있습니다. 이 작업을 수행하는 방법을 배우려면 Vikas Dwivedi 의이 훌륭한 답변 을 참조하십시오 .
PHP의 커스텀 활성화 mail.log
MTA 및 PHP의 로그 파일 외에도 함수에 대한 로깅을mail()
구체적으로 활성화 할 수 있습니다 . 완전한 SMTP 상호 작용은 기록하지 않지만 최소한 함수 호출 매개 변수 및 호출 스크립트는 기록하지 않습니다.
ini_set("mail.log", "/tmp/mail.log");
ini_set("mail.add_x_header", TRUE);
자세한 내용은 http://php.net/manual/en/mail.configuration.php 를 참조하십시오. (그것은 이러한 옵션 가능하게하는 것이 가장 좋습니다 php.ini
하거나 .user.ini
또는 .htaccess
아마도합니다.)
메일 테스트 서비스로 확인
MTA / 웹 서버 설정을 테스트하는 데 사용할 수있는 다양한 배달 및 스팸 확인 서비스가 있습니다. 일반적으로 다음 주소로 메일 프로브를 보낸 다음 배달 보고서를 받고 나중에보다 구체적인 오류나 분석을받습니다.
다른 메일러 사용
PHP의 내장 mail()
함수는 편리하고 종종 작업을 수행하지만 단점이 있습니다. 다행스럽게도 위에서 설명한 많은 문제를 처리하는 등 더 강력한 기능과 유연성을 제공하는 대안이 있습니다.
이들 모두는 전문 SMTP 서버 / 서비스 제공 업체와 결합 될 수 있습니다. (일반적인 08/15 공유 웹 호스팅 계획은 이메일 설정 / 구성 가능성과 관련하여 적발되거나 누락되었으므로)