PHP 인증을 사용하여 smtp를 통해 이메일을 보냅니다. PHP에서 SMTP를 통해 메일 보내기. SMTP 스크립트 설정을 통해 PHP 메일 보내기

메일 PHP

이 기능은 기본적으로 이메일 전송으로 구현됩니다. 이 기능을 사용하려면 이메일을 전달하기 위해 타사 서버가 필요하지 않습니다. 이 기능의 정확성을 확인하려면 사이트가 있는 폴더에 test.php 파일을 만들고 거기에 다음 코드를 배치하세요.

대신 어디에 "이메일받는 사람" 편지를 보낼 이메일을 입력하세요.

장소 이 파일귀하의 사이트 루트에.

그런 다음 주소 표시줄에 www.YourDomain/test.php를 입력합니다. 지정된 이메일로 편지를 받으면 호스팅이 편지 보내기 기능과 함께 올바르게 작동하는 것입니다. 메일 PHP". 해당 편지가 스팸으로 분류될 가능성도 있으므로 확인이 필요합니다.

편지가 이해할 수 없는 인코딩으로 도착한 경우 다음 줄을 변경하십시오. "메일 발송 확인 중입니다"~에 "메일 전송 확인 중", "Content-type:text/html;charset=utf-8".

그리고 브라우저의 주소 표시줄을 통해 편지를 반복해서 보냅니다.

위의 조작 후에도 테스트 편지가 최종 수신자에게 전달되지 않으면 호스팅 기술 지원에 문의해야 합니다.

단점 중에는 이 방법작업이 영구적이지 않다는 점은 주목할 가치가 있습니다. 이 방법. 호스팅 측에서 이메일 전송이 중단될 수 있습니다.

이 방법의 가장 큰 단점은 고객의 이메일로 전송된 모든 편지가 귀하의 웹사이트에서 직접 전송되었기 때문에 메일 서비스(gmail, mail.ru, yandex.ru)에서 인식되지 않는다는 것입니다.

Gmail 메일 서비스에는 "Gmail 시스템에서 이 편지가 YourDomain 도메인에서 전송되었는지 확인할 수 없습니다. 스팸일 수 있습니다."라는 물음표와 서명이 포함된 문자가 표시됩니다.

이런 상황을 방지하려면 .

SMTP(간단한 메일 전송 프로토콜)

SMTP - 메일 전송 프로토콜입니다. 전체적으로 이 프로토콜을 사용하여 메일 전송을 설정하려면 SMTP 서버 자체가 필요합니다. 회사(도메인) 메일 yandex.ru를 SMTP 서버로 사용하는 가장 일반적인 옵션은 https://pdd.yandex.ru/입니다.

우선 꼭 필요한 계정(메일) yandex, 귀하의 도메인에 대해 생성되는 이메일을 기준으로: "order@YourDomain" "info@YourDomain"... 기본 계정은 어디에도 표시되지 않으며 향후 이를 기반으로 도메인 이메일을 생성하는 데에만 사용됩니다.

귀하의 계정에 로그인한 후 개인 계정 Yandex 도메인 메일은 https://pdd.yandex.ru/ 링크를 사용하여 생성됩니다. 이는 "발신자" 필드에서 사용자에게 표시되는 도메인 이메일입니다.

SMTP를 통해 이메일을 보낼 때 "보내는 사람" 필드가 필요합니다. SMTP를 사용하여 편지를 보내는 경우 " 도메인" - "이메일", 그에 따라 문자는 메일 서비스에서 인식됩니다.


이 방법의 단점 중 하나는 메일 서비스 자체가 아직 이 기능을 제공하지 않기 때문에 도메인 메일 초상화를 "로드"할 수 없다는 점에 주목할 가치가 있습니다.

2019-08-05

안녕하세요, 방문객 여러분!

블로그 업데이트가 늦어진 점 양해 부탁드립니다. 그러나 이에 대한 완전히 이해 가능한 설명이 있습니다. 결국 여름, 다차, 손님, 숲, 물 등이 있었기 때문에 웹 사이트를 만드는 문제를 해결할 수 없었습니다. 그런데 이제 좀 여유가 생겼고, 손님들도 떠났고, 이제는 확실히 이것에 주의를 기울일 수 있을 것 같아요.

따라서 지난 기사에서 우리 도메인의 메일을 메일 서비스 중 하나에 연결한 후 이제 사이트에서 이메일을 보내는 방법을 살펴보겠습니다. 더욱이, 우리의 편지가 SPAM으로 끝나지 않고 높은 확률로 수신자에게 안정적으로 전달되는 방식으로 말입니다.

일반적으로 PHP에는 편지를 보내는 mail() 함수가 내장되어 있습니다. 그러나 이 방법의 단순성에도 불구하고(이 경우 문자를 보내려면 특정 매개 변수를 사용하여 한 줄의 코드만 지정하면 충분함) 이 옵션을 사용하면 SPAM 문제와 관련된 심각한 단점이 있습니다. .

사실 수신자 측 메일 서버의 스팸 방지 필터는 실제로 mail() 기능을 통해 전송된 편지를 선호하지 않습니다. 그리고 대부분의 경우 이러한 메시지는 수취인에게 도달하기 전에 필터링되거나 삭제되기도 합니다.

그리고 이러한 경우를 최대한 없애기 위해 일반적으로 타사 메일 서비스에서 보낸 것처럼 편지를 보내는 또 다른 옵션이 사용됩니다.

이 방법을 인증을 통해 SMTP를 통해 메일을 보내는 것입니다. 오늘은 양식 제출의 예를 사용하여 살펴보겠습니다. 피드백. 또한 이를 위해 SMTP를 통해 보내는 편지를 아주 간단하게 구성할 수 있는 꽤 유명하고 인기 있는 PHPMailer 라이브러리를 사용할 것입니다.

  • 피드백 편지를 보내는 방법
  • 피드백 양식 만들기
  • PHPMailer 라이브러리 설치
  • SMTP를 통해 메일을 보내기 위한 스크립트를 만듭니다.
  • 이메일 발송 확인 중
  • 사이트 소스 파일

피드백 편지를 보내는 방법

시작하기 전에 실무피드백 편지를 보낸 후 먼저 어떻게 할지 결정하겠습니다.

피드백 양식은 사용자가 사이트 관리자와 소통하여 메시지를 전달할 수 있도록 설계되었습니다. 일반적으로 이 양식은 여러 필드와 "제출" 버튼으로 구성됩니다.

원칙적으로 이메일을 보내려면 다음과 같이 사용자 및 메시지 내용에 대한 충분한 정보를 제공하는 몇 가지 필드만 사용하면 충분합니다.

  • "이름" - 메시지 보낸 사람의 이름을 입력합니다.
  • "이메일" - 주소용 이메일보내는 사람;
  • "메시지 제목";
  • "메시지 텍스트".

다른 사람을 추가할 수도 있지만. 예를 들어 전화번호(정말 필요한 경우)입니다.

우리의 경우 이러한 편지는 도메인이 연결된 메일 서비스에 대한 승인을 받아 실제 사서함에서 사이트 관리자의 주소로 전송됩니다.

이전 기사에서는 도메인 메일과 Yandex.Mail 서비스의 연결을 확인하는 데 중점을 두었으므로 이 옵션에 대한 메일을 보내겠습니다. 이것은 중요하지 않지만. 아래에는 변경 시 다음을 통해 이메일을 보낼 수 있는 옵션이 표시됩니다. 메일 서버 Mail.ru.

편지가 전송되는 실제 사서함으로 새로 생성된 도메인 메일 사용자의 계정을 주소와 함께 사용합니다. [이메일 보호됨]. 그리고 우리는 이 편지를 다음에게 보낼 것입니다. 사서함관리자 [이메일 보호됨], 이전 기사에서 이전에 만든 것입니다.

따라서 피드백 양식의 편지를 보낸 사람이 사서함이 됩니다. [이메일 보호됨]., 그리고 수신자 - [이메일 보호됨]. 이 경우, 메시지를 보낸 사용자에 대한 모든 정보와 그 내용이 보낸 편지의 본문에 포함되어 전송됩니다.

피드백 양식 만들기

편지를 보내는 절차를 결정한 후에는 이를 수행할 피드백 양식을 작성하겠습니다.

다음은 "연락처" 페이지(기사 디렉토리의 kontakty.php 파일)에 배치할 이 양식의 HTML 코드입니다.

    "기사" >

    콘택트 렌즈

    피드백

    "연락하다"행동 = "#" 방법 = "우편" >

    피드백 폼

    모든 질문, 요청 및 사업 제안에 대해서는 아래 피드백 양식을 사용하여 문의하실 수 있습니다.

    "접촉 블록" >

    "연락처 입력" >

    "텍스트"아이디 = "담당자 이름"이름 = "담당자 이름"제목 = "이름은 러시아어로 되어 있어야 하며 3자 이상이어야 합니다." 패턴 = "{3,}" 필수 >

  1. "빈 접촉" >

    "연락처 입력" >

    "이메일"아이디 = "이메일 연락처"이름 = "이메일 연락처"필수 >

  2. "연락처 제목" >

  3. "연락처-댓글" >

  4. "연락처 버튼" >

    "제출하다"이름 = "연락처 버튼"값 = "보내다" >

Fig.1 피드백 양식의 HTML 코드

여기에 표시된 피드백 양식이 다음 스크린샷에서 최종적으로 어떻게 보이는지 확인할 수 있습니다.

따라서 필수 양식만들어진. 이제 이메일 메시지 형식으로 데이터를 처리하고 전송하는 문제로 넘어갈 수 있습니다.

PHPMailer 라이브러리 설치

이전에 언급한 것처럼 메일을 보내기 위해 PHPMailer 라이브러리를 사용합니다. 이는 PHPMailer 라이브러리를 통해 이메일 보내기를 크게 단순화합니다. SMTP 프로토콜제3자 메일 서비스에 대한 승인을 받아.

설치하려면 다운로드가 필요합니다 필요한 파일. 이는 Composer(PHP용 패키지 종속성 관리자)를 사용하여 GitHub 웹 서비스에서 수행할 수 있습니다. 아니면 일반적인 방법으로 필요한 파일을 다운로드하면 됩니다.

스크린샷 73

아래는 PHPMailer 라이브러리의 일반 다운로드 링크가 표시된 GitHub 웹 서비스 페이지입니다.

게다가, 최신 버전본 글 작성 당시 저장되어 있던 6.0.7은 첨부된 자료에서 다운로드 받으실 수 있습니다.

어떤 경우든 결과 아카이브 파일의 압축을 풀어야 하며, 그 후에 모든 내용이 포함된 추출된 PHPMailer-master 폴더를 사이트 루트에 배치해야 합니다. 동시에 단순화를 위해 이름을 PHPMailer로 바꿀 수 있습니다. 아래는 사이트의 루트 디렉터리에 있는 PHPMailer 폴더의 내용입니다.

따라서 우리는 PHPMailer 라이브러리를 설치했습니다. 그런 다음 웹사이트에서 이메일 메시지를 보내는 데 사용할 스크립트 작성을 시작할 수 있습니다.

SMTP를 통해 메일을 보내기 위한 스크립트를 만듭니다.

스크립트를 작성하려면 이전에 라이브러리를 다운로드하는 데 사용했던 GitHub 페이지에 제공된 PHPMailer 사용에 대한 권장 사항을 사용하면 충분합니다.

특히 스크립트 시작 부분에서 PHPMailer 클래스를 전역 네임스페이스로 가져와야 함을 나타냅니다. 그리고 해당 코드의 특정 줄이 제공됩니다. SMTP를 통해 메일을 보내는 옵션을 포함하여 PHPMailer의 속성과 메서드를 사용하는 예도 있습니다.

하지만 이것이 충분하지 않다면 이 라이브러리의 모든 속성과 메서드에 대한 설명이 포함된 설명서를 사용할 수도 있습니다.

스크린샷 74

아래는 승인을 받아 SMTP를 통해 피드백 양식의 메일을 보내기 위한 스크립트 코드입니다. PHPMailer와 관련된 모든 라인에 대한 설명이 제공되고 밝은 배경으로 강조 표시됩니다.

이전에 다른 프로세서에서 사용해야 했던 양식의 데이터 수신 및 처리와 관련된 조각을 포함한 나머지 부분은 어두운 배경으로 표시됩니다. 이는 PHP의 양식에서 데이터를 얻고 확인하는 문제를 구체적으로 다룬 기사의 앞부분에서 자세히 논의되었습니다. 양식 데이터의 유효성을 검사하고 처리하기 위한 범용 사용자 기능에 대해서도 이야기했습니다. check_symbol().

이 스크립트를 이전에 피드백 양식을 생성했던 것과 동일한 kontakty.php 파일에 배치하겠습니다.

    //----PHPMailer를 사용하여 SMTP를 통해 메일을 보내는 스크립트----

    //PHPMailer 클래스를 전역 네임스페이스로 가져옵니다. 함수 내부가 아닌 스크립트 상단에 있어야 합니다.

    사용 PHPMailer\PHPMailer\PHPMailer ;

    사용 PHPMailer\PHPMailer\Exception ;

    만약에 (!비어 있는($_POST["연락처 버튼" ])) (

    $name = $_POST["연락처 이름" ];

    $name = check_symbol ($name, "이름" , "1" , "/^+\z/iu" );

    $email = $_POST["연락처-이메일" ];

    $email = check_symbol ($email, "이메일" , "1" , "/^+@(+\.)+(2,6)\z/i");

    $subject = $_POST["연락처-제목" ];

    $subject = check_symbol ($subject, "메시지 제목" , "1" , "0" );

    $comment = $_POST["연락처-댓글" ];

    $comment = check_symbol($comment, "메시지 텍스트", "1" , "0" );

    만약에 (!비어 있는($GLOBALS["경고" ])) (

    $경고 = "양식 데이터가 전송되지 않았습니다. 다음 오류가 발견되었습니다:\n".$경고;

    포함하다"경고.php" ;

    또 다른 {

    //라이브러리 연결

    필요하다"PHPMailer/src/PHPMailer.php" ;

    필요하다"PHPMailer/src/Exception.php" ;

    필요하다"PHPMailer/src/SMTP.php" ;

    $메일 = 새로운 PHP메일러(); //클래스 초기화

    $에서 = " [이메일 보호됨]" ; //편지를 보낸 이메일 주소

    $에 = " [이메일 보호됨]" ; //받는 사람의 주소

    $mail -> isSMTP(); //SMTP 프로토콜 사용

    $mail -> 호스트 = "smtp.yandex.ru" ; //메일서버 주소

    $mail -> SMTPAuth = 진실 ; //인증 모드 활성화

    $mail -> 사용자 이름 = " [이메일 보호됨]" ; //타사 이메일 서비스(이 경우 Yandex.Mail)에 연결된 도메인 이메일에서 로그인

    $mail -> 비밀번호 = "27MrDon89" ; //도메인 메일 비밀번호

    $mail -> SMTPSecure = "ssl" ; //암호화 프로토콜

    $mail -> 포트 = "465" ; //SMTP 서버 포트

    $mail -> CharSet = "UTF-8" ; //부호화

    $mail -> setFrom ($from, "관리자" ); //보내는 사람의 주소와 이름

    $mail -> addAddress ($to, "관리자" ); //받는 사람의 주소와 이름

    $mail -> isHTML( 진실 ); //이메일 형식을 HTML로 설정

    $mail -> 제목 = '의견 양식이 제출되었습니다.'; //이메일 제목(heading)

    $mail -> 본문 = "

    보내는 사람 이름: $name

    보내는 사람의 주소: $이메일

    메시지 제목: $주제

    메시지 내용: $댓글



    " ; //메시지 내용

    $mail -> AltBody = "대체 문자 텍스트"; //이메일 클라이언트가 HTML 형식을 지원하지 않는 경우 대체 이메일

    $mail -> SMTPDebug = 0 ; //SMTP 디버깅 활성화: 0 - 꺼짐(일반 사용의 경우), 1 = 클라이언트 메시지, 2 - 클라이언트 및 서버 메시지

    만약에($mail -> 보내기()) (

    $경고 = "메시지 전송 됨"; //성공적인 편지 전송에 대한 메시지를 브라우저 대화 상자에 출력합니다.

    또 다른 {

    $경고 = "오류, 이메일을 보낼 수 없습니다: ".$mail -> 오류정보 ; //오류 메시지 출력

    포함하다"경고.php" ;

그림 5 인증을 통해 SMTP를 통해 이메일을 보내는 스크립트

보시다시피, 필요한 방법과 속성이 지정된 전자 메일 메시지 보내기와 직접 관련된 모든 줄에는 주석이 함께 제공됩니다. 따라서 반복하는 것은 의미가 없지만 실제로 추가 설명이 필요한 일부에만 머물 수 있습니다. 즉:

1. 편지가 타사 메일 서비스에서 전송된다는 사실로 인해 특정 SMTP 서버에 해당하는 설정이 여기에 적용됩니다. 이 경우 Yandex.Mail 서버 사용 사례의 경우 다음 속성 값이 적용됩니다.

  • 재산 주인(pos.28) - 값이 smtp.yandex.ru인 메일 서버 주소;
  • 재산 SMTP보안
  • 재산 포트

이러한 속성 값은 다음 스크린샷에 표시된 Yandex.Help 페이지에서 가져왔습니다.

그러나 그러한 정보는 다른 리소스에서도 얻을 수 있습니다. 이렇게 하려면 검색 엔진에 "Yandex smtp 서버"와 같은 적절한 쿼리를 입력하기만 하면 됩니다. 이 문제에 대한 많은 참고 자료를 어디에서 찾을 수 있습니까?

비슷한 방법으로 다른 SMTP 서버에서도 설정 값을 얻을 수 있습니다. 다음은 Mail.ru 메일 서비스의 SMTP 서버 설정을 표시하는 Mail.ru 도움말 페이지의 스크린샷입니다.

따라서 Mail.ru를 타사 SMTP 서버로 사용하는 경우 PHPMailer 클래스 속성의 다음 값을 적용해야 합니다.

  • 재산 주인(pos.28) - 메일 서버 주소 (smtp.mail.ru);
  • 재산 SMTP보안(pos.32) - 암호화 프로토콜(ssl);
  • 재산 포트(위치 33) - SMTP 서버 포트(465).

다른 이메일 서비스에도 유사한 접근 방식을 적용해야 합니다.

2. 부동산 내 사용자 이름(pos. 30) 도메인 메일함의 전체 주소를 표시해야 합니다. 이 경우 " [이메일 보호됨]".

다만, 도메인 메일 계정이 아닌 다른 계정을 사용하여 편지를 보내는 경우에는 메일 서비스와 직접적으로 관련된 주소를 사용하는 경우(예: " [이메일 보호됨]"인 경우 로그인은 "@" 기호까지의 주소 부분이어야 합니다. 이 경우 로그인의 값은 "feedback"입니다.

3. PHPMailer는 속성을 제공합니다 SMTP디버그(pos. 50), 브라우저 화면에 다양한 수준의 오류를 표시할 수 있습니다. 이 기능은 스크립트를 디버깅할 때 문제를 찾는 것을 크게 단순화합니다.

일반적으로 일반 모드에서는 값을 0으로 설정하면 자세한 오류 정보 출력이 비활성화됩니다. 그러나 메일 전송이나 디버깅 중에 문제가 발생하는 경우 다른 값을 사용하여 오류에 대한 보다 의미 있는 정보를 표시할 수 있습니다.

이것이 실제로 어떻게 보이는지 확인하기 위해 일시적으로 설정에 일부 오류를 도입해 보겠습니다. 예를 들어, 도메인 메일 비밀번호(속성 비밀번호, 31항). 또한 속성에 임시로 설정된 오류에 대한 자세한 정보를 표시합니다. SMTP디버그(pos.50) 값 1. 모든 것이 디버깅되고 확인되면 SMTP 디버깅 모드를 비활성화하고 1을 0으로 바꿉니다.

스크립트의 마지막 부분에서는 필요한 모든 속성과 메서드를 지정한 후 해당 메서드를 사용하여 편지를 보냅니다. 보내다()) (위치 51). 그리고 편지를 보낸다면, 그리고 방법은 보내다()대상을 위해 $mail true를 반환한 다음 브라우저 대화 상자에서 변수를 통해 $경고메일 전송 성공에 대한 메시지가 표시됩니다(52번).

어떤 이유로 메일을 보낼 수 없어 메서드가 true를 반환할 수 없는 경우 이 상태에는 해당 오류 메시지(위치 55)가 표시됩니다.

이메일 발송 확인 중

메일을 보내기 위한 스크립트를 만든 후에는 당연히 "창의성"의 결과를 살펴봐야 합니다. 여기에서 모든 것을 고려했는데 실수는 없었나요?

이를 위해 의도한 대로 피드백 양식에서 사용자가 사이트 관리자에게 메시지를 보내도록 시도해 보겠습니다. 다음은 제출 전 필드가 채워진 피드백 양식의 스크린샷입니다.

그리고 다음은 양식을 제출한 결과입니다.

브라우저 대화 상자의 메시지를 보면 SMTP 연결 문제로 인해 편지를 보낼 수 없다는 것이 분명합니다.

하지만 이제부터 부동산은 SMTP디버그(pos. 50)에 값 1이 할당되면 발생한 오류에 대한 자세한 정보를 볼 수 있고 오류 발생 이유를 알아낼 수 있습니다.

다음 스크린샷은 연결을 시도할 때 잘못된 로그인 또는 비밀번호 사용을 의미하는 인증 오류가 감지되었음을 보여줍니다.

비밀번호 불일치(이전에는 오류에 대한 추가 정보 출력을 확인하기 위해 잘못된 비밀번호를 사용함)를 제거한 후 메일을 다시 보내도록 시도합니다.

이번에는 모든 일이 순조롭게 진행되는 것 같았고 메일이 성공적으로 전송되었다는 메시지를 받았습니다. 분명히 도메인 메일 비밀번호에 고의로 일시적인 오류를 입력한 것 외에는 다른 실수는 하지 않았습니다.

하지만 편지가 실제로 수취인에게 전달되었는지 확인하기 위해 메일에 주소를 입력해 보겠습니다. [이메일 보호됨]그리고 결과를 보세요.

보시다시피 주소에서 온 편지입니다. [이메일 보호됨], "Feedback"이라는 이름의 이메일 메시지가 사이트 관리자에게 성공적으로 전달되었습니다. 동시에 편지 본문에는 피드백 양식에서 받은 데이터를 사용하여 스크립트에서 생성한 모든 콘텐츠가 포함됩니다.

  • 보낸 사람 이름: 니콜라이;
  • 보내는 사람의 주소: [이메일 보호됨];
  • 메시지 제목: 메일 발송 확인 중;
  • 메시지 내용: 테스트 메시지입니다.

이제 메일 전송을 성공적으로 확인한 후 속성을 할당하여 SMTP 디버깅 모드를 비활성화할 수 있습니다. SMTP디버그(pos.50) 값 0.

따라서 우리는 타사 메일 서버를 사용하여 인증을 받아 SMTP를 통해 메일을 보내는 도구를 만드는 작업을 완료했습니다.

예를 들어, 다음 기사에서는 등록된 사용자 계정 데이터를 복구하기 위해 확인 이메일을 보내는 방법을 살펴보겠습니다.

사이트 소스 파일

이 기사에서 업데이트된 사이트의 소스 파일은 첨부된 추가 자료에서 다운로드할 수 있습니다.

  • www 디렉토리 파일
  • MySQL 데이터베이스 테이블

로컬 서버에서 SMTP를 통해 메일을 보내면 로컬 컴퓨터에 있는 사이트, 더 간단하게는 로컬 서버에서 메시지 보내기를 테스트할 수 있습니다. 이를 위해 Yandex, Google 또는 mail.ru 메일 서비스를 사용할 수 있습니다.

우선, SMTP(Simple Mail Transfer Protocol)는 TCP/IP 네트워크를 통해 이메일을 전송하도록 설계된 널리 사용되는 네트워크 프로토콜입니다. 그리고 널리 사용되는 모든 이메일 서비스에는 이러한 프로토콜이 있습니다.

로컬 서버의 출현으로 개별 스크립트나 cms 시스템의 성능을 확인하기 위해 더 이상 호스팅 제공업체를 선택할 필요가 없었고 그에 따른 비용도 더 이상 들지 않았습니다. 컴퓨터에서 모든 것을 테스트하는 것이 훨씬 쉬우며, 자신이 "수행한" 작업을 모든 사람에게 보여줄 수 있습니다.

이러한 서버 중 다수에는 이미 소프트웨어와 메일 작업에 필요한 기능이 내장되어 있으므로 올바르게 구성하기만 하면 됩니다.

해당 메일의 기능을 확인하려면 최소한 다음 사항이 필요합니다.

  • Openserver를 로컬 서버로 사용할 수 있습니다.
  • 그리고 간단한 스크립트는 바로 아래에서 찾을 수 있는 템플릿입니다.
  • 모든 메일 서버를 사용할 수 있습니다.

SMTP 스크립트 설정을 통해 PHP 메일 보내기

아래에서 복사하거나 수백 개의 유사한 사이트에서 다운로드할 수 있는 간단한 스크립트 템플릿을 편집해야 합니다.

먼저 스크립트 템플릿에서 일부 값을 변경해야 합니다.
에게 — 메일 메시지가 전송될 우편 주소로 변경합니다.
주제 - 편지 제목
메시지 — 메시지 자체 또는 편지 본문.

내 스크립트의 예:

물론 기능을 약간 확장하여 스크립트가 메일 전송에 대한 메시지를 표시하도록 할 수 있습니다. 실제로 전송을 수행하는 것은 SMTP 서버이고 스크립트는 메시지만 생성합니다.

예를 들어 다음과 같이 작성할 수 있습니다.

모든 대체 값은 따옴표로 묶어야 합니다. 그렇지 않으면 스크립트에서 오류가 발생합니다. 그런 다음 스크립트를 로컬 서버 폴더에 저장할 수 있습니다.

예를 들어: 도메인/send/index.php SMTP opensrever를 통해 메일 전송 설정을 시작합니다.

메일은 값 대신 스크립트에 지정된 주소로 도착합니다. '에게' 하지만 이 메일은 openserver 설정에 지정된 SMTP에 의해 정확하게 처리되고 전송됩니다.

  1. 서버 시작
  2. "mail" 메뉴의 설정으로 openserver 모듈을 엽니다.
  3. 그림과 같이 모든 필드를 채우고 실제 Yandex 사서함에서 사용자 이름, 보낸 사람의 이메일 및 비밀번호를 대체합니다.

설정을 저장하고 서버가 다시 시작된 후 스크립트 자체에 액세스할 수 있습니다. "내 사이트" 폴더에서 이전에 저장한 index.php 스크립트가 있는 "send" 폴더를 엽니다.

이 스크립트에 액세스하자마자 새 브라우저 창에 스크립트가 완료되었음을 나타내는 정보가 나타납니다.

그런 다음 스크립트에 주소가 지정된 사서함을 확인하여 편지가 도착했는지 확인해야합니다.

거기에 없으면 무언가가 올바르게 구성되지 않았거나 편지가 스팸 폴더에 있다는 의미입니다.

다른 모든 설정은 비슷해 보이지만 혹시라도 추가 정보가 손상되지는 않습니다.

SMTP mail ru를 통해 메일 전송을 설정하려면 Yandex 매개변수를 mail ru 매개변수로 바꾸면 됩니다.

그리고 매번 로컬 서버를 재구축하지 않으려면 서로 다른 openserver 프로필을 구성하는 것이 가장 좋습니다. 이를 수행하는 방법은 비디오 튜토리얼에 나와 있습니다.

이 경우 프로필을 로드하기만 하면 충분하며 서버를 다시 시작한 후에는 이 프로필에 지정된 모든 설정을 사용할 수 있습니다. 그것은 매우 편리하고 매우 간단하게 작동합니다.

각 프로필(이름은 전혀 중요하지 않음)에 대해 고유한 설정을 지정해야 합니다. 단, 스크립트, cms 시스템 및 다른 매개변수를 사용하는 응용 프로그램을 사용하려는 경우는 예외입니다.
그렇지 않은 경우 기본 설정을 사용하면 됩니다.

SMTP 메일 ru의 경우 모든 것이 동일합니다.

Yandex 데이터가 메일 ru 데이터로 변경되었습니다.

smtp google을 통해 메일 보내기

Google SMTP를 통해 메일 전송을 설정하려면 약간의 노력이 필요합니다.

첫째, Google에서 프로필을 만드는 것이 다른 Yandex 및 메일 ru 시스템보다 어렵습니다.
둘째, 귀하가 로그인 정보를 제공하더라도 시스템은 단순히 편지를 통과시키지 않습니다. 우선, 그녀는 추가 지침에 대해 필요한 모든 정보가 포함된 편지를 보낼 것입니다.

그렇지 않으면 Google의 경우 정확히 동일한 방식으로 구성됩니다. 모든 데이터만 변경됩니다.

다른 SMTP를 통해 메일 전송을 구성하려면 모든 데이터가 거의 동일합니다.

모든 것이 잘 진행되고 편지가 지정된 수취인에게 도달하면 모든 것이 올바르게 완료된 것입니다. 댓글로 경험을 공유해 주시면 좋을 것 같습니다.

특정 웹사이트가 효율적이고 생산적으로 작동할 수 있는 기회를 가지려면 가능한 한 책임감 있고 신중하게 웹사이트 제작에 접근해야 합니다. 온라인 상점을 만드는 데 사용할 시스템 선택에는 특별한 주의가 필요합니다. 사실 상품이나 서비스 판매를 전문으로 하는 상업 플랫폼은 사이트 유지 관리 및 채우기에 관련된 관리자와 온라인 상점 고객 모두에게 필요한 모든 기능을 구현하고 사용하기 쉬워야 합니다. 자신에게 적합한 CMS를 선택해야 하는 문제에 직면한 많은 사람들과 회사는 Magento를 선택할지, OkkaCMS를 선택할지 분석합니다. 이러한 웹사이트 엔진의 특징과 성능을 비교해 보겠습니다.

자신의 웹 사이트를 작업할 때 개인이나 회사는 많은 노력을 기울여야 합니다. 이 경우에만 긍정적인 결과를 기대할 수 있고 진정으로 효과적인 도구를 얻을 수 있습니다. 웹사이트 제작을 시작하기 전에 먼저 해결해야 할 근본적인 질문 중 하나는 가장 적합한 CMS 옵션을 어떻게 결정하느냐 하는 것입니다. 다음으로 두 가지 CMS(Joomla 또는okayCMS)를 비교하고 각각의 기능에 주목하겠습니다.

자신만의 웹사이트를 갖는 것은 효과적이고 성공적으로 운영되는 비즈니스를 위한 기본 요구 사항 중 하나입니다. 통계에 따르면 인터넷을 통한 다양한 상품 구매 및 서비스 주문 수가 증가한 것으로 나타났습니다. 이를 고려하여 대부분의 상업 회사는 이미 자체 웹사이트의 필요성을 인식하고 있습니다. 그러나 인터넷 리소스를 보유하고 있다는 단순한 사실만으로는 그 효율성, 수익성 및 기대되는 비즈니스 이점을 기대하기에 충분하지 않습니다.

자신만의 웹사이트를 만들거나 온라인 상점을 오픈하려고 준비할 때, 많은 문제를 고려하고 분석하고 다양한 문제를 해결해야 합니다. 이 경우에만 귀하의 프로젝트가 긍정적인 결과를 가져오고 귀하의 기대를 완전히 충족시킬 수 있다는 사실을 믿을 수 있습니다. 온라인 상점 개발과 관련된 다양한 문제 중 CMS 선택 문제는 특히 주목할 만합니다. 귀하가 최적의 엔진을 스스로 쉽게 결정할 수 있도록

미래의 온라인 상점을 위한 자체 웹사이트를 만들 계획을 세울 때 상당히 많은 수의 사람들, 심지어 판매 전문 회사조차도 기존 CMS 중 무엇을 선택할 것인지 어렵고 매우 중요한 선택에 직면합니다. 무엇을 선택할지 고민 중이라면 PrestaShop 또는 OKCMS를 읽어 보시기 바랍니다. 이 기사에서는 인터넷 사이트, 특히 온라인 상점을 만들기 위한 이 두 시스템을 비교할 것입니다.

가상 Windows 호스팅 서버에서는 익명 메시지를 보내는 것이 금지되어 있으므로 편지를 보내는 것은 SMTP 서버를 통해 이루어져야 하며, 이 경우 당사의 메일 시스템도 사용할 수 있습니다.

PHP를 사용하여 이메일을 보내는 방법은 무엇입니까?

smtp 서버에서 인증을 지원하는 PHP 클래스를 사용합니다. 예를 들어 PHPMailer 클래스 세트를 사용할 수 있습니다.

인증이 필요한 smtp 서버를 사용하여 편지 보내기를 구현하는 예제를 사용할 수도 있습니다. 따라서 스크립트에 적절한 액세스 세부정보를 추가하는 것을 잊지 마세요. 예:

// SMTP 세션 로그를 표시해야 하는 경우 다음 줄의 주석 처리를 제거할 수 있습니다. // $_SERVER["debug"] = true;기능 MailSmtp ($reciever, $subject, $content, $headers, $debug = 0) ( $smtp_server = "smtp.site"; // SMTP 서버 주소$smtp_port = 25 ; // SMTP 서버 포트$smtp_user = " [이메일 보호됨]" ; // SMTP 서버 인증을 위한 사용자 이름$smtp_password = "pAsSwORd" ; // SMTP 서버 인증을 위한 비밀번호$mail_from = " [이메일 보호됨]" ; // 편지가 발송된 우편함$sock = fsockopen($smtp_server, $smtp_port, $errno, $errstr, 30); $str = fgets($sock, 512); if (! $sock ) ( printf ( "소켓이 생성되지 않았습니다\n" ); exit(1 ); ) smtp_msg ($sock , "HELO " . $_SERVER [ "SERVER_NAME" ]); smtp_msg($sock, "인증 로그인"); smtp_msg($sock, base64_encode($smtp_user)); smtp_msg($sock, base64_encode($smtp_password)); smtp_msg ($sock , "메일 보낸 사람:<" . $mail_from . ">" ); smtp_msg ($sock , "RCPT 대상:<" . $reciever . ">" ); smtp_msg ($sock , "DATA" ); $headers = "제목: " . $subject . "\r\n" . $headers ; $data = $headers . "\r\n\r\n" . $content . "\r\n." ; smtp_msg ($sock , $data ); smtp_msg ($sock , "QUIT" ); fclose ($sock ); ) 함수 smtp_msg ($sock , $msg ) ( if ( ! $sock ) ( printf ("깨진 소켓!\n" ); exit(1 ); ) if (isset($_SERVER [ "debug" ]) && $_SERVER [ "debug" ]) ( printf ( "우리로부터 보내기 : %s
" , nl2br (htmlspecialchars ($msg )); ) fputs ($sock , " $msg \r\n" ); $str = fgets ($sock , 512 ); if (! $sock ) ( printf ( "소켓은 down\n" ); exit(1); ) else ( if (isset($_SERVER [ "debug" ]) && $_SERVER [ "debug" ]) ( printf ("서버에서 가져옴: %s
" , nl2br (htmlspecialchars ($str )); ) $e = 분해 (" " , $str ); $code = array_shift ($e ); $str = 파열 ( " " , $e ); if ($code > 499 ) ( printf ( "SMTP 대화에 문제가 있습니다.

코드 %d.
메시지 %s
"
, $code , $str ); 출구(1); ) ) ) ?>

MailSmtp() 함수가 포함된 미리 만들어진 스크립트의 예를 다운로드하세요: smtpauth.php.sample

위에서 설명한 MailSmtp() 함수를 사용하여 mail() 함수를 직접 대체할 수 있습니다. PHP에서 가장 간단한 형식의 예를 살펴보겠습니다.

// 메시지 헤더는 메시지 인코딩, 보낸 ​​사람, 받는 사람 필드 등을 정의합니다.$headers = "MIME 버전: 1.0\r\n" ; $헤더 .= "콘텐츠 유형: text/html; charset=windows-1251\r\n"; $headers .= "받는 사람: $to \r\n" ; $헤더 .= "보낸 사람: 보낸 사람 이름 " ; // 메일($to, $subject, $message, $headers); require_once "smtpauth.php" ; MailSmtp($to, $subject, $message, $headers); ) ?>
누구에게: 주제: 텍스트: 
 
 

이 양식이 mail() 함수 없이 작동하도록 하기 위해 require_once를 통해 smtpauth.php 파일을 포함시키고 mail()과 유사한 인수를 사용하여 여기에 설명된 MailSmtp() 함수를 호출했습니다. 동시에 스크립트 실행 시 오류를 방지하기 위해 코드에서 mail() 호출 자체를 주석 처리했습니다.

ASP.NET을 사용하여 이메일을 보내는 방법은 무엇입니까?

버전 2.0을 사용하는 경우 MailMessage 클래스를 사용하세요. System.Net.Mail), 잘 설명되어 있습니다.

다음은 C# 및 VisualBasic 언어에 대한 사용 예입니다.

C# 언어의 예:

<% @Page Language="c#" %> <% @Import Namespace="System.Net.Mail" %> <% @Import Namespace="System.Net" %> <% MailMessage message = new MailMessage(); //새 문자 만들기메시지.대상.추가(" [이메일 보호됨]"); //수취인 주소 추가 message.From = 새로운 MailAddress("from@ domain.tld", "보낸 사람 이름"); // 보낸 사람의 이름과 주소를 지정합니다. message.Subject = "메시지 제목"; // 편지의 제목 지정 message.BodyEncoding = System.Text.Encoding.UTF8; // 문자 인코딩 지정 message.IsBodyHtml = 거짓; // 문자 형식 지정(true - HTML, false - HTML 아님) message.Body = "메시지 텍스트"; // 편지의 텍스트(본문) 지정 SmtpClient 클라이언트 = new SmtpClient("smtp.site",25); // "smtp.site" 서버에 대한 새 연결 생성 client.DeliveryMethod = SmtpDeliveryMethod.Network; // 메시지 전송 방법을 정의합니다.클라이언트.EnableSsl = 거짓; // 서버에 대한 보안 연결을 사용할 필요가 없도록 합니다. client.UseDefaultCredentials = false; // 기본 인증 세부정보 사용을 비활성화합니다. client.Credentials = new NetworkCredential("postmaster@ domain.tld", "***비밀번호***"); // SMTP 서버 인증에 필요한 세부 정보(사용자 이름 및 비밀번호) 지정클라이언트.보내기(메시지); // 문자 보내 %>

이 방법의 사용을 보여주는 완성된 양식의 예인 MailForm.aspx를 다운로드하세요.

VisualBasic 언어의 예:

<% @Page Language="VB" Debug="true" %> <% @Import Namespace="System.Net.Mail" %> <% @Import Namespace="System.Net" %> <% Dim smtpMssg AS new MailMessage smtpMssg.From = New MailAddress ("admin@domain.tld", "Sender_name") smtpMssg.To.Add (" [이메일 보호됨]") "수취인 주소 추가 smtpMssg.Subject = "이메일 제목" "편지의 주제 표시 smtpMssg.Body = "메시지 텍스트" " 편지의 내용(본문) 표시 smtpMssg.BodyEncoding = System.Text.Encoding.UTF8 " 문자 인코딩 표시 smtpMssg.IsBodyHtml = 거짓 " 문자 형식 표시(true - HTML, false - HTML 아님) SmtpMail을 새 SmtpClient("smtp.site", 25)로 희미하게 표시 " "SmtpClient" 유형의 새 객체 선언 SmtpMail.DeliveryMethod = SmtpDeliveryMethod.Network "편지 배송 방법 안내 SmtpMail.UseDefaultCredentials = False "기본적으로 인증 자격 증명 사용을 비활성화합니다" SmtpMail.EnableSsl = 거짓 "는 서버에 대한 보안 연결을 사용할 필요성을 비활성화합니다. SmtpMail.Credentials = new NetworkCredential("postmaster@ domain.tld", "***비밀번호***") "SMTP 서버 인증에 필요한 세부 정보(사용자 이름 및 비밀번호)를 나타냅니다. SmtpMail.Send(smtpMssg) " 메시지를 보내는 중 %>

더 이상 사용되지 않는(그리고 더 이상 사용되지 않는) SmtpMail 클래스도 있습니다(네임스페이스 사용). 시스템.웹.메일). 다음은 VisualBasic 언어에 대한 사용 예입니다.

<% @Page Language="VB" Debug="true" %> <% @Import Namespace="System.Web" %> <% @Import Namespace="System.Web.Mail" %> <% Dim smtpMssg = new MailMessage " "MailMessage" 유형의 새 객체 선언 smtpMssg.From = "발신자_이름 domain.tld>" "발송인의 이름과 주소 표시 smtpMssg.To = "관리자@ domain.tld" "수취인의 주소 표시 smtpMssg.BodyFormat = MailFormat.Text " 문자 형식 표시 smtpMssg.BodyEncoding = 인코딩.UTF8 "문자 인코딩을 나타냅니다. smtpMssg.Subject = "이메일 제목" "편지의 주제 표시 smtpMssg.Body = "메시지 텍스트" " 편지 내용 표시 smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate",1) "서버에서 SMTP 인증이 필요함을 나타냅니다. smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/sendusername", "admin@ domain.tld") "인증을 위한 사용자 이름 smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/sendpassword", "***비밀번호***") "인증용 비밀번호 SmtpMail.SmtpServer = "smtp.site" " SMTP 서버 주소 지정 SmtpMail.Send(smtpMssg) " 메시지를 보내는 중 %>

ASP를 사용하여 이메일을 보내는 방법은 무엇입니까?

당사의 smtp 서버를 사용하는 경우 인증이 필요하므로 스크립트에 적절한 액세스 세부정보를 추가하는 것을 잊지 마십시오. 예:

<% iConfig = Server.CreateObject("CDO.Configuration") Set iConfig = Server.CreateObject("CDO.Configuration") With iConfig.Fields .Item("http://schemas.microsoft.com/cdo/configuration/smtpserver") = "smtp.сайт" .Item("http://schemas.microsoft.com/cdo/configuration/smtpserverport") = 25 .Item("http://schemas.microsoft.com/cdo/configuration/sendusing") = 2 .Item("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate") = 1 .Item("http://schemas.microsoft.com/cdo/configuration/languagecode") = "ru" .Item("http://schemas.microsoft.com/cdo/configuration/sendusername") = "postmaster@domain.tld" .Item("http://schemas.microsoft.com/cdo/configuration/sendpassword") = "password" .Update End With Set cdoMessage = CreateObject("CDO.Message") With cdoMessage Set .Configuration = iConfig .From = "테스트 사용자 domain.tld>" .To = "사용자 " .Subject = "안녕하세요, 사용자" .TextBody = "ASP 스크립트에서 이 메시지를 작성합니다." .Send End With Set cdoMessage = Nothing Set iConfig = Nothing %>

일부 CMS에는 이미 서신이나 해당 모듈을 보내기 위한 도구가 내장되어 있습니다. 가장 인기 있는 도구를 살펴보겠습니다.

워드프레스

이 CMS에는 "WP Mail SMTP"라는 특수 모듈이 있으며, 구성 예는 모듈 페이지에 설명되어 있습니다.

예제의 그림에 주의하십시오. 당사 메일 시스템에서는 포트 25를 사용해야 하며 SSL 암호화는 필요하지 않습니다.

줌라

관리 패널에서 "일반 설정" 섹션으로 이동하여 "서버" 탭을 선택합니다. "메일" 필드에서 전송 방법을 "SMTP 서버"로 선택해야 하며, "SMTP 서버 주소", "SMTP 로그인" 및 "SMTP 비밀번호" 필드에서 메일 시스템의 적절한 세부 정보를 지정해야 합니다. 예: smtp.site, 상자@your_domain그리고 그에 상응하는 비밀번호.

드루팔

이 CMS에는 SMTP 서버와 작업하기 위한 자체 모듈도 있습니다. PHP메일러.이 모듈은 CMS Drupal 웹사이트 페이지에서 다운로드할 수 있으며, 모듈 설치에 대한 설명은 모듈과 함께 제공되는 아카이브에서 확인할 수 있습니다.

넷캣

이 CMS에는 SMTP 서버 작업을 위한 내장 기능이 없습니다. 사이트 스크립트를 사용하여 메일을 보내려면 당사의 솔루션을 사용하도록 제안할 수 있으며 이를 연결하려면 다음 단계를 수행해야 합니다.

  • 당사 웹사이트에서 필요한 파일이 포함된 아카이브를 다운로드하세요( send_auth_mail.php그리고 mail.inc.php) 컴퓨터에서 압축을 풀어보세요.
  • 파일 편집 send_auth_mail.php아카이브에서 원하는 SMTP 서버에 대한 연결 세부 정보를 나타냅니다.

    • $mail_smtpServer = "smtp.site"; (SMTP 서버 주소)
    • $mail_port = "25" ; (연결 포트)
    • $mail_username = "[이메일 보호됨]" ; (SMTP 서버 인증을 위한 사용자 이름)
    • $mail_password = "비밀번호"; (SMTP 서버 인증을 위한 비밀번호)
  • 파일의 백업 복사본 만들기 domain.tld/www/netcat/admin/mail.inc.php;
  • 파일 다운로드 send_auth_mail.php그리고 mail.inc.php디렉토리의 가상 사이트로 domain.tld/www/netcat/admin/

domain.tld귀하의 도메인 이름으로 바꿔야 합니다.

제안된 솔루션은 이 CMS의 표준 기능을 사용하여 메일을 보내는 모든 NetCat 모듈에서 작동합니다.




맨 위